aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/trace_profile/vtune.md
diff options
context:
space:
mode:
authorJohannes Stoelp <johannes.stoelp@gmail.com>2025-02-21 22:14:05 +0100
committerJohannes Stoelp <johannes.stoelp@gmail.com>2025-02-21 22:35:26 +0100
commit4b026881591e99425c9e8a74162a15952ff92354 (patch)
tree5ee5f32ff71e9726cb05e129d52712267701821c /src/trace_profile/vtune.md
parentc9bfd7ea16ec63ca689734ad9dd279a8f76d88be (diff)
downloadnotes-4b026881591e99425c9e8a74162a15952ff92354.tar.gz
notes-4b026881591e99425c9e8a74162a15952ff92354.zip
vtune: initial notes
Diffstat (limited to 'src/trace_profile/vtune.md')
-rw-r--r--src/trace_profile/vtune.md45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/trace_profile/vtune.md b/src/trace_profile/vtune.md
new file mode 100644
index 0000000..022a652
--- /dev/null
+++ b/src/trace_profile/vtune.md
@@ -0,0 +1,45 @@
+# [vtune(1)][vtune]
+
+Vtune offers different analysis. Run `vtune -collect help` to list the
+availale analysis.
+
+## Profiling
+
+The following shows some common flows with the `hotspot` analsysis
+as an example.
+```
+# Launch and profile process.
+vtune -collect hotspots [opts] -- target [args]
+
+# Attach and profile running process.
+vtune -collect hotspots [opts] -target-pid <pid>
+```
+Some common options are the following.
+```
+-r <dir> output directory for the profile
+-no-follow-child dont attach to to child processes (default is to follow)
+-start-paused start with paused profiling
+```
+
+## Analyze
+```
+vtune-gui <dir>
+```
+
+## Programmatically control sampling
+Vtune offers an API to *resume* and *pause* the profile collection from within
+the profilee itself. This can be helpful if either only a certain phase should
+be profiled or some phase should be skipped.
+
+The following gives an example where only one phase in the program is profiled.
+The program makes calls to the vtune API to resume and pause the collection,
+while vtune is invoked with `-start-paused` to pause profiling initially.
+```c
+{{#include vtune/main.c::16}}
+```
+The makefile gives an example how to build and profile the application.
+```makefile
+{{#include vtune/Makefile::7}}
+```
+
+[vtune]: https://www.intel.com/content/www/us/en/docs/vtune-profiler/user-guide