~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/tools/perf/Documentation/perf-lock.txt

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 perf-lock(1)
  2 ============
  3 
  4 NAME
  5 ----
  6 perf-lock - Analyze lock events
  7 
  8 SYNOPSIS
  9 --------
 10 [verse]
 11 'perf lock' {record|report|script|info|contention}
 12 
 13 DESCRIPTION
 14 -----------
 15 You can analyze various lock behaviours
 16 and statistics with this 'perf lock' command.
 17 
 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.
 22 
 23   'perf lock report' reports statistical data.
 24 
 25   'perf lock script' shows raw lock events.
 26 
 27   'perf lock info' shows metadata like threads or addresses
 28   of lock instances.
 29 
 30   'perf lock contention' shows contention statistics.
 31 
 32 COMMON OPTIONS
 33 --------------
 34 
 35 -i::
 36 --input=<file>::
 37         Input file name. (default: perf.data unless stdin is a fifo)
 38 
 39 --output=<file>::
 40         Output file name for perf lock contention and report.
 41 
 42 -v::
 43 --verbose::
 44         Be more verbose (show symbol address, etc).
 45 
 46 -q::
 47 --quiet::
 48         Do not show any warnings or messages. (Suppress -v)
 49 
 50 -D::
 51 --dump-raw-trace::
 52         Dump raw trace in ASCII.
 53 
 54 -f::
 55 --force::
 56         Don't complain, do it.
 57 
 58 --vmlinux=<file>::
 59         vmlinux pathname
 60 
 61 --kallsyms=<file>::
 62         kallsyms pathname
 63 
 64 
 65 REPORT OPTIONS
 66 --------------
 67 
 68 -k::
 69 --key=<value>::
 70         Sorting key. Possible values: acquired (default), contended,
 71         avg_wait, wait_total, wait_max, wait_min.
 72 
 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.
 78 
 79 -c::
 80 --combine-locks::
 81         Merge lock instances in the same class (based on name).
 82 
 83 -t::
 84 --threads::
 85     The -t option is to show per-thread lock stat like below:
 86 
 87       $ perf lock report -t -F acquired,contended,avg_wait
 88 
 89                     Name   acquired  contended   avg wait (ns)
 90 
 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
103 
104 -E::
105 --entries=<value>::
106         Display this many entries.
107 
108 
109 INFO OPTIONS
110 ------------
111 
112 -t::
113 --threads::
114         dump only the thread list in perf.data
115 
116 -m::
117 --map::
118         dump only the map of lock instances (address:name table)
119 
120 
121 CONTENTION OPTIONS
122 ------------------
123 
124 -k::
125 --key=<value>::
126         Sorting key. Possible values: contended, wait_total (default),
127         wait_max, wait_min, avg_wait.
128 
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.
134 
135 -t::
136 --threads::
137         Show per-thread lock contention stat
138 
139 -b::
140 --use-bpf::
141         Use BPF program to collect lock contention stats instead of
142         using the input data.
143 
144 -a::
145 --all-cpus::
146         System-wide collection from all CPUs.
147 
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.
153 
154 -p::
155 --pid=<value>::
156         Record events on existing process ID (comma separated list).
157 
158 --tid=<value>::
159         Record events on existing thread ID (comma separated list).
160 
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.
165 
166 --max-stack=<value>::
167         Maximum stack depth when collecting lock contention (default: 8).
168 
169 --stack-skip=<value>::
170         Number of stack depth to skip when finding a lock caller (default: 3).
171 
172 -E::
173 --entries=<value>::
174         Display this many entries.
175 
176 -l::
177 --lock-addr::
178         Show lock contention stat by address
179 
180 -o::
181 --lock-owner::
182         Show lock contention stat by owners.  Implies --threads and
183         requires --use-bpf.
184 
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
192 
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.
195 
196 -L::
197 --lock-filter=<value>::
198         Show lock contention only for given lock addresses or names (comma separated list).
199 
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'.
205 
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.
210 
211 --lock-cgroup::
212         Show lock contention stat by cgroup.  Requires --use-bpf.
213 
214 -G::
215 --cgroup-filter=<value>::
216         Show lock contention only in the given cgroups (comma separated list).
217 
218 
219 SEE ALSO
220 --------
221 linkperf:perf[1]

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php