nasm汇编以及bochs调试
2017-03-15 15:44
330 查看
先说下编译的命令:
编译:
nasm -f elf hello.asm -o hello.o
加权限:
chmod +x hello.o
链接:
ld -m elf_i386 -s -o hello hello.o
直接运行就可以了。
bochs下调试com文件方法:
方法一:在你的程序 LABEL_BEGIN后面紧接着写一个jmp $(让代码死循环在这个位置),然后编译为com文件。写入虚拟软盘。
之后启动调试模式的bochs,先不要设置任何断点,直接执行到dos界面。然后在dos中运行你的程序,出现假死状态(必然的,程序一开始就会死循环)。
然后切换到bochs的命令行窗口,估计需要先按ctrl+c,然后输入r命令,察看当前eip寄存器的值。例如当前值为0x124,那么就输入下面的命令,set \$eip=0x126,就是让EIP增大2即可,JMP \$的机器码要占这么个大小。之后,就可以单步跟踪执行了
方法二:先在bochs的配置文件中加入一句话”magic_break: enabled=1”,这句话的作用就是bochs启动时开启魔术断点调试功能,然后在程序开始处添加一句xchg bx,bx。
将com文件复制到虚拟软盘pm.img中,启动bochs在freedos中运行com文件,当执行到xchg bx,bx指令时就会自动断到Bochsdbg里。
bochs调试参考bochs 调试 com 文件。
编译:
nasm -f elf hello.asm -o hello.o
加权限:
chmod +x hello.o
链接:
ld -m elf_i386 -s -o hello hello.o
直接运行就可以了。
bochs下调试com文件方法:
方法一:在你的程序 LABEL_BEGIN后面紧接着写一个jmp $(让代码死循环在这个位置),然后编译为com文件。写入虚拟软盘。
之后启动调试模式的bochs,先不要设置任何断点,直接执行到dos界面。然后在dos中运行你的程序,出现假死状态(必然的,程序一开始就会死循环)。
然后切换到bochs的命令行窗口,估计需要先按ctrl+c,然后输入r命令,察看当前eip寄存器的值。例如当前值为0x124,那么就输入下面的命令,set \$eip=0x126,就是让EIP增大2即可,JMP \$的机器码要占这么个大小。之后,就可以单步跟踪执行了
方法二:先在bochs的配置文件中加入一句话”magic_break: enabled=1”,这句话的作用就是bochs启动时开启魔术断点调试功能,然后在程序开始处添加一句xchg bx,bx。
将com文件复制到虚拟软盘pm.img中,启动bochs在freedos中运行com文件,当执行到xchg bx,bx指令时就会自动断到Bochsdbg里。
bochs调试参考bochs 调试 com 文件。
相关文章推荐
- C语言中main函数的研究,以及对代码断点调试的研究(王爽老师 汇编语言)
- 用gdb调试nasm汇编程序
- 汇编环境配置以及代码编写调试
- bochs+nasm:调试小技巧
- C语言中main函数的研究,以及对代码断点调试的研究(王爽老师 汇编语言)
- 用gdb调试nasm汇编程序
- 八、汇编源程序的基本构成以及编译、调试
- bochs调试操作系统,以及可引导img的制作
- [Intel汇编-MASM]内存访问方式以及循环程序的调试
- 在linux下用gdb调试gcc编译的代码;以及反汇编的操作
- nasm : 修改bochs配置, 记录调试屏幕的输出.
- gdb调试nasm语法的汇编程序(转载)
- [Intel汇编-MASM]源程序的组成以及编译调试
- [Intel汇编-NASM]软中断以及BIOS中断调用
- [Intel汇编-NASM]任务控制以及特权级保护
- asm基础——使用nasm和bochs学习汇编
- 在ubuntu下用bochs仿真freedos学习8086汇编和debug调试
- [Intel汇编-NASM]任务控制以及特权级保护
- bochs+nasm:调试小技巧