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

本文详细介绍了一段nasm汇编代码的调试过程,包括如何使用gdb进行单步调试,以及如何通过ni命令和info register命令查看寄存器状态。文章还解释了为什么使用'main'而非'_start'作为程序入口,并提供了具体的调试步骤。
2450

被折叠的 条评论
为什么被折叠?



