本文将介绍一下哈工大李治军老师《操作系统》课程在完成Lab时所使用到的 Bochs 调试工具的使用方法。这是一款汇编级调试工具,打开调试模式非常简单,只需在终端下输入如下指令:
1、bochs 调试基本指令大全
功能 | 指令 | 举例 |
---|---|---|
在某物理地址设置断点 | b addr | b 0x90000 |
运行到断点位置 | c | c |
单步运行(遇到函数则进入) | s | s |
单步运行(遇到函数则跳过) | n | n |
继续运行上调指令 | 回车 | 回车 |
显示当前所有断点信息 | info break | info break |
显示所有使用的寄存器值 | r | r |
显示段寄存器值 | sreg | sreg |
显示控制寄存器值 | creg | creg |
显示 CPU 状态信息 | info cpu | info cpu |
显示浮点寄存器值 | fp | fp |
退出调试模式 | q | q |
查看堆栈 | print-stack | print-stack |
每执行一条指令就打印CPU信息 | trace-reg | trace-reg on |
查看内存物理地址内容 | xp /nuf addr | xp /40bx 0x9013e |
查看线性地址内容 | x /nuf addr | x /40bx 0x13e |
反汇编一段内存 | u start end | u 0x30400 0x3040D |
反汇编执行的每一条指令 | trace-on | trace-on |
查看 bochs 基本命令 | help | help |
2、 使用方法
(1)进入调试模式
cd oslab // 进入 oslab 文件夹下
./dbg-asm // 启动 bochs 调试模式
出现如下界面,即表示成功进入boch调试模式。
(2)调试方法
在 0x7e00 处打上断点(即setup的启动位置),并运行到断点处,出现如下界面。此时 bootsect.s 已经运行至导入 setup.s 处,但 setup.s 还未运行。
b 0x7e00 // 在 0x7e00 处加载断点
c // 运行到断点为止
需要注意的是:终端上显示的代码是下一行将要执行的,是还未执行的代码。
此外,我们还可以通过单步运行来一行一行运行代码,或者查看寄存器信息。
n // 单步运行
回车 // 继续上次的命令
r // 查看常用寄存器信息
sreg // 查看段寄存器信息
q // 退出 debug
显示段寄存器信息:
至此,关于李治军老师的操作系统课程 bochs 使用方法已介绍完毕,更加具体的使用方法可以参考 Bochs使用手册 Bochs User Manual (sourceforge.io)。