6

我有一个使用as编译的目标文件(来自汇编代码)。

如果我使用ld链接它,当我尝试stepi(或nexti)时,gdb 会抱怨地址 0x0 的内存访问。如果我使用gcc链接它,一切都很好。

我猜这个问题是由ld引起的,与gcc的链接结果相比,它产生的部分更少。

有没有办法将 gdb 配置得更详细,这样我就可以找出可执行文件出了什么问题?

(gdb) b main
Breakpoint 1 at 0x100000f8e
(gdb) r
Breakpoint 1, 0x0000000100000f8e in main ()
(gdb) x/10i $pc
0x100000f8e <main>: fbld   0x6c(%rip)        # 0x100001000 <data1>
0x100000f94 <main+6>: fimul  0x7a(%rip)        # 0x100001014 <data2>
0x100000f9a <main+12>: fbstp  0x60(%rip)        # 0x100001000 <data1>
0x100000fa0 <main+18>: mov0x0    $0x2000001,%rax
0x100000fa7 <main+25>: mov    $,%rdi
0x100000fae <main+32>: syscall 
(gdb) si
Cannot access memory at address 0x0
0x0000000100000f94 in main ()

PS:可执行文件本身在两个版本中都按预期运行。

稍后编辑:我用来编译的命令:

as -arch x86_64 src.s -o src.o
ld -e _main -arch x86_64 src.o -o src
gcc -o src src.o
4

2 回答 2

2

gdb 有一个“show debug”命令,提供各种内部调试设置。例如,“set debug target 1”将开启跟踪 gdb 与目标进程的交互。您可能想尝试他们拥有的每个标志(没有那么多)。

于 2010-12-04T00:13:03.190 回答
1

GCC 实际上并不进行链接,它只是代表您调用 ld 。它提供的选项必须与您使用的选项不同。

根据这个线程:

如何获取 GCC 链接器命令?

您应该能够通过运行 gcc -v 查看 ld 调用的命令行。这应该告诉你如何修改你的 ld 命令行,以便为你工作。

于 2010-12-04T17:59:29.733 回答