如何在 NASM 中不发出本地符号,以便 GDB disas 不会停留在它们上?



我正试图在linux上使用nasm编写一些汇编程序。一切都很好,但我大量使用本地符号(.roop、.else等),这在调试时很痛苦,因为这些符号被发送到符号表,例如:

[BITS 32]
global main
section .text
main:
    do stuff
.else:
    do other stuff

将生成一个反汇编,看起来像:

<main>:
00000000      do stuff
<main.else>:
00000000      do other stuff

这有点烦人,因为gdb会认为这些都是单独的函数,所以当我"disas"时,它只会在运行到另一个标签并停止之前分解几个指令。

有没有一种方法可以在linux下使用nasm来抑制将这些符号发送到ELF符号表?

我还没有找到直接使用nasm的方法,但是,如果您将对象与ld链接,那么您就可以使用一个非常方便的开关。引用ld的手册页:

-x—全部丢弃删除所有本地符号。

-X—丢弃本地删除所有临时本地符号。(这些符号以系统特定的本地标签前缀,通常为ELF的.L系统或L表示传统a.out系统。)

因此,如果你有,例如,这个:

section .data
    hello:     db 'Hello world!',10
    helen:     equ $-hello           
    hi:        db 'Hi!',10
    hilen:     equ $-hi
section .text
    global _start
_start:
    mov eax,4            
    mov ebx,1            
    mov ecx,hello        
    mov edx,helen                        
    int 80h
.there:
    mov eax,4
    mov ebx,1   
    mov ecx,hi
    mov edx,hilen
    int 80h
.end:
    mov eax,1
    mov ebx,0
    int 80h

然后像这样构建、链接(并运行)它:

$ nasm -g -f elf32 prog.asm && ld -x prog.o -o prog && ./prog
Hello world!
Hi!

然后,当你把它加载到gdb中时,你会得到这个:

$ gdb prog
.....
Reading symbols from prog...done.
(gdb) disas _start
Dump of assembler code for function _start:
   0x08048080 <+0>: mov    $0x4,%eax
   0x08048085 <+5>: mov    $0x1,%ebx
   0x0804808a <+10>:    mov    $0x80490b8,%ecx
   0x0804808f <+15>:    mov    $0xd,%edx
   0x08048094 <+20>:    int    $0x80
   0x08048096 <+22>:    mov    $0x4,%eax
   0x0804809b <+27>:    mov    $0x1,%ebx
   0x080480a0 <+32>:    mov    $0x80490c5,%ecx
   0x080480a5 <+37>:    mov    $0x4,%edx
   0x080480aa <+42>:    int    $0x80
   0x080480ac <+44>:    mov    $0x1,%eax
   0x080480b1 <+49>:    mov    $0x0,%ebx
   0x080480b6 <+54>:    int    $0x80
End of assembler dump.
(gdb)

其中分解不再受到局部符号的阻碍。

最新更新