我正试图在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)
其中分解不再受到局部符号的阻碍。