diff --git a/jme3-core/src/main/java/com/jme3/opencl/AbstractOpenCLObject.java b/jme3-core/src/main/java/com/jme3/opencl/AbstractOpenCLObject.java index fce0f481d..2bb80cff7 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/AbstractOpenCLObject.java +++ b/jme3-core/src/main/java/com/jme3/opencl/AbstractOpenCLObject.java @@ -43,8 +43,9 @@ public abstract class AbstractOpenCLObject implements OpenCLObject { this.releaser = releaser; } @Override - public void register() { + public AbstractOpenCLObject register() { OpenCLObjectManager.getInstance().registerObject(this); + return this; } @Override public void release() { diff --git a/jme3-core/src/main/java/com/jme3/opencl/Buffer.java b/jme3-core/src/main/java/com/jme3/opencl/Buffer.java index ebb7d2bb2..ce3ff8fab 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/Buffer.java +++ b/jme3-core/src/main/java/com/jme3/opencl/Buffer.java @@ -52,6 +52,12 @@ public abstract class Buffer extends AbstractOpenCLObject { protected Buffer(ObjectReleaser releaser) { super(releaser); } + + @Override + public Buffer register() { + super.register(); + return this; + } /** * @return the size of the buffer in bytes. @@ -423,5 +429,10 @@ public abstract class Buffer extends AbstractOpenCLObject { //default implementation, overwrite for better performance releaseBufferForSharingAsync(queue).release(); } - + + @Override + public String toString() { + return "Buffer (" + getSize() + "B)"; + } + } diff --git a/jme3-core/src/main/java/com/jme3/opencl/CommandQueue.java b/jme3-core/src/main/java/com/jme3/opencl/CommandQueue.java index 6d54237f9..8b9f77ef2 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/CommandQueue.java +++ b/jme3-core/src/main/java/com/jme3/opencl/CommandQueue.java @@ -43,10 +43,29 @@ package com.jme3.opencl; * @author shaman */ public abstract class CommandQueue extends AbstractOpenCLObject { + + protected Device device; - protected CommandQueue(ObjectReleaser releaser) { + protected CommandQueue(ObjectReleaser releaser, Device device) { super(releaser); + this.device = device; } + + @Override + public CommandQueue register() { + super.register(); + return this; + } + + /** + * Returns the device associated with this command queue. + * It can be used to query properties of the device that is used to execute + * the commands issued to this command queue. + * @return the associated device + */ + public Device getDevice() { + return device; + } /** * Issues all previously queued OpenCL commands in command_queue to the diff --git a/jme3-core/src/main/java/com/jme3/opencl/Context.java b/jme3-core/src/main/java/com/jme3/opencl/Context.java index fed3cd2a3..52d5eba24 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/Context.java +++ b/jme3-core/src/main/java/com/jme3/opencl/Context.java @@ -72,6 +72,12 @@ public abstract class Context extends AbstractOpenCLObject { super(releaser); } + @Override + public Context register() { + super.register(); + return this; + } + /** * Returns all available devices for this context. * These devices all belong to the same {@link Platform}. @@ -436,4 +442,10 @@ public abstract class Context extends AbstractOpenCLObject { * @return the new program */ public abstract Program createProgramFromBinary(ByteBuffer binaries, Device device); + + @Override + public String toString() { + return "Context (" + getDevices() + ')'; + } + } diff --git a/jme3-core/src/main/java/com/jme3/opencl/Event.java b/jme3-core/src/main/java/com/jme3/opencl/Event.java index 44ea3da16..66aa12a5c 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/Event.java +++ b/jme3-core/src/main/java/com/jme3/opencl/Event.java @@ -43,6 +43,12 @@ public abstract class Event extends AbstractOpenCLObject { protected Event(ObjectReleaser releaser) { super(releaser); } + + @Override + public Event register() { + super.register(); + return this; + } /** * Waits until the action has finished (blocking). diff --git a/jme3-core/src/main/java/com/jme3/opencl/Image.java b/jme3-core/src/main/java/com/jme3/opencl/Image.java index f9d9d9f28..7d5d07fb7 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/Image.java +++ b/jme3-core/src/main/java/com/jme3/opencl/Image.java @@ -249,7 +249,13 @@ memory layout in which channels are stored in the image. protected Image(ObjectReleaser releaser) { super(releaser); } - + + @Override + public Image register() { + super.register(); + return this; + } + /** * @return the width of the image */ @@ -532,6 +538,26 @@ memory layout in which channels are stored in the image. //default implementation, overwrite it for performance improvements releaseImageForSharingAsync(queue).release(); } + + @Override + public String toString() { + StringBuilder str = new StringBuilder(); + str.append("Image ("); + ImageType t = getImageType(); + str.append(t); + str.append(", w=").append(getWidth()); + if (t == ImageType.IMAGE_2D || t == ImageType.IMAGE_3D) { + str.append(", h=").append(getHeight()); + } + if (t == ImageType.IMAGE_3D) { + str.append(", d=").append(getDepth()); + } + if (t == ImageType.IMAGE_1D_ARRAY || t == ImageType.IMAGE_2D_ARRAY) { + str.append(", arrays=").append(getArraySize()); + } + str.append(", ").append(getImageFormat()); + str.append(')'); + return str.toString(); + } - //TODO: add variants of the above two methods that don't create the event object, but release the event immediately } diff --git a/jme3-core/src/main/java/com/jme3/opencl/Kernel.java b/jme3-core/src/main/java/com/jme3/opencl/Kernel.java index 09f22a813..1105a2504 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/Kernel.java +++ b/jme3-core/src/main/java/com/jme3/opencl/Kernel.java @@ -97,6 +97,12 @@ public abstract class Kernel extends AbstractOpenCLObject { this.workGroupSize = new WorkSize(0); } + @Override + public Kernel register() { + super.register(); + return this; + } + /** * @return the name of the kernel as defined in the program source code */ @@ -424,7 +430,12 @@ public abstract class Kernel extends AbstractOpenCLObject { setArgs(args); RunNoEvent(queue); } - + + @Override + public String toString() { + return "Kernel (" + getName() + ")"; + } + /** * A placeholder for kernel arguments representing local kernel memory. * This defines the size of available shared memory of a {@code __shared} kernel @@ -468,6 +479,12 @@ public abstract class Kernel extends AbstractOpenCLObject { } return true; } + + @Override + public String toString() { + return "LocalMem (" + size + "B)"; + } + } /** @@ -519,6 +536,12 @@ public abstract class Kernel extends AbstractOpenCLObject { } return true; } + + @Override + public String toString() { + return "LocalMemPerElement (" + size + "B)"; + } + } /** @@ -623,6 +646,21 @@ public abstract class Kernel extends AbstractOpenCLObject { } return true; } + + @Override + public String toString() { + StringBuilder str = new StringBuilder(); + str.append("WorkSize["); + for (int i=0; i0) { + str.append(", "); + } + str.append(sizes[i]); + } + str.append(']'); + return str.toString(); + } + } } diff --git a/jme3-core/src/main/java/com/jme3/opencl/OpenCLObject.java b/jme3-core/src/main/java/com/jme3/opencl/OpenCLObject.java index f9d631346..d2a45077d 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/OpenCLObject.java +++ b/jme3-core/src/main/java/com/jme3/opencl/OpenCLObject.java @@ -61,6 +61,7 @@ public interface OpenCLObject { ObjectReleaser getReleaser(); /** * Releases this native object. + * * Should delegate to {@code getReleaser().release()}. */ void release(); @@ -70,6 +71,10 @@ public interface OpenCLObject { * {@link OpenCLObjectManager}, you have to release it manually * by calling {@link #release() }. * Without registering or releasing, a memory leak might occur. + *
+ * Returns {@code this} to allow calls like + * {@code Buffer buffer = clContext.createBuffer(1024).register();}. + * @return {@code this} */ - void register(); + OpenCLObject register(); } diff --git a/jme3-core/src/main/java/com/jme3/opencl/Program.java b/jme3-core/src/main/java/com/jme3/opencl/Program.java index a98cf2c02..c55f320d5 100644 --- a/jme3-core/src/main/java/com/jme3/opencl/Program.java +++ b/jme3-core/src/main/java/com/jme3/opencl/Program.java @@ -49,6 +49,12 @@ public abstract class Program extends AbstractOpenCLObject { protected Program(ObjectReleaser releaser) { super(releaser); } + + @Override + public Program register() { + super.register(); + return this; + } /** * Builds this program with the specified argument string on the specified diff --git a/jme3-examples/src/main/java/jme3test/opencl/TestContextSwitching.java b/jme3-examples/src/main/java/jme3test/opencl/TestContextSwitching.java index 80be89cd7..a1d87899d 100644 --- a/jme3-examples/src/main/java/jme3test/opencl/TestContextSwitching.java +++ b/jme3-examples/src/main/java/jme3test/opencl/TestContextSwitching.java @@ -131,8 +131,7 @@ public class TestContextSwitching extends SimpleApplication implements ScreenCon if (testBuffer == null && clContext != null && !bufferCreated) { try { - testBuffer = clContext.createBuffer(1024); - testBuffer.register(); + testBuffer = clContext.createBuffer(1024).register(); LOG.info("Test buffer created"); } catch (OpenCLException ex) { LOG.log(Level.SEVERE, "Unable to create buffer", ex); diff --git a/jme3-examples/src/main/java/jme3test/opencl/TestVertexBufferSharing.java b/jme3-examples/src/main/java/jme3test/opencl/TestVertexBufferSharing.java index 514a41d63..0e4314fbc 100644 --- a/jme3-examples/src/main/java/jme3test/opencl/TestVertexBufferSharing.java +++ b/jme3-examples/src/main/java/jme3test/opencl/TestVertexBufferSharing.java @@ -115,8 +115,7 @@ public class TestVertexBufferSharing extends SimpleApplication { private void initOpenCL1() { clContext = context.getOpenCLContext(); Device device = clContext.getDevices().get(0); - clQueue = clContext.createQueue(device); - clQueue.register(); + clQueue = clContext.createQueue(device).register(); //create kernel Program program = null; File tmpFolder = JmeSystem.getStorageFolder(); @@ -156,15 +155,13 @@ public class TestVertexBufferSharing extends SimpleApplication { } LOG.info("create new program from sources"); } - program.register(); - kernel = program.createKernel("ScaleKernel"); - kernel.register(); + program.register(); + kernel = program.createKernel("ScaleKernel").register(); } private void initOpenCL2() { //bind vertex buffer to OpenCL VertexBuffer vb = geom.getMesh().getBuffer(VertexBuffer.Type.Position); - buffer = clContext.bindVertexBuffer(vb, MemoryAccess.READ_WRITE); - buffer.register(); + buffer = clContext.bindVertexBuffer(vb, MemoryAccess.READ_WRITE).register(); ws = new com.jme3.opencl.Kernel.WorkSize(geom.getMesh().getVertexCount()); } private void updateOpenCL(float tpf) { diff --git a/jme3-examples/src/main/java/jme3test/opencl/TestWriteToTexture.java b/jme3-examples/src/main/java/jme3test/opencl/TestWriteToTexture.java index bb407893c..6feeab4b9 100644 --- a/jme3-examples/src/main/java/jme3test/opencl/TestWriteToTexture.java +++ b/jme3-examples/src/main/java/jme3test/opencl/TestWriteToTexture.java @@ -122,8 +122,7 @@ public class TestWriteToTexture extends SimpleApplication implements AnalogListe private void initOpenCL1() { clContext = context.getOpenCLContext(); - clQueue = clContext.createQueue(); - clQueue.register(); + clQueue = clContext.createQueue().register(); programCache = new ProgramCache(clContext); //create kernel String cacheID = getClass().getName()+".Julia"; @@ -135,14 +134,12 @@ public class TestWriteToTexture extends SimpleApplication implements AnalogListe programCache.saveToCache(cacheID, program); } program.register(); - kernel = program.createKernel("JuliaSet"); - kernel.register(); + kernel = program.createKernel("JuliaSet").register(); C = new Vector2f(0.12f, -0.2f); } private void initOpenCL2() { //bind image to OpenCL - texCL = clContext.bindImage(tex, MemoryAccess.WRITE_ONLY); - texCL.register(); + texCL = clContext.bindImage(tex, MemoryAccess.WRITE_ONLY).register(); } private void updateOpenCL(float tpf) { //aquire resource diff --git a/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclCommandQueue.java b/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclCommandQueue.java index e7b8a3743..702300ddf 100644 --- a/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclCommandQueue.java +++ b/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclCommandQueue.java @@ -32,11 +32,9 @@ package com.jme3.opencl.jocl; import com.jme3.opencl.CommandQueue; -import com.jme3.opencl.OpenCLObjectManager; -import com.jogamp.opencl.CLCommandQueue; +import com.jme3.opencl.Device; import com.jogamp.opencl.CLPlatform; import com.jogamp.opencl.llb.CL; -import com.jogamp.opencl.llb.CLCommandQueueBinding; /** * @@ -47,8 +45,8 @@ public class JoclCommandQueue extends CommandQueue { final CL cl; final long id; - public JoclCommandQueue(long id) { - super(new ReleaserImpl(id)); + public JoclCommandQueue(long id, Device device) { + super(new ReleaserImpl(id), device); this.id = id; this.cl = CLPlatform.getLowLevelCLInterface(); } diff --git a/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclContext.java b/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclContext.java index d372587f1..8e06cb3e2 100644 --- a/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclContext.java +++ b/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclContext.java @@ -88,7 +88,7 @@ public class JoclContext extends Context { long properties = 0; long q = cl.clCreateCommandQueue(id, d, properties, Utils.errorBuffer); Utils.checkError(Utils.errorBuffer, "clCreateCommandQueue"); - return new JoclCommandQueue(q); + return new JoclCommandQueue(q, device); } @Override diff --git a/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclPlatform.java b/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclPlatform.java index 56d551180..a481e8818 100644 --- a/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclPlatform.java +++ b/jme3-jogl/src/main/java/com/jme3/opencl/jocl/JoclPlatform.java @@ -124,4 +124,9 @@ public final class JoclPlatform implements Platform { return platform.getExtensions(); } + @Override + public String toString() { + return getName(); + } + } diff --git a/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java b/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java index c413d6a8e..28c867620 100644 --- a/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java +++ b/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java @@ -32,6 +32,7 @@ package com.jme3.opencl.lwjgl; import com.jme3.opencl.CommandQueue; +import com.jme3.opencl.Device; import com.jme3.opencl.OpenCLObjectManager; import org.lwjgl.opencl.CL10; import org.lwjgl.opencl.CLCommandQueue; @@ -44,8 +45,8 @@ public class LwjglCommandQueue extends CommandQueue { private final CLCommandQueue queue; - public LwjglCommandQueue(CLCommandQueue queue) { - super(new ReleaserImpl(queue)); + public LwjglCommandQueue(CLCommandQueue queue, Device device) { + super(new ReleaserImpl(queue), device); this.queue = queue; } diff --git a/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java b/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java index c0b05c673..96b34eb10 100644 --- a/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java +++ b/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java @@ -79,7 +79,7 @@ public class LwjglContext extends Context { long properties = 0; CLCommandQueue q = CL10.clCreateCommandQueue(context, d, properties, Utils.errorBuffer); Utils.checkError(Utils.errorBuffer, "clCreateCommandQueue"); - return new LwjglCommandQueue(q); + return new LwjglCommandQueue(q, device); } @Override diff --git a/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java b/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java index 7d22d0aca..610b07e47 100644 --- a/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java +++ b/jme3-lwjgl/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java @@ -124,4 +124,9 @@ public final class LwjglPlatform implements Platform { return Arrays.asList(platform.getInfoString(CL10.CL_PLATFORM_EXTENSIONS).split(" ")); } + @Override + public String toString() { + return getName(); + } + } diff --git a/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java b/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java index 5be22813a..88a34ac31 100644 --- a/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java +++ b/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglCommandQueue.java @@ -32,6 +32,7 @@ package com.jme3.opencl.lwjgl; import com.jme3.opencl.CommandQueue; +import com.jme3.opencl.Device; import org.lwjgl.opencl.CL10; /** @@ -42,8 +43,8 @@ public class LwjglCommandQueue extends CommandQueue { private final long queue; - public LwjglCommandQueue(long queue) { - super(new ReleaserImpl(queue)); + public LwjglCommandQueue(long queue, Device device) { + super(new ReleaserImpl(queue), device); this.queue = queue; } diff --git a/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java b/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java index 83d43ca77..53267f4cc 100644 --- a/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java +++ b/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglContext.java @@ -79,7 +79,7 @@ public class LwjglContext extends Context { long properties = 0; long q = CL10.clCreateCommandQueue(context, d, properties, Utils.errorBuffer); Utils.checkError(Utils.errorBuffer, "clCreateCommandQueue"); - return new LwjglCommandQueue(q); + return new LwjglCommandQueue(q, device); } @Override diff --git a/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java b/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java index 74fc685c1..24b95f6c3 100644 --- a/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java +++ b/jme3-lwjgl3/src/main/java/com/jme3/opencl/lwjgl/LwjglPlatform.java @@ -125,4 +125,9 @@ public final class LwjglPlatform implements Platform { return Arrays.asList(Info.clGetPlatformInfoStringASCII(platform.address(), CL10.CL_PLATFORM_EXTENSIONS).split(" ")); } + @Override + public String toString() { + return getName(); + } + }