使用Bochs调试Linux内核初级入门
之所以能用Bochs調(diào)試Linux內(nèi)核,還是因?yàn)锽ochs做了一些工作;
安裝完成以后如下;如果使用bochs.exe加載操作系統(tǒng)映像,就是在虛擬機(jī)中運(yùn)行操作系統(tǒng);
如果使用bochsdbg.exe加載操作系統(tǒng)映像,就同時(shí)附帶有調(diào)試命令,可進(jìn)行調(diào)試;
如下圖,.bxrc文件,是欲加載的操作系統(tǒng)映像的配置文件;我這個(gè)是Bochs 2.5自帶的;
此目錄下有run.bat;原內(nèi)容如下;
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
然后運(yùn)行run.bat;出現(xiàn)下圖;Display面板為空;命令行顯示 <bochs:1>;到此停住,即可進(jìn)行調(diào)試;
打 help 查看調(diào)試命令;
查看vbreak命令的幫助;此命令在某個(gè)虛擬地址設(shè)置斷點(diǎn);
設(shè)一個(gè)斷點(diǎn)在0x7c00;
?
0x7C00的定義
BIOS就是將MBR讀入0x7C00地址,然后進(jìn)行后續(xù)的引導(dǎo)的。
操作系統(tǒng)或是bootloader開發(fā)者必須假設(shè) 他們的匯編代碼被加載并從0x7C00處開始執(zhí)行。
對于這個(gè)地址,它不屬于Intel x86平臺規(guī)范的,而是屬于BIOS規(guī)范中定義的內(nèi)容。
?
回車再輸入c之后運(yùn)行;
此時(shí)Display面板出現(xiàn)下圖然后停住;
命令行顯示中斷在 0000:7c00;
但是我的輸出和網(wǎng)上資料有所不同;我的輸出顯示在7c00處是一條匯編cli指令;根據(jù)資料到此應(yīng)該顯示類似如下內(nèi)容;
<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 命令;
這個(gè)是查看寄存器;可以查看eflags寄存器;
可以打印當(dāng)前堆棧;
可以打 n 逐條執(zhí)行指令;
看上去可以進(jìn)行調(diào)試了,目前還不了解bxrc文件里面的配置;
總結(jié)
以上是生活随笔為你收集整理的使用Bochs调试Linux内核初级入门的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: VC++简单实现工具软件随鼠标移动画线的
- 下一篇: 使用CUrl断点续传下载Linux内核5