Transferring Data from Host to Device

I am working on a framework which generates OpenCL code automatically from Java Code based on certain input.

So the number of device variables generated are going to be different for each case.
Is there a way to transfer those variables from Host to Device without passing them as arguments to the kernel as otherwise I would have to set the kernel arguments manually for each case.

I have been using ClCreateBuffer, ClEnqueueWriteBuffer and ClSetKernelArg to do it manually.
I wanted to know if there is any way like CUDA where I can create a variable in the host side and just do cudaMemcpytoSymbol to access it in the kernel code.


couldnt get the exact picture of wat ur trying to say…
post a sample code that better depicts…