Hi I trying to debug OpenCL kernel code on PS3. Here is the code:
#pragma OPENCL EXTENSION cl_khr_byte_addressable_store : enable
int offset() {
return 'A' - 'a';
}
__kernel void tKernel(__global unsigned char *in, __global unsigned char *out) {
size_t i;
printf(“var”);
for (i = 0; i < 10; i++)
out[i] = in[i] + offset();
}
In IBM OpenCL_guide.pdf in section 4.3.3 on page 18, there are describe debugging kernel with printf method. So I add the printf function to my kernel and trying test it. But OpenCL compile gave me this error:
"IBM_OpenCL_kernel.cl", line 9.15: 1506-766 (S) The universal character name "?" is not in the allowable range for an identifier.
I also have exported LD_LIBRARY_PATH variable. Can anyone have this problem?
It seems that your implementation of OpenCL doesn't support printf, or maybe you are using hardware device instead of emulated one.
In my opinion you shouldn't use printf at all, it is not sharp enough tool to give answers with more complex hardware-dependent problems. Try using additional argument aka '__global float* output'. Fill it inside the kernel with something like
if (something_happened) { output[get_global_id(0)] = the_value_you_need_to_debug; }
this will help you diagnose any possible issue and this approach is platform independent