我正在尝试使用perf来获取有关系统中堆栈回溯的信息。 我编译了一个应用程序,主要调用f,f调用g1,g1调用g3,g3调用g4,g4调用g2。 我希望我的回溯类似于
但相反,我在perf脚本中裁剪了回溯,比如
a.out 2869 [000] 19414.348571: 225426 cycles:ppp:
7ac f (/opt/usr/home/owner/a.out)
beb3dd2c [unknown] ([unknown])
a.out 2869 [000] 19414.348754: 235721 cycles:ppp:
72c g1 (/opt/usr/home/owner/a.out)
beb3dd24 [unknown] ([unknown])
a.out 2869 [000] 19414.348937: 246486 cycles:ppp:
670 g3 (/opt/usr/home/owner/a.out)
beb3dd14 [unknown] ([unknown])
a.out 2869 [000] 19414.349121: 232929 cycles:ppp:
60c g4 (/opt/usr/home/owner/a.out)
beb3dd04 [unknown] ([unknown])
如何获得有关我的回溯的更多信息?
编译:arm-linux-gnueabi-gcc -O0 -g3 -marm -fno-omit-frame-pointer -funwind-tables main.c
Perf记录:perf记录-g -a
Perf脚本:perf脚本
目标在Linux 3.10.65上运行。
答案 0 :(得分:1)
ARM的perf中的堆栈展开实现存在问题:某些时候没有实现。 尝试最近的内核和/或最新版本的perf(新的perf工具将在旧内核上运行,但回溯读取的一部分在内核中)。
https://wiki.linaro.org/LEG/Engineering/TOOLS/perf-callstack-unwinding(在那里也提到:How does linux's perf utility understand stack traces?)
Linux perf具有特定于体系结构的支持代码。 x86有一些矮小的堆叠框架展开支撑,而arm和arm64没有。它应该在ARM32 / 64上实现。 ARMv7的工作是在LEG-760蓝图下完成的。 ..预期结果是perf输出统计信息中用户和内核调用链的回溯。
支持在2013年9月之后提交:http://www.spinics.net/lists/kernel/msg1608919.html 和3.10 is from june 2013。
从3.11或任何更新版本的内核尝试kernel& perf。