blob: 34750fc32714caeb18ba0fdcb55cb4f4928c1648 [file] [log] [blame]
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +09001perf-bench(1)
Arnaldo Carvalho de Melo4778e0e2010-05-05 11:23:27 -03002=============
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +09003
4NAME
5----
6perf-bench - General framework for benchmark suites
7
8SYNOPSIS
9--------
10[verse]
11'perf bench' [<common options>] <subsystem> <suite> [<options>]
12
13DESCRIPTION
14-----------
Namhyung Kim08942f62012-06-20 15:08:06 +090015This 'perf bench' command is a general framework for benchmark suites.
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090016
17COMMON OPTIONS
18--------------
Davidlohr Buesob6f06292014-06-16 11:14:19 -070019-r::
20--repeat=::
21Specify amount of times to repeat the run (default 10).
22
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090023-f::
24--format=::
25Specify format style.
Randy Dunlap854c5542010-03-31 11:31:00 -070026Current available format styles are:
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090027
28'default'::
29Default style. This is mainly for human reading.
30---------------------
Randy Dunlap854c5542010-03-31 11:31:00 -070031% perf bench sched pipe # with no style specified
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090032(executing 1000000 pipe operations between two tasks)
33 Total time:5.855 sec
34 5.855061 usecs/op
35 170792 ops/sec
36---------------------
37
38'simple'::
39This simple style is friendly for automated
40processing by scripts.
41---------------------
42% perf bench --format=simple sched pipe # specified simple
435.988
44---------------------
45
46SUBSYSTEM
47---------
48
49'sched'::
50 Scheduler and IPC mechanisms.
51
Namhyung Kim08942f62012-06-20 15:08:06 +090052'mem'::
53 Memory access performance.
54
Ramkumar Ramachandra95a2b3c2014-03-27 19:50:18 -040055'numa'::
56 NUMA scheduling and MM benchmarks.
57
58'futex'::
59 Futex stressing benchmarks.
60
Namhyung Kim08942f62012-06-20 15:08:06 +090061'all'::
62 All benchmark subsystems.
63
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090064SUITES FOR 'sched'
65~~~~~~~~~~~~~~~~~~
66*messaging*::
67Suite for evaluating performance of scheduler and IPC mechanisms.
68Based on hackbench by Rusty Russell.
69
Namhyung Kim08942f62012-06-20 15:08:06 +090070Options of *messaging*
71^^^^^^^^^^^^^^^^^^^^^^
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090072-p::
73--pipe::
74Use pipe() instead of socketpair()
75
76-t::
77--thread::
78Be multi thread instead of multi process
79
80-g::
81--group=::
82Specify number of groups
83
84-l::
Ingo Molnarb0d22e52015-10-19 10:04:28 +020085--nr_loops=::
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090086Specify number of loops
87
88Example of *messaging*
89^^^^^^^^^^^^^^^^^^^^^^
90
91---------------------
92% perf bench sched messaging # run with default
93options (20 sender and receiver processes per group)
94(10 groups == 400 processes run)
95
96 Total time:0.308 sec
97
Randy Dunlap854c5542010-03-31 11:31:00 -070098% perf bench sched messaging -t -g 20 # be multi-thread, with 20 groups
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +090099(20 sender and receiver threads per group)
100(20 groups == 800 threads run)
101
102 Total time:0.582 sec
103---------------------
104
105*pipe*::
106Suite for pipe() system call.
107Based on pipe-test-1m.c by Ingo Molnar.
108
109Options of *pipe*
110^^^^^^^^^^^^^^^^^
111-l::
112--loop=::
113Specify number of loops.
114
115Example of *pipe*
116^^^^^^^^^^^^^^^^^
117
118---------------------
119% perf bench sched pipe
120(executing 1000000 pipe operations between two tasks)
121
122 Total time:8.091 sec
123 8.091833 usecs/op
124 123581 ops/sec
125
126% perf bench sched pipe -l 1000 # loop 1000
127(executing 1000 pipe operations between two tasks)
128
129 Total time:0.016 sec
130 16.948000 usecs/op
131 59004 ops/sec
132---------------------
133
Namhyung Kim08942f62012-06-20 15:08:06 +0900134SUITES FOR 'mem'
135~~~~~~~~~~~~~~~~
136*memcpy*::
137Suite for evaluating performance of simple memory copy in various ways.
138
139Options of *memcpy*
140^^^^^^^^^^^^^^^^^^^
141-l::
Ingo Molnara69b4f72015-10-19 10:04:25 +0200142--size::
143Specify size of memory to copy (default: 1MB).
Namhyung Kim08942f62012-06-20 15:08:06 +0900144Available units are B, KB, MB, GB and TB (case insensitive).
145
Ingo Molnar2f211c82015-10-19 10:04:29 +0200146-f::
147--function::
148Specify function to copy (default: default).
149Available functions are depend on the architecture.
Namhyung Kim08942f62012-06-20 15:08:06 +0900150On x86-64, x86-64-unrolled, x86-64-movsq and x86-64-movsb are supported.
151
Ingo Molnarb0d22e52015-10-19 10:04:28 +0200152-l::
153--nr_loops::
Namhyung Kim08942f62012-06-20 15:08:06 +0900154Repeat memcpy invocation this number of times.
155
156-c::
Ingo Molnarb14f2d32015-10-19 10:04:23 +0200157--cycles::
Namhyung Kim08942f62012-06-20 15:08:06 +0900158Use perf's cpu-cycles event instead of gettimeofday syscall.
159
Namhyung Kim08942f62012-06-20 15:08:06 +0900160*memset*::
161Suite for evaluating performance of simple memory set in various ways.
162
163Options of *memset*
164^^^^^^^^^^^^^^^^^^^
165-l::
Ingo Molnara69b4f72015-10-19 10:04:25 +0200166--size::
167Specify size of memory to set (default: 1MB).
Namhyung Kim08942f62012-06-20 15:08:06 +0900168Available units are B, KB, MB, GB and TB (case insensitive).
169
Ingo Molnar2f211c82015-10-19 10:04:29 +0200170-f::
171--function::
172Specify function to set (default: default).
173Available functions are depend on the architecture.
Namhyung Kim08942f62012-06-20 15:08:06 +0900174On x86-64, x86-64-unrolled, x86-64-stosq and x86-64-stosb are supported.
175
Ingo Molnarb0d22e52015-10-19 10:04:28 +0200176-l::
177--nr_loops::
Namhyung Kim08942f62012-06-20 15:08:06 +0900178Repeat memset invocation this number of times.
179
180-c::
Ingo Molnarb14f2d32015-10-19 10:04:23 +0200181--cycles::
Namhyung Kim08942f62012-06-20 15:08:06 +0900182Use perf's cpu-cycles event instead of gettimeofday syscall.
183
Ramkumar Ramachandra95a2b3c2014-03-27 19:50:18 -0400184SUITES FOR 'numa'
185~~~~~~~~~~~~~~~~~
186*mem*::
187Suite for evaluating NUMA workloads.
188
189SUITES FOR 'futex'
190~~~~~~~~~~~~~~~~~~
191*hash*::
192Suite for evaluating hash tables.
193
194*wake*::
195Suite for evaluating wake calls.
196
Davidlohr Buesod65817b2015-05-08 11:37:59 -0700197*wake-parallel*::
198Suite for evaluating parallel wake calls.
199
Ramkumar Ramachandra95a2b3c2014-03-27 19:50:18 -0400200*requeue*::
201Suite for evaluating requeue calls.
202
Davidlohr Buesod2f3f5d2015-07-07 01:55:53 -0700203*lock-pi*::
204Suite for evaluating futex lock_pi calls.
205
206
Hitoshi Mitake9fbc04f2009-11-10 20:50:54 +0900207SEE ALSO
208--------
209linkperf:perf[1]