QEMU调试总结
调试步骤
Qemu monitor
为什么要使用 QEMU monitor命令?
QEMU monitor用于向QEMU模拟器提供复杂的命令。你可以用它来:
- 删除或插入可移动媒体映像(如CD-ROM或软盘)。
- 冻结/解冻虚拟机,并通过磁盘文件保存或恢复虚拟机状态。
- 在没有外部调试器的情况下检查VM状态。如
查看CPU寄存器信息、打印虚拟/物理地址内容
,这个用的最多。
进入退出monitor
C-a c
在console和monitor模式切换。其他命令如下:
console是qemu的软件仿真输出打印模式,monitor是qemu的监控调试模式
C-a h print this help C-a x exit emulator C-a s save disk data back to file (if -snapshot) C-a t toggle console timestamps C-a b send break (magic sysrq) C-a c switch between console and monitor C-a C-a sends C-a
常用命令
进入monitor模式化,可以进行以下操作
- 地址类
i /fmt addr -- I/O port read
o /fmt addr value -- I/O port write
x /fmt addr -- virtual memory dump starting at 'addr'
xp /fmt addr -- physical memory dump starting at 'addr'
print|p /fmt expr -- print expression value (use $reg for CPU register access)
Dump 80 16 bit values at the start of the video memory: (qemu) xp /80hx 0xb8000
- 查询
info [subcommand] -- show various information about the system state
Show the all cpu registers. (qemu) info registers -a
- 控制
system_powerdown -- send system power down event
system_reset -- reset the system
system_wakeup -- wakeup guest from suspend
Ref
更详细信息请查看qemu文档
Qemu + GDB
为什么使用GDB调试
GDB相对于Qemu monitor来说,是外部调试器Debugger,能够使用常见的设置断点、查看堆栈,基于代码的调试。看到的软件调试信息更多。
调试步骤
-
arm不能使用系统自带的gdb,要用gdb-multiarch、或者指定的toolchain下面的gdb
sudo apt install gdb-multiarch
-
确保编译选项加了
-g
kernel要打开选项CONFIG_DEBUG_INFO,CONFIG_GDB_SCRIPTS
-
qemu命令需要添加以下选项
qemu-system-aarch64 -S -s -S:表示qemu虚拟机会冻结CPU,直到远程的gdb输入相应控制命令 -s:表示在1234端口接受gdb的调试连接
- 在另一终端输入命令
gdb-multiarch --tui -q --se=vmlinux -ex 'target remote :1234' (gdb) b start_kernel //在内核start_kernel设置断点 (gdb) c //continue 运行
- 命令解释:
--tui // 使用终端命令行
-q //不打印gdb启动信息
--se=vmlinux //指定符号表和可执行文件
gdb启动命令太长的话,在命令行输入不方便,也可以通过指定命令文件的方式,自动执行多条命令。
- --command=FILE, -x //执行指定文件中的命令
- --init-command=FILE, -ix //与-x类似,启动gdb调试前执行命令
- 或者在工作目录创建初始化文件,每次启动gdb自动执行,
/<path-to-workspace>/.gdbinit
,例如:
file /path/vmlinux target remote :1234
Ref
https://www.kernel.org/doc/Documentation/dev-tools/gdb-kernel-debugging.rst
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构