准备调试的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命令来单步执行程序并查看寄存器状态.