1 of 1 people found this helpful
CodeXL is supposed to identify the .cl files from the solution, if the source code passed to clCreateProgramWithSource is exactly the same.
However, some situations (passing the string through a utility class that normalizes line endings, concatenating several strings, using sprintf to change the source, etc.) can cause the string passed to clCreateProgramWithSource to vary a little bit.
You were on the right track, but didn't quite get there, here's what you should do:
1. Set a breakpoint on the kernel function name, or set a breakpoint on clEnqueueNDRangeKernel and use F11 to go into kernel debugging.
2. Once the kernel is dispatched, CodeXL will open a Visual Studio source window for the kernel source. It will either be the file from your solution or a temporary file (named <application name>-OpenCLContextX-CLProgramYYY.cl) if the match was not exact.
3a. If the file is the file from your solution, you should be able to just set breakpoints in it and run to them (with F5), and these will persist to the next run of the application.
3b. If the file is a temporary file, you can set a breakpoint in it - but the next time you run the app a new temporary file might be generated, so the breakpoint might no longer work, and you'll have to repeat steps 1-2.
4. Either way, since the for loop is not considered a function (i.e. it does not add a level to the call stack) - pressing F11 will not run to its end, but rather exit the kernel. Set a breakpoint on the first line of executable code after the for loop to reach it.
Hope this helps,
Thanks for your suggestions! Now I am able to also break on the kernel-function, again by adding breakpoints using the breakpoints view. The source file that shows up is the correct .cl file (no temporary). One peculiar thing I noted is that when it breaks, it jumps to the first line in the file, but when pressing F10/F11 it moves to the correct kernel function.
But the problem of not being able to set breakpoints persists. After breaking on the kernel function and setting a breakpoint (as in 1+2+3a above), it does not break.when hitting F5.
I had the problem of VS2012 crashing (so I disabled automatic indentation as suggested in this forum). Can this somehow be related?
The smart tabs issue is unrelated to the breakpoint or kernel debugging in specific and is just a bug with the VS code editor that CodeXL is triggering.
As for the source breakpoints, this is an issue of which we are not currently aware.
If you could supply us with the kernel source (and details on which kernel you are trying to debug as well as on what line are you specifying the source breakpoint), we could try reproducing the issue in our labs.
In the meantime, a few other questions just to try and fathom what's up:
1. If you set a breakpoint on an executable line before the for loop and continue (F5) to it - is the breakpoint hit?
2. Same question, only with the breakpoint inside the for loop.
3. Is there a way for you to shorten the for loop to a lower number of iterations and seeing if you are able to step / hit breakpoints out its other side then?
4. If you try debugging your application in the standalone CodeXL app, are you seeing the same issues? anything behaving differently? (be sure to set the kernel source code folder in the project settings to find the .cl files where they are loaded).
I simplified the file to do almost nothing and have verified that the problem is still there (see code below). In this file, the behavior is independent on where I set the breakpoint. I have now verified that breaking actually works in a few of my other .cl files in the same project, so there seems to be something with this particular file and how it is being built. I think I will continue to dig a bit myself and report back if I discover something.
To take your questions in order:
1+2+3) No, breakpoints set by mouse clicking anywhere in the file, break. Only points set by breakpoints view.
4. I struggle a bit here. I manage to start our application and initialize it, but then it crashes with "Program error. unable to locate binary". No other details in the message. Not sure how to debug. (The application runs fine when starting it directly from windows (no need to start from VS)). Based on the timing of the crash, it might well have something to do with opencl. But I do not know...
Sten Roar Snare
kernel void MyKernel (read_only image2d_t pts, read_only image2d_t input,
write_only image2d_t output)
pos.x = get_global_id(0);
pos.y = get_global_id(1);
int2 pts_dim = get_image_dim( pts );
int2 dim = get_image_dim( input );
// bounds checking
if ( (pos.x >= pts_dim.x) || (pos.y >= pts_dim.y) )
// do something
float2 mDir = (float2) (pos.x, pos.y);
write_imagef(output, (int2)(pos.x, pos.y), (float4)(mDir.x, mDir.y, 0.0f, 0.0f));
Found the problem. We use some -D statements in the build options, in order to let the user change some parameters (such as window sizes) in the program. When the user changes parameters and, in our implementation, during setup, a new build of the opencl code is triggered and causes codexl breakpoints to stop working. I guess we should reconsider our design or work around it for debugging purposes.
Sten Roar Snare
Sorry for the long time in replying.
We have finally managed to reproduce the issue in our labs.
We are currently looking into its cause and seeing if we can fix it or find a workaround.
Thanks for the detailed report!