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 @   jiangbo4444  阅读(288)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2021-01-31 【Kubernetes】Service 环境变量的问题
2021-01-31 【Kubernetes】访问 Service 环境变量
2021-01-31 【Kubernetes】动态修改数据库连接
2021-01-31 【Kubernetes】Pod 注入环境变量
2021-01-31 【Kubernetes】集群访问本地服务
2021-01-31 【Kubernetes】将本地服务引入集群
2021-01-31 【Kubernetes】访问 Postgresql 数据库
点击右上角即可分享
微信分享提示