diff options
author | Michael Bien <[email protected]> | 2010-02-12 02:15:06 +0100 |
---|---|---|
committer | Michael Bien <[email protected]> | 2010-02-12 02:15:06 +0100 |
commit | a93e4532f9515f5b2c0d2c67a45db1236a29ab12 (patch) | |
tree | 71623ffb0c352481d0eaa816d3a842245a403121 /src/com | |
parent | 3d033bfadaf569d2198de6ca5dfac855dc25ac35 (diff) |
fixed bug in CL[GL]Context.create(..., device), added test.
CLKernel is now Cloneable.
Diffstat (limited to 'src/com')
-rw-r--r-- | src/com/mbien/opencl/CLContext.java | 12 | ||||
-rw-r--r-- | src/com/mbien/opencl/CLDevice.java | 4 | ||||
-rw-r--r-- | src/com/mbien/opencl/CLGLContext.java | 16 | ||||
-rw-r--r-- | src/com/mbien/opencl/CLKernel.java | 12 |
4 files changed, 32 insertions, 12 deletions
diff --git a/src/com/mbien/opencl/CLContext.java b/src/com/mbien/opencl/CLContext.java index e75aaddd..99322035 100644 --- a/src/com/mbien/opencl/CLContext.java +++ b/src/com/mbien/opencl/CLContext.java @@ -113,7 +113,7 @@ public class CLContext implements CLResource { * Creates a context on the specified platform and with the specified * device types. */ - private static final CLContext create(CLPlatform platform, CLDevice.Type... deviceTypes) { + public static final CLContext create(CLPlatform platform, CLDevice.Type... deviceTypes) { long type = toDeviceBitmap(deviceTypes); @@ -125,10 +125,16 @@ public class CLContext implements CLResource { * Creates a context on the specified platform and with the specified * devices. */ - private static final CLContext create(CLPlatform platform, CLDevice[] devices) { + public static final CLContext create(CLPlatform platform, CLDevice... devices) { PointerBuffer properties = setupContextProperties(platform); - return new CLContext(createContext(properties, devices)); + CLContext context = new CLContext(createContext(properties, devices)); + if(devices != null) { + for (int i = 0; i < devices.length; i++) { + devices[i].setContext(context); + } + } + return context; } protected static final long createContextFromType(PointerBuffer properties, long deviceType) { diff --git a/src/com/mbien/opencl/CLDevice.java b/src/com/mbien/opencl/CLDevice.java index c6134248..d6013166 100644 --- a/src/com/mbien/opencl/CLDevice.java +++ b/src/com/mbien/opencl/CLDevice.java @@ -72,6 +72,10 @@ public final class CLDevice { CLContext getContext() { return context; } + + void setContext(CLContext context) { + this.context = context; + } /** * Returns the name of this device. diff --git a/src/com/mbien/opencl/CLGLContext.java b/src/com/mbien/opencl/CLGLContext.java index a66772e7..a96891c0 100644 --- a/src/com/mbien/opencl/CLGLContext.java +++ b/src/com/mbien/opencl/CLGLContext.java @@ -39,6 +39,10 @@ public final class CLGLContext extends CLContext { return create(glContext, platform, CLDevice.Type.ALL); } + /** + * Creates a shared context on the specified platform and with the specified + * device types. + */ public static CLGLContext create(GLContext glContext, CLDevice.Type... deviceTypes) { return create(glContext, null, deviceTypes); } @@ -55,7 +59,7 @@ public final class CLGLContext extends CLContext { * Creates a shared context on the specified platform and with the specified * device types. */ - private static final CLGLContext create(GLContext glContext, CLPlatform platform, CLDevice.Type... deviceTypes) { + public static final CLGLContext create(GLContext glContext, CLPlatform platform, CLDevice.Type... deviceTypes) { long[] glID = new long[1]; PointerBuffer properties = setupContextProperties(glContext, platform, glID); @@ -69,13 +73,19 @@ public final class CLGLContext extends CLContext { * Creates a shared context on the specified platform and with the specified * devices. */ - private static final CLGLContext create(GLContext glContext, CLPlatform platform, CLDevice... devices) { + public static final CLGLContext create(GLContext glContext, CLPlatform platform, CLDevice... devices) { long[] glID = new long[1]; PointerBuffer properties = setupContextProperties(glContext, platform, glID); long clID = createContext(properties, devices); - return new CLGLContext(clID, glID[0]); + CLGLContext context = new CLGLContext(clID, glID[0]); + if(devices != null) { + for (int i = 0; i < devices.length; i++) { + devices[i].setContext(context); + } + } + return context; } diff --git a/src/com/mbien/opencl/CLKernel.java b/src/com/mbien/opencl/CLKernel.java index 7e2ee54e..eb817f14 100644 --- a/src/com/mbien/opencl/CLKernel.java +++ b/src/com/mbien/opencl/CLKernel.java @@ -19,7 +19,7 @@ import static com.mbien.opencl.CL.*; * CLKernel is not threadsafe. * @author Michael Bien */ -public class CLKernel implements CLResource/*, Cloneable*/ { +public class CLKernel implements CLResource, Cloneable { public final long ID; public final String name; @@ -228,11 +228,11 @@ public class CLKernel implements CLResource/*, Cloneable*/ { } /** - * Returns a new instance of this kernel. + * Returns a new instance of this kernel with uninitialized arguments. */ -// @Override -// public CLKernel clone() { -// return program.createCLKernel(name); -// } + @Override + public CLKernel clone() { + return program.createCLKernel(name).setForce32BitArgs(force32BitArgs); + } } |