Irr*_*ewb 9 linux assembly gdb nasm
我正在使用Ubuntu 12.10 64bit.
我正在尝试在GDB中调试一个简单的汇编程序.但是GDB的gui模式(-tui)似乎无法找到我的汇编文件的源代码.我在目前的目录中重建了该项目并搜索谷歌无济于事,请在这里帮助我.
我的命令:
nasm -f elf64 -g -F dwarf hello.asm
gcc -g hello.o -o hello
gdb -tui hello
Run Code Online (Sandbox Code Playgroud)
似乎加载了调试信息,我可以在main()处设置断点,但屏幕的上半部分仍然显示' [No Source Available] '.
如果你有兴趣,这是hello.asm:
; hello.asm a first program for nasm for Linux, Intel, gcc
;
; assemble: nasm -f elf -l hello.lst hello.asm
; link: gcc -o hello hello.o
; run: hello
; output is: Hello World
SECTION .data ; data section
msg: db "Hello World",10 ; the string to print, 10=cr
len: equ $-msg ; "$" means "here"
; len is a value, not an address
SECTION .text ; code section
global main ; make label available to linker
main: ; standard gcc entry point
mov edx,len ; arg3, length of string to print
mov ecx,msg ; arg2, pointer to string
mov ebx,1 ; arg1, where to write, screen
mov eax,4 ; write command to int 80 hex
int 0x80 ; interrupt 80 hex, call kernel
mov ebx,0 ; exit code, 0=normal
mov eax,1 ; exit command to kernel
int 0x80 ; interrupt 80 hex, call kernel
Run Code Online (Sandbox Code Playgroud)
这句话是错误的.
汇编程序确实生成行号信息(注意-g -F矮人)位.
另一方面,他将明显的32位代码组装为64位,这可能有效,也可能无效.
现在,如果NASM的调试输出中存在错误,我们需要知道.
几个快速实验表明,addr2line(但不是gdb!)确实使用stabs正确解码NASM生成的行号信息,但不使用dwarf,因此NASM生成DWARF的方式可能有些不对... GDB.
GNU addr2line版本2.22.52.0.1-10.fc17 20120131,GNU gdb(GDB)Fedora(7.4.50.20120120-52.fc17)).
这种情况下的问题是汇编程序没有为调试器生成行号信息.所以尽管源代码存在(如果你在gdb中执行"list",它会显示源文件的列表 - 至少当我按照你的步骤进行时,它确实如此),但调试器需要从文件中获取行号信息才能知道什么线对应于什么地址.它不能用给出的信息做到这一点.
据我所知,没有办法让NASM发出使用as时使用的.loc指令gcc.但是as无法在不产生大量错误的情况下获取源文件[即使使用-msyntax = intel -mmnemonic = intel - 你会认为应该可以工作].
因此,除非有更聪明的人能想出一种生成.loc条目的方法来提供调试器行号信息,否则我不能完全确定我们如何以您满意的方式回答您的问题.