Analyzers
Talk to fellow users of Intel Analyzer tools (Intel VTune™ Profiler, Intel Advisor)

Profiling Haswell GPU command queues with VTune

PCox
Beginner
900 Views

We are looking for OpenCL timelines showing Haswell GPU command queues.

In more detail....We are transcoding some Cuda across to OpenCL under Windows, mostly targeting Haswell’s GPU. The Nvidia profilers gave us timelines containing kernels and data transfers, but we’re struggling to find something comparable with Intel tools. Code-Builder (as a VS plugin) has some simple application analysis tools, but nothing like proper timelines. We have tried Amplifier XE (GPU/CPU concurrency), but once again can’t find a way to see the relationship between the various command queues. Do we have to pay extra for the “Platform Analyser” tool before this is possible?

Second (related) question: we originally installed “intel SDK for OCL applications” to get Code Builder under visual studio. If I understand the marketing right, this has now gone away, with Code Builder now bundled inside  “Intel Integrated Native Developer Experience (Intel® INDE)”. The free version of this gets the basic Code Builder, whilst the $800 version also gives me “Platform Analyzer”. True?

0 Kudos
4 Replies
Peter_W_Intel
Employee
900 Views

Answer your first question:

After you installing the VTune(TM) Amplifier XE, open a cmd as administrator then run "amplxe-vars.bat" to set VTune's environment, so you can use VTune's command line.

See my example:

amplxe-cl -collect advanced-hotspots -knob collection-detail=stack-sampling -knob enable-gpu-usage=true -knob enable-gpu-runtimes=true -knob gpu-counters-mode=global-local-accesses -duration 60 -- MonteCarlo.exe

Thus, you can use amplxe-gui to open result to review Hottest GPU coomputing tasks in Summary report & (any time) GPU EU Array usage in timeline report.

GPU hottest.png

GPU timeline.png

0 Kudos
Volker_Bruns
Beginner
900 Views
Hi there, just like the previous authour, I have also ported CUDA code over to OpenCL and want to tune it now for Intel HD graphics cards. 1) Beging used to Nvidia Nsight, is there a way to have source level profiling, e.g. collect statistics for each individual line of code in my kernel? 2) Also, as far as I understand, OpenCL developers targeting Intel GPUs have to decide whether they want/need Platform Analyzer (part of Intel INDE) or VTune Amplifier to profile their code. Ignoring costs, can you confirm that VTune is the safer bet as it provides more detailed profiling information? I appreciate any help. cheers
0 Kudos
David_A_Intel1
Employee
900 Views

Regarding the original question, here is an excellent article written by one of the developers on profiling OpenCL* code on Intel® HD Graphics.

0 Kudos
Robert_I_Intel
Employee
900 Views

Hi Volker,

1. Intel(R) OpenCL(T) Code Builder, part of Intel(R) INDE suite has an entry-level source level profiling (just highlights high-latency operations in your code - meaning read/write lines that take most time). you can download Intel(R) INDE here https://software.intel.com/en-us/intel-inde and then follow this article  https://software.intel.com/en-us/articles/getting-started-with-opencl-development-on-windows-with-intel-inde if you just want the Code Builder portion.

2. Platform Analyzer and VTune Amplifier use the same underlying technology for the GPU analysis, though what is provided in Vtune is more sophisticated. VTune would be a safer bet.

0 Kudos
Reply