diff options
| author | Maxime Ripard <maxime@cerno.tech> | 2020-02-17 10:34:34 +0100 | 
|---|---|---|
| committer | Maxime Ripard <maxime@cerno.tech> | 2020-02-17 10:34:34 +0100 | 
| commit | 28f2aff1caa4997f58ca31179cad1b4a84a62827 (patch) | |
| tree | 69fb4b0a752f3660ce022a4313f8c7b276bbcceb /tools/perf/lib/Documentation/tutorial | |
| parent | 3e8a3844fefbaad911c596f02dd48c39188ffa81 (diff) | |
| parent | 11a48a5a18c63fd7621bb050228cebf13566e4d8 (diff) | |
Merge v5.6-rc2 into drm-misc-next
Lyude needs some patches in 5.6-rc2 and we didn't bring drm-misc-next
forward yet, so it looks like a good occasion.
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
Diffstat (limited to 'tools/perf/lib/Documentation/tutorial')
| -rw-r--r-- | tools/perf/lib/Documentation/tutorial/tutorial.rst | 123 | 
1 files changed, 0 insertions, 123 deletions
| diff --git a/tools/perf/lib/Documentation/tutorial/tutorial.rst b/tools/perf/lib/Documentation/tutorial/tutorial.rst deleted file mode 100644 index 7be7bc27b385..000000000000 --- a/tools/perf/lib/Documentation/tutorial/tutorial.rst +++ /dev/null @@ -1,123 +0,0 @@ -.. SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause) - -libperf tutorial -================ - -Compile and install libperf from kernel sources -=============================================== -.. code-block:: bash - -  git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git -  cd linux/tools/perf/lib -  make -  sudo make install prefix=/usr - -Libperf object -============== -The libperf library provides several high level objects: - -struct perf_cpu_map -  Provides a cpu list abstraction. - -struct perf_thread_map -  Provides a thread list abstraction. - -struct perf_evsel -  Provides an abstraction for single a perf event. - -struct perf_evlist -  Gathers several struct perf_evsel object and performs functions on all of them. - -The exported API binds these objects together, -for full reference see the libperf.7 man page. - -Examples -======== -Examples aim to explain libperf functionality on simple use cases. -They are based in on a checked out linux kernel git tree: - -.. code-block:: bash - -  $ cd tools/perf/lib/Documentation/tutorial/ -  $ ls -d  ex-* -  ex-1-compile  ex-2-evsel-stat  ex-3-evlist-stat - -ex-1-compile example -==================== -This example shows the basic usage of *struct perf_cpu_map*, -how to create it and display its cpus: - -.. code-block:: bash - -  $ cd ex-1-compile/ -  $ make -  gcc -o test test.c -lperf -  $ ./test -  0 1 2 3 4 5 6 7 - - -The full code listing is here: - -.. code-block:: c - -   1 #include <perf/cpumap.h> -   2 -   3 int main(int argc, char **Argv) -   4 { -   5         struct perf_cpu_map *cpus; -   6         int cpu, tmp; -   7 -   8         cpus = perf_cpu_map__new(NULL); -   9 -  10         perf_cpu_map__for_each_cpu(cpu, tmp, cpus) -  11                 fprintf(stdout, "%d ", cpu); -  12 -  13         fprintf(stdout, "\n"); -  14 -  15         perf_cpu_map__put(cpus); -  16         return 0; -  17 } - - -First you need to include the proper header to have *struct perf_cpumap* -declaration and functions: - -.. code-block:: c - -   1 #include <perf/cpumap.h> - - -The *struct perf_cpumap* object is created by *perf_cpu_map__new* call. -The *NULL* argument asks it to populate the object with the current online CPUs list: - -.. code-block:: c - -   8         cpus = perf_cpu_map__new(NULL); - -This is paired with a *perf_cpu_map__put*, that drops its reference at the end, possibly deleting it. - -.. code-block:: c - -  15         perf_cpu_map__put(cpus); - -The iteration through the *struct perf_cpumap* CPUs is done using the *perf_cpu_map__for_each_cpu* -macro which requires 3 arguments: - -- cpu  - the cpu numer -- tmp  - iteration helper variable -- cpus - the *struct perf_cpumap* object - -.. code-block:: c - -  10         perf_cpu_map__for_each_cpu(cpu, tmp, cpus) -  11                 fprintf(stdout, "%d ", cpu); - -ex-2-evsel-stat example -======================= - -TBD - -ex-3-evlist-stat example -======================== - -TBD | 
