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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源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 数据库