GDB调试NASM语法的汇编代码

准备调试的nasm版的汇编代码如下:

section .data
section .text
global main
main:
  ;100001/100
 mov rdx,1
 mov rax,86A1H
 mov rbx,100
 div rbx
 mov rax,60
 syscall

有的程序会用'_start'代替'main',但是我用_start字样去测试时,总会出现:

输入y之后有时程序会直接执行完推出,而我可是想单步执行并且查看寄存器状态的呀,所以直接用'main'字眼了.

接着输入以下命令:    nasm -f elf64 -o div.0 div.asm

                                 ld -o div div.o

它会提示一个警告,这是由于我们没有使用'_start'字眼,直接忽略~~~~~

接着输入gdb div 启动gdb,输入start开始运行该程序

如果以上操作都没有问题的话,那么我们就开始单步调试了.

这里使用的命令为ni来单步调试程序,注意有的博客输入的命令为n或者next,我在我个人机器发现这样输入会把整个程序一次跑完.

然后输入info register命令来检查寄存器的状态.

这里也可以说明,采用'main'字眼,gdb会自动为程序设置一个临时断点.

接下来,我们每输入一次ni,info register命令来单步执行程序并查看寄存器状态.

发布了37 篇原创文章 · 获赞 10 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/OneLinee/article/details/103916620