繁体   English   中英

GDB说“没有符号表”,但nm显示文件有调试符号

[英]GDB says “no symbol table,” but nm shows file has debug symbols

我正在尝试使用GDB调试一个简单的C项目,但无论我如何编译它,GDB似乎都找不到该程序的调试符号。

当我将程序加载到GDB时,它声称已成功读取符号,因为它打印

Reading symbols from /home/edward/<executable>...done.

但是,当我运行程序时,打破分段错误,并输入info locals ,它说

No symbol table info available.

另外, bt表明执行在我写的函数(不是系统或库调用)中停止,但是没有行号信息,只有原始内存地址。

为什么GDB不能找到或使用之前成功读取的符号? 我在运行的二进制文件上运行了nmobjdump ,它们都显示了.debug_info.debug_line等部分,因此该文件确实包含调试符号。

我通常用Makefile编译,设置以下标志:

CFLAGS = -mno-red-zone -fno-omit-frame-pointer -ggdb -O0 -I. -Wdeclaration-after-statement -Wall

当我调用gcc时,我可以看到它被使用。 但是,我尝试更改为-g ,并通过在简单的测试文件上调用gcc -g -O0手动编译,结果仍然相同:二进制文件包含调试符号,GDB读取它们,但调用任何GDB命令都会产生一条消息,指出调试信息不​​可用。

更新

我正在运行Ubuntu 12.04,我的GDB版本是7.4,而我的GCC版本是4.8.1。

如果我在GDB中set complaints 10000然后加载文件,它会打印以下投诉:

Reading symbols from /home/edward/<snip>/minithread...
DW_AT_low_pc 0x400690 is not < DW_AT_high_pc 0x33 for DIE at 0x205 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x4006c3 is not < DW_AT_high_pc 0xa9 for DIE at 0x235 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x40076c is not < DW_AT_high_pc 0xad for DIE at 0x287 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400819 is not < DW_AT_high_pc 0xe7 for DIE at 0x2d3 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400900 is not < DW_AT_high_pc 0x4f for DIE at 0x345 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x40094f is not < DW_AT_high_pc 0x55 for DIE at 0x39d [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x4009a4 is not < DW_AT_high_pc 0x38 for DIE at 0x3e7 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x4009dc is not < DW_AT_high_pc 0x43 for DIE at 0x433 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400a20 is not < DW_AT_high_pc 0x2e for DIE at 0x56c [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400a4e is not < DW_AT_high_pc 0x2e for DIE at 0x5aa [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400a7c is not < DW_AT_high_pc 0x29 for DIE at 0x5d4 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400aa5 is not < DW_AT_high_pc 0x49 for DIE at 0x620 [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400aee is not < DW_AT_high_pc 0xca for DIE at 0x66c [in module /home/edward/<snip>/minithread]
...DW_AT_low_pc 0x400bb8 is not < DW_AT_high_pc 0x7bb for DIE at 0x6f0 [in module /home/edward/<snip>/minithread]...done.

这些错误是导致问题的原因吗? 他们是说我的GDB是“错误的”版本吗?

gcc 4.8.1生成dwarf4调试信息,gdb 7.4无法理解。 您需要安装gdb 7.6

除了Chris Dodd的回答之外,您还可以使用gcc -gdwarf-3编译代码,该代码使用dwarf3调试信息进行编译。 哪个与您的GDB版本兼容。

gdb在.symtab .dynsym之前读取.debug_info部分。

nm只读了.symtab .dynsym。

这是因为ELF文件中的.debug_info部分是条带化的。

您可以使用:

readelf -S youelf | grep -i debug

检查是否存在debug_info。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM