diff options
author | Michael Bien <[email protected]> | 2009-10-01 01:19:17 +0200 |
---|---|---|
committer | Michael Bien <[email protected]> | 2009-10-01 01:19:17 +0200 |
commit | be4e9559f16e3ac5a5d109b26fbb9d579345f25c (patch) | |
tree | 2e1dddf49650c1d7eade1aea936c0c76b735e5d1 /src/com/mbien/opencl | |
parent | a550876d23b84427667111c5e2700766752b6040 (diff) |
added utility methods and getters to CLPlatform, CLDevice and CLContext.
adapted unit test.
Diffstat (limited to 'src/com/mbien/opencl')
-rw-r--r-- | src/com/mbien/opencl/CLContext.java | 84 | ||||
-rw-r--r-- | src/com/mbien/opencl/CLDevice.java | 179 | ||||
-rw-r--r-- | src/com/mbien/opencl/CLPlatform.java | 11 |
3 files changed, 264 insertions, 10 deletions
diff --git a/src/com/mbien/opencl/CLContext.java b/src/com/mbien/opencl/CLContext.java index dc3c7279..533d45d4 100644 --- a/src/com/mbien/opencl/CLContext.java +++ b/src/com/mbien/opencl/CLContext.java @@ -1,14 +1,18 @@ package com.mbien.opencl; import com.mbien.opencl.impl.CLImpl; +import java.nio.ByteBuffer; +import java.nio.ByteOrder; +import java.nio.IntBuffer; /** * * @author Michael Bien */ -public class CLContext { +public final class CLContext { private final static CL cl; + public final long contextID; static{ System.loadLibrary("gluegen-rt"); @@ -16,6 +20,84 @@ public class CLContext { cl = new CLImpl(); } + private CLContext(long contextID) { + this.contextID = contextID; + } + + /** + * Creates a default context on all available devices. + */ + public static CLContext create() { + IntBuffer ib = IntBuffer.allocate(1); + long context = cl.clCreateContextFromType(null, 0, CL.CL_DEVICE_TYPE_ALL, null, null, null, 0); + +// int errorCode = ib.get(); +// if(errorCode != CL.CL_SUCCESS) +// throw new CLException(errorCode, "can not create CL context"); + + return new CLContext(context); + } + + /** + * Creates a default context on the specified device types. + */ + public static CLContext create(CLDevice.Type... deviceTypes) { + + int type = deviceTypes[0].CL_TYPE; + for (int i = 1; i < deviceTypes.length; i++) { + type |= deviceTypes[i].CL_TYPE; + } + + long context = cl.clCreateContextFromType(null, 0, type, null, null, null, 0); + return new CLContext(context); + } + + /** + * Releases the context and all resources. + */ + public void release() { + int ret = cl.clReleaseContext(contextID); + if(CL.CL_SUCCESS != ret) + throw new CLException(ret, "error releasing context"); + } + + /** + * Gets the device with maximal FLOPS from this context. + */ + public CLDevice getMaxFlopsDevice() { + + //TODO not finished + + long[] longBuffer = new long[1]; +// ByteBuffer bb = ByteBuffer.allocate(8); +// bb.order(ByteOrder.nativeOrder()); + + int ret = cl.clGetContextInfo(contextID, CL.CL_CONTEXT_DEVICES, 0, null, longBuffer, 0); + if(CL.CL_SUCCESS != ret) + throw new CLException(ret, "can not receive context info"); + + System.out.println("#devices: "+longBuffer[0]); + + long[] deviceIDs = new long[(int)longBuffer[0]]; + ret = cl.clGetContextInfo(contextID, CL.CL_CONTEXT_DEVICES, 0, null, deviceIDs, 0); + + if(CL.CL_SUCCESS != ret) + throw new CLException(ret, "can not receive context info"); + + for (int i = 0; i < deviceIDs.length; i++) { + long l = deviceIDs[i]; + System.out.println("device id"+l); + } + + // get the list of GPU devices associated with context +// ciErrNum = clGetContextInfo(cxGPUContext, CL_CONTEXT_DEVICES, 0, NULL, &dataBytes); +// cl_device_id *cdDevices = (cl_device_id *)malloc(dataBytes); +// ciErrNum |= clGetContextInfo(cxGPUContext, CL_CONTEXT_DEVICES, dataBytes, cdDevices, NULL); +// shrCheckError(ciErrNum, CL_SUCCESS); + + return null; + } + /** * Lists all available OpenCL implementaitons. * @throws CLException if something went wrong initializing OpenCL diff --git a/src/com/mbien/opencl/CLDevice.java b/src/com/mbien/opencl/CLDevice.java index 58d35fa9..3db2511f 100644 --- a/src/com/mbien/opencl/CLDevice.java +++ b/src/com/mbien/opencl/CLDevice.java @@ -1,15 +1,71 @@ package com.mbien.opencl; import java.nio.ByteBuffer; +import java.nio.ByteOrder; +import java.util.Collections; +import java.util.HashSet; +import java.util.Scanner; +import java.util.Set; /** - * + * * @author Michael Bien */ -public class CLDevice { +public final class CLDevice { + + //FIXME gluegen does not generate CL_DEVICE_TYPE_* remove hardcoded values ASAP + + /** + * Enumeration for the type of a device. + */ + public enum Type { + /** + * CL_DEVICE_TYPE_CPU + */ + CPU(1 << 1), + /** + * CL_DEVICE_TYPE_GPU + */ + GPU(1 << 2), + /** + * CL_DEVICE_TYPE_ACCELERATOR + */ + ACCELERATOR(1 << 3), + /** + * CL_DEVICE_TYPE_DEFAULT + */ + DEFAULT(1 << 0); + + /** + * Value of wrapped OpenCL device type. + */ + public final int CL_TYPE; + + private Type(int CL_TYPE) { + this.CL_TYPE = CL_TYPE; + } + + public static Type valueOf(int clDeviceType) { + switch(clDeviceType) { + case(1 << 0): + return DEFAULT; + case(1 << 1): + return CPU; + case(1 << 2): + return GPU; + case(1 << 3): + return ACCELERATOR; + } + return null; + } + } private final CL cl; - private final long deviceID; + + /** + * OpenCL device id for this device. + */ + public final long deviceID; CLDevice(CL cl, long id) { this.cl = cl; @@ -23,7 +79,96 @@ public class CLDevice { return getInfoString(CL.CL_DEVICE_NAME); } - public String getInfoString(int key) { + /** + * Returns the OpenCL profile of this device. + */ + public String getProfile() { + return getInfoString(CL.CL_DEVICE_PROFILE); + } + + /** + * Returns the vendor of this device. + */ + public String getVendor() { + return getInfoString(CL.CL_DEVICE_VENDOR); + } + + /** + * Returns the type of this device. + */ + public Type getType() { + return Type.valueOf((int)getInfoLong(CL.CL_DEVICE_TYPE)); + } + + /** + * Returns the maximal number of compute units. + */ + public int getMaxComputeUnits() { + return (int) getInfoLong(CL.CL_DEVICE_MAX_COMPUTE_UNITS); + } + + /** + * Returns the maximal work group size. + */ + public int getMaxWorkGroupSize() { + return (int) getInfoLong(CL.CL_DEVICE_MAX_WORK_GROUP_SIZE); + } + + /** + * Returns the max clock frequency in Hz. + */ + public int getMaxClockFrequency() { + return (int) (getInfoLong(CL.CL_DEVICE_MAX_CLOCK_FREQUENCY)); + } + + /** + * Returns the global memory size in Bytes. + */ + public long getGlobalMemSize() { + return getInfoLong(CL.CL_DEVICE_GLOBAL_MEM_SIZE); + } + + /** + * Returns the local memory size in Bytes. + */ + public long getLocalMemSize() { + return getInfoLong(CL.CL_DEVICE_LOCAL_MEM_SIZE); + } + + /** + * Returns all device extension names as unmodifiable Set. + */ + public Set<String> getExtensions() { + + String ext = getInfoString(CL.CL_DEVICE_EXTENSIONS); + + Scanner scanner = new Scanner(ext); + Set<String> extSet = new HashSet<String>(); + + while(scanner.hasNext()) + extSet.add(scanner.next()); + + return Collections.unmodifiableSet(extSet); + } + + //TODO CL_DEVICE_IMAGE_SUPPORT + //TODO CL_DEVICE_MAX_WORK_ITEM_SIZES + + + private final long getInfoLong(int key) { + + ByteBuffer bb = ByteBuffer.allocate(8); + bb.order(ByteOrder.nativeOrder()); + + int ret = cl.clGetDeviceInfo(deviceID, key, bb.capacity(), bb, null, 0); + + if(CL.CL_SUCCESS != ret) + throw new CLException(ret, "can not receive device info"); + + return bb.getLong(); + } + + public final String getInfoString(int key) { long[] longBuffer = new long[1]; ByteBuffer bb = ByteBuffer.allocate(512); @@ -31,12 +176,32 @@ public class CLDevice { int ret = cl.clGetDeviceInfo(deviceID, key, bb.capacity(), bb, longBuffer, 0); if(CL.CL_SUCCESS != ret) - throw new CLException(ret, "can not receive info string"); + throw new CLException(ret, "can not receive device info string"); return new String(bb.array(), 0, (int)longBuffer[0]); } -// ret = cl.clGetDeviceInfo(device, CL.CL_DEVICE_TYPE, bb.capacity(), bb, longBuffer, 0); -// assertEquals(CL.CL_SUCCESS, ret); + + @Override + public String toString() { + return "CLPlatform [name:" + getName() + + " type:" + getType() + + " profile: " + getProfile()+"]"; + } + + @Override + public boolean equals(Object obj) { + if(obj != null && obj instanceof CLDevice) + return ((CLDevice)obj).deviceID == deviceID; + return false; + } + + @Override + public int hashCode() { + int hash = 3; + hash = 79 * hash + (int) (this.deviceID ^ (this.deviceID >>> 32)); + return hash; + } + } diff --git a/src/com/mbien/opencl/CLPlatform.java b/src/com/mbien/opencl/CLPlatform.java index 582e8abc..252872dc 100644 --- a/src/com/mbien/opencl/CLPlatform.java +++ b/src/com/mbien/opencl/CLPlatform.java @@ -6,9 +6,13 @@ import java.nio.ByteBuffer; * * @author Michael Bien */ -public class CLPlatform { +public final class CLPlatform { + + /** + * OpenCL platform id for this platform. + */ + public final long platformID; - private final long platformID; private final CL cl; CLPlatform(CL cl, long id) { @@ -16,6 +20,9 @@ public class CLPlatform { this.cl = cl; } + /** + * Lists all physical devices available on this platform. + */ public CLDevice[] listCLDevices() { int[] intBuffer = new int[1]; |