0158-使用 QEMU 执行汇编二

环境

  • Time 2022-11-06
  • WSL-Ubuntu 22.04
  • QEMU 6.2.0
  • NASM 2.15.05

前言

说明

参考:《x86汇编语言:从实模式到保护模式》李忠

目标

使用 GDB 调试 QEMU 模拟器执行汇编的过程。

设置断点

从前面知道,BIOS 加载启动文件后,会跳转到 0x7c0:0x0000 处执行。

设置断点命令:break *0x7c00

(gdb) break *0x7c00
Breakpoint 1 at 0x7c00

继续运行

继续命令:continue

(gdb) continue
Continuing.

Breakpoint 1, 0x00007c00 in ?? ()

查看汇编代码

查看命令:layout asm

查看汇编代码

可以看到当前即将运行的就是我们编写的汇编指令,AT&T 风格。

单步调试汇编

命令:ni,查看寄存器 al 的命令:info registers al

单步调试

执行完 ni 命令后,al 寄存器的内容已经被改变。
因为机器码是两个字节,所以地址来到了 0x7c02 处。

总结

使用 QEMU 调试编写的汇编程序,并且单步运行,并且查看了寄存器的结果。

附录

源码

mov al,4
times 508 db 0
db 0x55
db 0xaa
posted @ 2023-01-31 16:40  jiangbo4444  阅读(347)  评论(0)    收藏  举报