Provided by: uftrace_0.16-1_amd64
NAME
uftrace - Function graph tracer for userspace
SYNOPSIS
uftrace [record|replay|live|report|info|dump|recv|graph|script|tui] [options] COMMAND [command-options]
DESCRIPTION
The uftrace tool is a function tracer that traces the execution of given COMMAND at the function level. COMMAND should be a C or C++ executable built with compiler instrumentation (-pg or -finstrument-functions). COMMAND needs to have an ELF symbol table (i.e. not be strip(1)-ed) in order for the names of traced functions to be available. The uftrace command consists of a number of sub-commands, in the manner of git(1) or perf(1). Below is a short description of each sub-command. For more detailed information, see the respective manual pages. The options in this page can be given to any sub-command also. For convenience, if no sub-command is given, uftrace acts as though the live sub-command was specified, which runs the record and replay sub-commands in turn. See uftrace-live(1) for options belonging to the live sub-command. For more detailed analysis, it is better to use uftrace-record(1) to save trace data, and then analyze it with other uftrace commands like uftrace-replay(1), uftrace-report(1), uftrace-info(1), uftrace-dump(1), uftrace-script(1) or uftrace-tui(1).
SUB-COMMANDS
record Run a given command and save trace data in a data file or directory. replay Print recorded function trace data with time durations. live Do live tracing. Print function trace of the given command. report Print various statistics and summary of the recorded trace data. info Print side-band information like OS version, CPU info, command line and so on. dump Print raw tracing data in the data files. recv Save tracing data sent to network graph Print function call graph script Run a script for recorded function trace tui Show text user interface for graph and report
COMMON OPTIONS
These are the common options supported by all uftrace subcommands: -h, --help Print help message and list of options with description --usage Print usage string -V, --version Print program version -v, --verbose Print verbose messages. This option increases a debug level and can be used at most 3 times. --debug Print debug messages. This option is same as -v/--verbose and is provided only for backward compatibility. --debug-domain=DOMAIN[,DOMAIN, ...] Limit the printing of debug messages to those belonging to one of the DOMAINs specified. Available domains are: uftrace, symbol, demangle, filter, fstack, session, kernel, mcount, dynamic, event, script and dwarf. The domains can have an their own debug level optionally (preceded by a colon). For example, -v --debug- domain=filter:2 will apply debug level of 2 to the “filter” domain and apply debug level of 1 to others. -d DATA, --data=DATA Specify name of trace data (directory). Default is uftrace.data. --logfile=FILE Save warning and debug messages into this file instead of stderr. --color=VAL Enable or disable color on the output. Possible values are “yes”(= “true” | “1” | “on” ), “no”(= “false” | “0” | “off” ) and “auto”. The “auto” value is default and turns on coloring if stdout is a terminal. --no-pager Do not use a pager. --opt-file=FILE Read command-line options from the FILE.
SUBCOMMAND-SPECIFIC OPTIONS
These options are listed here for completeness, but are only effective with specific subcommands. Please see the uftrace-<subcommand> manual pages for more information: The manual for uftrace-live(1) is special: The subcommand live does record and replay internally. Thus, it describes most regular option in detail. --avg-self Show average/min/max of self function time --avg-total Show average/min/max of total function time -a, --auto-args Show arguments and return value of known functions -A, --argument=FUNC@arg[,arg,...] Show function arguments -b, --buffer=SIZE Size of tracing buffer (default: 128K) --chrome Dump recorded data in chrome trace format --clock Set clock source for timestamp (default: mono) --column-offset=DEPTH Offset of each column (default: 8) --column-view Print tasks in separate columns -C, --caller-filter=FUNC Only trace callers of those FUNCs --demangle=TYPE C++ symbol demangling: full, simple, no (default: simple) --diff=DATA Report differences --diff-policy=POLICY Control diff report policy (default: `abs,compact,no-percent') --disable Start with tracing disabled -D, --depth=DEPTH Trace functions within DEPTH -e, --estimate-return Use only entry record type for safety --event-full Show all events outside of function -E, --Event=EVENT Enable EVENT to save more information --flame-graph Dump recorded data in FlameGraph format --flat Use flat output format --force Trace even if executable is not instrumented --format=FORMAT Use FORMAT for output: normal, html (default: normal) -f, --output-fields=FIELD Show FIELDs in the replay or graph output -F, --filter=FUNC Only trace those FUNCs -g, --agent Start an agent in mcount to listen to commands --graphviz Dump recorded data in DOT format -H, --hide=FUNC Hide FUNCs from trace --host=HOST Send trace data to HOST instead of write to file -k, --kernel Trace kernel functions also (if supported) --keep-pid Keep same pid during execution of traced program --kernel-buffer=SIZE Size of kernel tracing buffer (default: 1408K) --kernel-full Show kernel functions outside of user --kernel-only Dump kernel data only --kernel-skip-out Skip kernel functions outside of user (deprecated) -K, --kernel-depth=DEPTH Trace kernel functions within DEPTH --libmcount-single Use single thread version of libmcount --list-event List available events --logfile=FILE Save warning and debug messages into this file instead of stderr. -l, --nest-libcall Show nested library calls --libname Show libname name with symbol name --libmcount-path=PATH Load libmcount libraries from this PATH --match=TYPE Support pattern match: regex, glob (default: regex) --max-stack=DEPTH Set max stack depth to DEPTH (default: 65535) --no-args Do not show arguments and return value --no-comment Don’t show comments of returned functions --no-event Disable (default) events --no-sched Disable schedule events --no-sched-preempt Hide pre-emptive schedule event but show regular(sleeping) schedule event --no-libcall Don’t trace library function calls --no-merge Don’t merge leaf functions --no-pltbind Do not bind dynamic symbols (LD_BIND_NOT) --no-randomize-addr Disable ASLR (Address Space Layout Randomization) --nop No operation (for performance test) --num-thread=NUM Create NUM recorder threads -N, --notrace=FUNC Don’t trace those FUNCs -p, --pid=PID Connect to the PID of an interactive mcount instance --port=PORT Use PORT for network connection (default: 8090) -P, --patch=FUNC Apply dynamic patching for FUNCs --record Record a new trace before running given script --report Show a live report before replay --rt-prio=PRIO Record with real-time (FIFO) priority -r, --time-range=TIME~TIME Show output within the TIME (timestamp or elapsed time) range only --run-cmd=CMDLINE Command line that want to execute after tracing data received -R, --retval=FUNC[@retspec] Show function return values for FUNC, optionally with given uftrace retspec --sample-time=TIME Show flame graph with this sampling time --signal=SIGNAL@act[,act,...] Trigger the given actions when the given SIGNAL is received --sort-column=INDEX Sort diff report on column INDEX (default: 2) --srcline Enable recording source line info --symbols Print symbol table instead of the recorded tracing info -s, --sort=KEY[,KEY,...] Sort reported functions by KEYs (default: 2) -S, --script=SCRIPT Run a given SCRIPT in function entry and exit -t, --time-filter=TIME Hide small functions run less than the TIME --task Print task relationship in a tree form instead of the tracing info. --task-newline Interleave a newline when task is changed --tid=TID[,TID,...] Only replay those tasks --time Print time information -T, --trigger=FUNC@act[,act,...] Trigger action on those FUNCs -U, --unpatch=FUNC Don’t apply dynamic patching for FUNCs --with-syms=DIR Use symbol files in the DIR -W, --watch=POINT Watch and report POINT if it’s changed -Z, --size-filter=SIZE Apply dynamic patching for functions bigger than SIZE For more detail about these command-specific options, please see the more specific manual pages listed below.
SEE ALSO
uftrace-live(1), uftrace-record(1), uftrace-replay(1), uftrace-report(1), uftrace-info(1), uftrace-dump(1), uftrace-recv(1), uftrace-graph(1), uftrace-script(1), uftrace-tui(1)
AUTHORS
Namhyung Kim <namhyung@gmail.com>.