Provided by: uftrace_0.8.2-1_amd64 

NAME
uftrace-graph - Show function call graph
SYNOPSIS
uftrace graph [options] [FUNCTION]
DESCRIPTION
This command shows a function call graph for the given function in a uftrace record datafile. If the
function name is omitted, main is used by default. The function call graph contains backtrace and call‐
ing functions. Each function in the output is annotated with a hit count and the total time spent run‐
ning that function.
OPTIONS
-F FUNC, --filter=FUNC
Set filter to trace selected functions only. This option can be used more than once. See uf‐
trace-replay(1) for an explanation of filters.
-N FUNC, --notrace=FUNC
Set filter not to trace selected functions (or the functions called underneath them). This option
can be used more than once. See uftrace-replay(1) for an explanation of filters.
-T TRG, --trigger=TRG
Set trigger on selected functions. This option can be used more than once. See uftrace-replay(1)
for an explanation of triggers.
-t TIME, --time-filter=TIME
Do not show functions which run under the time threshold. If some functions explicitly have the
'trace' trigger applied, those are always traced regardless of execution time.
--tid=TID[,TID,...]
Only print functions called by the given threads. To see the list of threads in the data file,
you can use uftrace report --threads or uftrace info. This option can also be used more than
once.
-D DEPTH, --depth DEPTH
Set trace limit in nesting level.
-r RANGE, --time-range=RANGE
Only show functions executed within the time RANGE. The RANGE can be <start>~<stop> (separated by
"~") and one of <start> and <stop> can be omitted. The <start> and <stop> are timestamp or
elapsed time if they have <time_unit> postfix, for example '100us'. The timestamp or elapsed time
can be shown with -f time or -f elapsed option respectively in uftrace replay(1).
--max-stack=DEPTH
Allocate internal graph structure up to DEPTH.
-k, --kernel
Trace kernel functions as well as user functions. Note that this option is set by default and al‐
ways shows kernel functions if exist.
--kernel-full
Show all kernel functions called outside of user functions. This option is the inverse of --ker‐
nel-skip-out.
--kernel-skip-out
Do not show kernel functions called outside of user functions. This option is deprecated and set
to true by default.
--kernel-only
Show kernel functions only without user functions.
--event-full
Show all (user) events outside of user functions.
--demangle=TYPE
Use demangled C++ symbol names for filters, triggers, arguments and/or return values. Possible
values are "full", "simple" and "no". Default is "simple" which ignores function arguments and
template parameters.
EXAMPLES
This command show data like below:
$ uftrace record loop
$ uftrace replay
# DURATION TID FUNCTION
[24447] | main() {
[24447] | foo() {
8.134 us [24447] | loop();
7.296 us [24447] | loop();
7.234 us [24447] | loop();
24.324 us [24447] | } /* foo */
[24447] | foo() {
7.234 us [24447] | loop();
7.231 us [24447] | loop();
7.231 us [24447] | loop();
22.302 us [24447] | } /* foo */
[24447] | bar() {
10.100 ms [24447] | usleep();
10.138 ms [24447] | } /* bar */
10.293 ms [24447] | } /* main */
Running the graph command on the main function shows called functions like below:
$ uftrace graph main
# Function Call Graph for 'main' (session: 073f1e84aa8b09d3)
=============== BACKTRACE ===============
backtrace #0: hit 1, time 10.293 ms
[0] main (0x4004f0)
========== FUNCTION CALL GRAPH ==========
10.293 ms : (1) main
46.626 us : +-(2) foo
44.360 us : | (6) loop
: |
10.138 ms : +-(1) bar
10.100 ms : (1) usleep
The left side shows total time running the function on the right side. The number in parentheses before
the function name is the invocation count. As you can see, main was called once and ran around 10 msec.
It called foo twice and then foo called loop 6 times in total. The time is the sum of all execution time
of the function.
It can also be seen that main called bar once and that bar then called usleep once. To avoid too deep
nesting level, it shows calls that have only a single call path at the same level. So usleep is not
called from main directly.
Running graph command on a leaf function looks like below.
$ uftrace graph loop
# Function Call Graph for 'loop' (session: 073f1e84aa8b09d3)
=============== BACKTRACE ===============
backtrace #0: hit 6, time 44.360 us
[0] main (0x4004b0)
[1] foo (0x400622)
[2] loop (0x400f5f6)
========== FUNCTION CALL GRAPH ==========
44.360 us : (6) loop
The backtrace shows that loop is called from foo and that foo is called from main. Since loop is a leaf
function, it didn't call any other function. In this case, loop was called only from a single path so
backtrace #0 is hit 6 times.
SEE ALSO
uftrace(1), uftrace-record(1), uftrace-replay(1)
AUTHORS
Namhyung Kim <namhyung@gmail.com>.
Uftrace User Manuals Jun, 2016 UFTRACE-GRAPH(1)