Merge tag 'trace-printf-v6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/trace...
[drm/drm-misc.git] / tools / perf / Documentation / perf-lock.txt
blob57a940399de05487635a204ff60a25bd4f8967bb
1 perf-lock(1)
2 ============
4 NAME
5 ----
6 perf-lock - Analyze lock events
8 SYNOPSIS
9 --------
10 [verse]
11 'perf lock' {record|report|script|info|contention}
13 DESCRIPTION
14 -----------
15 You can analyze various lock behaviours
16 and statistics with this 'perf lock' command.
18   'perf lock record <command>' records lock events
19   between start and end <command>. And this command
20   produces the file "perf.data" which contains tracing
21   results of lock events.
23   'perf lock report' reports statistical data.
25   'perf lock script' shows raw lock events.
27   'perf lock info' shows metadata like threads or addresses
28   of lock instances.
30   'perf lock contention' shows contention statistics.
32 COMMON OPTIONS
33 --------------
35 -i::
36 --input=<file>::
37         Input file name. (default: perf.data unless stdin is a fifo)
39 --output=<file>::
40         Output file name for perf lock contention and report.
42 -v::
43 --verbose::
44         Be more verbose (show symbol address, etc).
46 -q::
47 --quiet::
48         Do not show any warnings or messages. (Suppress -v)
50 -D::
51 --dump-raw-trace::
52         Dump raw trace in ASCII.
54 -f::
55 --force::
56         Don't complain, do it.
58 --vmlinux=<file>::
59         vmlinux pathname
61 --kallsyms=<file>::
62         kallsyms pathname
65 REPORT OPTIONS
66 --------------
68 -k::
69 --key=<value>::
70         Sorting key. Possible values: acquired (default), contended,
71         avg_wait, wait_total, wait_max, wait_min.
73 -F::
74 --field=<value>::
75         Output fields. By default it shows all the fields but users can
76         customize that using this.  Possible values: acquired, contended,
77         avg_wait, wait_total, wait_max, wait_min.
79 -c::
80 --combine-locks::
81         Merge lock instances in the same class (based on name).
83 -t::
84 --threads::
85     The -t option is to show per-thread lock stat like below:
87       $ perf lock report -t -F acquired,contended,avg_wait
89                     Name   acquired  contended   avg wait (ns)
91                     perf     240569          9            5784
92                  swapper     106610         19             543
93                   :15789      17370          2           14538
94             ContainerMgr       8981          6             874
95                    sleep       5275          1           11281
96          ContainerThread       4416          4             944
97          RootPressureThr       3215          5            1215
98              rcu_preempt       2954          0               0
99             ContainerMgr       2560          0               0
100                  unnamed       1873          0               0
101          EventManager_De       1845          1             636
102          futex-default-S       1609          0               0
104 -E::
105 --entries=<value>::
106         Display this many entries.
109 INFO OPTIONS
110 ------------
112 -t::
113 --threads::
114         dump only the thread list in perf.data
116 -m::
117 --map::
118         dump only the map of lock instances (address:name table)
121 CONTENTION OPTIONS
122 ------------------
124 -k::
125 --key=<value>::
126         Sorting key. Possible values: contended, wait_total (default),
127         wait_max, wait_min, avg_wait.
129 -F::
130 --field=<value>::
131         Output fields. By default it shows all but the wait_min fields
132         and users can customize that using this.  Possible values:
133         contended, wait_total, wait_max, wait_min, avg_wait.
135 -t::
136 --threads::
137         Show per-thread lock contention stat
139 -b::
140 --use-bpf::
141         Use BPF program to collect lock contention stats instead of
142         using the input data.
144 -a::
145 --all-cpus::
146         System-wide collection from all CPUs.
148 -C::
149 --cpu=<value>::
150         Collect samples only on the list of CPUs provided. Multiple CPUs can be
151         provided as a comma-separated list with no space: 0,1. Ranges of CPUs
152         are specified with -: 0-2.  Default is to monitor all CPUs.
154 -p::
155 --pid=<value>::
156         Record events on existing process ID (comma separated list).
158 --tid=<value>::
159         Record events on existing thread ID (comma separated list).
161 -M::
162 --map-nr-entries=<value>::
163         Maximum number of BPF map entries (default: 16384).
164         This will be aligned to a power of 2.
166 --max-stack=<value>::
167         Maximum stack depth when collecting lock contention (default: 8).
169 --stack-skip=<value>::
170         Number of stack depth to skip when finding a lock caller (default: 3).
172 -E::
173 --entries=<value>::
174         Display this many entries.
176 -l::
177 --lock-addr::
178         Show lock contention stat by address
180 -o::
181 --lock-owner::
182         Show lock contention stat by owners.  Implies --threads and
183         requires --use-bpf.
185 -Y::
186 --type-filter=<value>::
187         Show lock contention only for given lock types (comma separated list).
188         Available values are:
189           semaphore, spinlock, rwlock, rwlock:R, rwlock:W, rwsem, rwsem:R, rwsem:W,
190           rtmutex, rwlock-rt, rwlock-rt:R, rwlock-rt:W, pcpu-sem, pcpu-sem:R, pcpu-sem:W,
191           mutex
193         Note that RW-variant of locks have :R and :W suffix.  Names without the
194         suffix are shortcuts for the both variants.  Ex) rwsem = rwsem:R + rwsem:W.
196 -L::
197 --lock-filter=<value>::
198         Show lock contention only for given lock addresses or names (comma separated list).
200 -S::
201 --callstack-filter=<value>::
202         Show lock contention only if the callstack contains the given string.
203         Note that it matches the substring so 'rq' would match both 'raw_spin_rq_lock'
204         and 'irq_enter_rcu'.
206 -x::
207 --field-separator=<SEP>::
208         Show results using a CSV-style output to make it easy to import directly
209         into spreadsheets. Columns are separated by the string specified in SEP.
211 --lock-cgroup::
212         Show lock contention stat by cgroup.  Requires --use-bpf.
214 -G::
215 --cgroup-filter=<value>::
216         Show lock contention only in the given cgroups (comma separated list).
219 SEE ALSO
220 --------
221 linkperf:perf[1]