我正在玩glibc的backtrace(),我似乎无法让它在我的Raspberry Pi上正常工作.一切都没有警告编译,但backtrace()返回0作为存储的帧数.完全相同的代码确实在x86_64(Debian stable)上产生了回溯,backtrace()返回6帧:
/*test.c*/
#include dio.h>
#include @H_403_8@
#Makefile
CFLAGS=-Wall -Wextra -g
LDFLAGS=-rdynamic
@H_403_8@
x86_64上的输出(gcc(Debian 4.7.2-5)4.7.2与GNU libc6:amd64 2.13-38 deb7u1):
Hello,Backtrace
Last 6 frames:
./test(foo+0x19)[0x4009a5]
./test(bar+0x9)[0x4009e5]
./test(baz+0x9)[0x4009f0]
./test(main+0x13)[0x400a05]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xfd)[0x7f9286ddbead]
./test[0x4008a9]
@H_403_8@
Raspberry Pi上的输出(gcc(Debian 4.6.3-14 rpi1)4.6.3与GNU libc6:armhf(2.13-38 rpi2 deb7u1)):
Hello,Backtrace
Last 0 frames:
@H_403_8@
我已经验证Raspberry Pi上编译的可执行文件正在将帧指针和链接寄存器存储到堆栈中. objdump -d测试摘录:
0000882c @H_403_8@
我在论坛或Stack Overflow上找不到这样的东西.难道我做错了什么?我没有检查过什么?
最佳答案
必须使用-funwind-tables编译应用程序,以使backtrace()在ARM上运行.