【哈工大_操作系统】Bochs 汇编级调试方法及指令

August 01, 2024

Github代码仓库链接

本文将介绍一下哈工大李治军老师《操作系统》课程在完成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)


Profile picture

Written by JokerDebug who works at Southeast University, Nanjing, China You can follow me on Github