This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Performance and SGEMM example

Hi,

I've gotten most of my code working with the Chromebook development platform.  Simple kernels run fine and show a nice performance speedup.  However more complex kernels perform poorly.

As per the suggestions of some members of this forum, I've reorganized one of my OpenCL kernels to avoid using local memory and to use the float4 vectors.  The routine I was optimizing was a simple covariance calculation for large data sets.  Since this is essentially a modified matrix multiply, I used the provided sgemm.cl as an example.  This resulted in a pretty substantial speed up in my code (about a factor of 2-3).

Since I can't guarantee that a client's system has a function OpenCL system,  I have a standard CPU version of the same function.  Running both of these on the chromebook I get the following performance figures for a data set:

Using local memory (i.e. optimized for nVidia):   24.5 seconds

Using vectors and no local memory (i.e. optimized for Mali):  9.26 seconds

Using CPUs with calls to BLAS (no OpenCL): 6.99 seconds

So here despite optimization effort, it is still quicker to use the CPU to do the processing.

Just checking to see if I did anything wrong, I checked the provided sgemm.cpp file.  As a comparison, I ran the BLAS CPU version of sgemm (installed using apt-get) against the provided OpenCL example.  For the default matrix size of (2048x2048),  I get the following run times:

OpenCL sgemm: 84 seconds

CPU BLAS sgemm: 3 seconds

So the single core CPU version is abut 30 times faster than the OpenCL version!

I've checked an the output is the same for both cases. 

I suspect that performance is being choked in the OpenCL code by the sheer number of loads from global memory.  On the systems with Local memory, this can be cached so performance doesn't choke.  I assume the CPU is caching data fairly well and speeding this up.

If this is indeed the case, performance will be bad on anything other than extremely simple kernels.

Am I making some sort of mistake here? Is there anything I can do to mitigate this?  Essentially 90% of the processing time in most of my stuff is a matrix multiply.

Thanks for all of your help.

--Mike

Parents
  • > It didn't seem to have any effect on my code run times, however.  I still get the same 9.25 seconds for the Mali optimized covariance.


    I suspect you are running into one of the quirks of the DVFS implementation in our BSP. Most mobile DVFS policies are geared towards sustained workloads - so frequency choices are based on average utilization of the hardware over a time window. For pipelined workloads which keep both the CPU and GPU running at the same time and the dominant processor fully loaded this approach works well. For a graphics heavy game for example, the GPU will be fully loaded and drift towards a high frequency, the CPU will start of perhaps 50% loaded, and drift towards a lower frequency. As graphics is pipelined there is a constant queue of work available for the GPU, it never goes idle, so utilization stays high.


    Many off-the-shelf OpenCL kernels do not always fit this model - some push buffers to the CPU do some work, then switch to the GPU and do some work, and then flip back to the CPU again. Even though all cores are as busy as the design lets them be, their utilization is not 100%, so the DFVS governor will generally try to drop the frequency. Because the idle time is algorithmic in nature, rather than performance related, it doesn't go away even with a lower frequency, so the frequency drops some more, and soon you are running at the lowest operating point ...


    Our general advice is, where possible, pipeline your workloads so the CPU is preparing the next task, while the GPU is processing the last one, and keep the most heavily loaded part of the system fully utilized. That plays nicely with the default DVFS you will see today in most devices, but that said ... OpenCL is still a maturing technology so we are very interested in getting more developer input about what their use cases look like - we can undoubtedly do more with our partners to refine power policies here.


    > Is there any hope of future chips having dedicated fast local memory?


    The scale of a mobile GPU and a desktop GPU are very different, so our global memory access is already relatively fast in comparison. We've not yet seen much evidence that we need a faster local memory - GPUs are already much more latency tolerant than a CPU, and you can already share memory in the GPU caches if it is "hot" so that provides most of the locality benefits. If you have a particular use case we'd love to hear it.


    Kind regards,

    Pete

Reply
  • > It didn't seem to have any effect on my code run times, however.  I still get the same 9.25 seconds for the Mali optimized covariance.


    I suspect you are running into one of the quirks of the DVFS implementation in our BSP. Most mobile DVFS policies are geared towards sustained workloads - so frequency choices are based on average utilization of the hardware over a time window. For pipelined workloads which keep both the CPU and GPU running at the same time and the dominant processor fully loaded this approach works well. For a graphics heavy game for example, the GPU will be fully loaded and drift towards a high frequency, the CPU will start of perhaps 50% loaded, and drift towards a lower frequency. As graphics is pipelined there is a constant queue of work available for the GPU, it never goes idle, so utilization stays high.


    Many off-the-shelf OpenCL kernels do not always fit this model - some push buffers to the CPU do some work, then switch to the GPU and do some work, and then flip back to the CPU again. Even though all cores are as busy as the design lets them be, their utilization is not 100%, so the DFVS governor will generally try to drop the frequency. Because the idle time is algorithmic in nature, rather than performance related, it doesn't go away even with a lower frequency, so the frequency drops some more, and soon you are running at the lowest operating point ...


    Our general advice is, where possible, pipeline your workloads so the CPU is preparing the next task, while the GPU is processing the last one, and keep the most heavily loaded part of the system fully utilized. That plays nicely with the default DVFS you will see today in most devices, but that said ... OpenCL is still a maturing technology so we are very interested in getting more developer input about what their use cases look like - we can undoubtedly do more with our partners to refine power policies here.


    > Is there any hope of future chips having dedicated fast local memory?


    The scale of a mobile GPU and a desktop GPU are very different, so our global memory access is already relatively fast in comparison. We've not yet seen much evidence that we need a faster local memory - GPUs are already much more latency tolerant than a CPU, and you can already share memory in the GPU caches if it is "hot" so that provides most of the locality benefits. If you have a particular use case we'd love to hear it.


    Kind regards,

    Pete

Children
No data