使用Bochs调试Linux内核初级入门
之所以能用Bochs調試Linux內核,還是因為Bochs做了一些工作;
安裝完成以后如下;如果使用bochs.exe加載操作系統映像,就是在虛擬機中運行操作系統;
如果使用bochsdbg.exe加載操作系統映像,就同時附帶有調試命令,可進行調試;
如下圖,.bxrc文件,是欲加載的操作系統映像的配置文件;我這個是Bochs 2.5自帶的;
此目錄下有run.bat;原內容如下;
cd "C:\Program Files (x86)\Bochs-2.5\dlxlinux"
..\bochs -q -f bochsrc.bxrc
修改為如下;
"C:\Program Files (x86)\Bochs-2.5\bochsdbg" -q -f bochsrc.bxrc
然后運行run.bat;出現下圖;Display面板為空;命令行顯示 <bochs:1>;到此停住,即可進行調試;
打 help 查看調試命令;
查看vbreak命令的幫助;此命令在某個虛擬地址設置斷點;
設一個斷點在0x7c00;
?
0x7C00的定義
BIOS就是將MBR讀入0x7C00地址,然后進行后續的引導的。
操作系統或是bootloader開發者必須假設 他們的匯編代碼被加載并從0x7C00處開始執行。
對于這個地址,它不屬于Intel x86平臺規范的,而是屬于BIOS規范中定義的內容。
?
回車再輸入c之后運行;
此時Display面板出現下圖然后停住;
命令行顯示中斷在 0000:7c00;
但是我的輸出和網上資料有所不同;我的輸出顯示在7c00處是一條匯編cli指令;根據資料到此應該顯示類似如下內容;
<bochs:3> vbreak 0x0000:0x7c00
<bochs:4> c
(0) Breakpoint 1, 0x7c00 (0x0:0x7c00)
Next at t=4409138
(0) [0x00007c00] 0000:7c00 (unk. ctxt): mov ax, 0x7c0 ? ? ? ? ? ? ; b8c007
<bochs:5>
下回再搞;
然后可以打 u /10,反匯編從此地址開始的10條指令;
我的沒有 info r 命令;
這個是查看寄存器;可以查看eflags寄存器;
可以打印當前堆棧;
可以打 n 逐條執行指令;
看上去可以進行調試了,目前還不了解bxrc文件里面的配置;
總結
以上是生活随笔為你收集整理的使用Bochs调试Linux内核初级入门的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: VC++简单实现工具软件随鼠标移动画线的
- 下一篇: 使用CUrl断点续传下载Linux内核5