2013-03-07 20:45:20 +08:00
|
|
|
perf-ftrace(1)
|
2018-03-07 18:54:41 +08:00
|
|
|
==============
|
2013-03-07 20:45:20 +08:00
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
|
|
|
perf-ftrace - simple wrapper for kernel's ftrace functionality
|
|
|
|
|
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
|
|
|
[verse]
|
|
|
|
'perf ftrace' <command>
|
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
|
|
|
The 'perf ftrace' command is a simple wrapper of kernel's ftrace
|
|
|
|
functionality. It only supports single thread tracing currently and
|
|
|
|
just reads trace_pipe in text and then write it to stdout.
|
|
|
|
|
|
|
|
The following options apply to perf ftrace.
|
|
|
|
|
|
|
|
OPTIONS
|
|
|
|
-------
|
|
|
|
|
|
|
|
-t::
|
|
|
|
--tracer=::
|
2020-08-08 10:31:24 +08:00
|
|
|
Tracer to use when neither -G nor -F option is not
|
|
|
|
specified: function_graph or function.
|
2013-03-07 20:45:20 +08:00
|
|
|
|
|
|
|
-v::
|
|
|
|
--verbose=::
|
|
|
|
Verbosity level.
|
|
|
|
|
2020-08-08 10:31:25 +08:00
|
|
|
-F::
|
|
|
|
--funcs::
|
|
|
|
List all available functions to trace.
|
|
|
|
|
2017-02-24 09:12:48 +08:00
|
|
|
-p::
|
|
|
|
--pid=::
|
|
|
|
Trace on existing process id (comma separated list).
|
|
|
|
|
2020-08-08 10:31:39 +08:00
|
|
|
--tid=::
|
|
|
|
Trace on existing thread id (comma separated list).
|
|
|
|
|
2020-08-08 10:31:38 +08:00
|
|
|
-D::
|
|
|
|
--delay::
|
|
|
|
Time (ms) to wait before starting tracing after program start.
|
|
|
|
|
2017-02-24 09:12:50 +08:00
|
|
|
-a::
|
|
|
|
--all-cpus::
|
|
|
|
Force system-wide collection. Scripts run without a <command>
|
|
|
|
normally use -a by default, while scripts run with a <command>
|
|
|
|
normally don't - this option allows the latter to be run in
|
|
|
|
system-wide mode.
|
|
|
|
|
|
|
|
-C::
|
|
|
|
--cpu=::
|
|
|
|
Only trace for the list of CPUs provided. Multiple CPUs can
|
|
|
|
be provided as a comma separated list with no space like: 0,1.
|
|
|
|
Ranges of CPUs are specified with -: 0-2.
|
|
|
|
Default is to trace on all online CPUs.
|
|
|
|
|
2020-08-08 10:31:27 +08:00
|
|
|
-m::
|
|
|
|
--buffer-size::
|
|
|
|
Set the size of per-cpu tracing buffer, <size> is expected to
|
|
|
|
be a number with appended unit character - B/K/M/G.
|
|
|
|
|
2020-08-08 10:31:29 +08:00
|
|
|
--inherit::
|
|
|
|
Trace children processes spawned by our target.
|
|
|
|
|
2017-06-18 22:23:01 +08:00
|
|
|
-T::
|
|
|
|
--trace-funcs=::
|
2020-08-08 10:31:24 +08:00
|
|
|
Select function tracer and set function filter on the given
|
|
|
|
function (or a glob pattern). Multiple functions can be given
|
|
|
|
by using this option more than once. The function argument also
|
|
|
|
can be a glob pattern. It will be passed to 'set_ftrace_filter'
|
|
|
|
in tracefs.
|
2017-06-18 22:23:01 +08:00
|
|
|
|
|
|
|
-N::
|
|
|
|
--notrace-funcs=::
|
2020-08-08 10:31:24 +08:00
|
|
|
Select function tracer and do not trace functions given by the
|
|
|
|
argument. Like -T option, this can be used more than once to
|
|
|
|
specify multiple functions (or glob patterns). It will be
|
|
|
|
passed to 'set_ftrace_notrace' in tracefs.
|
2017-06-18 22:23:01 +08:00
|
|
|
|
2020-08-08 10:31:31 +08:00
|
|
|
--func-opts::
|
|
|
|
List of options allowed to set:
|
|
|
|
call-graph - Display kernel stack trace for function tracer.
|
2020-08-08 10:31:34 +08:00
|
|
|
irq-info - Display irq context info for function tracer.
|
2020-08-08 10:31:31 +08:00
|
|
|
|
2017-06-18 22:23:01 +08:00
|
|
|
-G::
|
|
|
|
--graph-funcs=::
|
2020-08-08 10:31:24 +08:00
|
|
|
Select function_graph tracer and set graph filter on the given
|
|
|
|
function (or a glob pattern). This is useful to trace for
|
|
|
|
functions executed from the given function. This can be used more
|
|
|
|
than once to specify multiple functions. It will be passed to
|
|
|
|
'set_graph_function' in tracefs.
|
2017-06-18 22:23:01 +08:00
|
|
|
|
|
|
|
-g::
|
|
|
|
--nograph-funcs=::
|
2020-08-08 10:31:24 +08:00
|
|
|
Select function_graph tracer and set graph notrace filter on the
|
|
|
|
given function (or a glob pattern). Like -G option, this is useful
|
|
|
|
for the function_graph tracer only and disables tracing for function
|
|
|
|
executed from the given function. This can be used more than once to
|
|
|
|
specify multiple functions. It will be passed to 'set_graph_notrace'
|
|
|
|
in tracefs.
|
2017-06-18 22:23:01 +08:00
|
|
|
|
2020-08-08 10:31:32 +08:00
|
|
|
--graph-opts::
|
|
|
|
List of options allowed to set:
|
|
|
|
nosleep-time - Measure on-CPU time only for function_graph tracer.
|
2020-08-08 10:31:33 +08:00
|
|
|
noirqs - Ignore functions that happen inside interrupt.
|
2020-08-08 10:31:35 +08:00
|
|
|
verbose - Show process names, PIDs, timestamps, etc.
|
2020-08-08 10:31:36 +08:00
|
|
|
thresh=<n> - Setup trace duration threshold in microseconds.
|
2020-08-08 10:31:37 +08:00
|
|
|
depth=<n> - Set max depth for function graph tracer to follow.
|
2020-08-08 10:31:32 +08:00
|
|
|
|
2013-03-07 20:45:20 +08:00
|
|
|
SEE ALSO
|
|
|
|
--------
|
|
|
|
linkperf:perf-record[1], linkperf:perf-trace[1]
|