mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/netdev/net.git/
synced 2026-04-18 06:33:43 -04:00
perf test: Test addr2line unwinding works with inline functions
Add a test that seeks to see inline functions correctly displayed in
'perf script' from the inlineloop workload.
Committer testing:
# perf test 'addr2line inline unwinding'
76: test addr2line inline unwinding : Ok
# perf test -vv 'addr2line inline unwinding'
76: test addr2line inline unwinding:
--- start ---
test child forked, pid 1508628
Inline unwinding verification test
[ perf record: Woken up 129 times to write data ]
[ perf record: Captured and wrote 32.282 MB /tmp/perf-test-inline-addr2line.L4Sz8QtADJ/perf.data (4014 samples) ]
Inline unwinding verification test [Success]
---- end(0) ----
76: test addr2line inline unwinding : Ok
#
Reviewed-by: James Clark <james.clark@linaro.org>
Signed-off-by: Ian Rogers <irogers@google.com>
Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Howard Chu <howardchu95@gmail.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephen Brennan <stephen.s.brennan@oracle.com>
Cc: Tony Jones <tonyj@suse.de>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
committed by
Arnaldo Carvalho de Melo
parent
abec464767
commit
54a23bff77
47
tools/perf/tests/shell/addr2line_inlines.sh
Executable file
47
tools/perf/tests/shell/addr2line_inlines.sh
Executable file
@@ -0,0 +1,47 @@
|
||||
#!/bin/bash
|
||||
# test addr2line inline unwinding
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
|
||||
set -e
|
||||
|
||||
err=0
|
||||
test_dir=$(mktemp -d /tmp/perf-test-inline-addr2line.XXXXXXXXXX)
|
||||
perf_data="${test_dir}/perf.data"
|
||||
perf_script_txt="${test_dir}/perf_script.txt"
|
||||
|
||||
cleanup() {
|
||||
rm -rf "${test_dir}"
|
||||
trap - EXIT TERM INT
|
||||
}
|
||||
|
||||
trap_cleanup() {
|
||||
echo "Unexpected signal in ${FUNCNAME[1]}"
|
||||
cleanup
|
||||
exit 1
|
||||
}
|
||||
trap trap_cleanup EXIT TERM INT
|
||||
|
||||
test_inlinedloop() {
|
||||
echo "Inline unwinding verification test"
|
||||
# Record data. Currently only dwarf callchains support inlined functions.
|
||||
perf record --call-graph dwarf -e task-clock:u -o "${perf_data}" -- perf test -w inlineloop 1
|
||||
|
||||
# Check output with inline (default) and srcline
|
||||
perf script -i "${perf_data}" --fields +srcline > "${perf_script_txt}"
|
||||
|
||||
# Expect the leaf and middle functions to occur on lines in the 20s, with
|
||||
# the non-inlined parent function on a line in the 30s.
|
||||
if grep -q "inlineloop.c:2. (inlined)" "${perf_script_txt}" &&
|
||||
grep -q "inlineloop.c:3.$" "${perf_script_txt}"
|
||||
then
|
||||
echo "Inline unwinding verification test [Success]"
|
||||
else
|
||||
echo "Inline unwinding verification test [Failed missing inlined functions]"
|
||||
err=1
|
||||
fi
|
||||
}
|
||||
|
||||
test_inlinedloop
|
||||
|
||||
cleanup
|
||||
exit $err
|
||||
Reference in New Issue
Block a user