Bochs调试Linux内核初级入门2、bochs调试断点和单步指令、0x7c00、关中断和开中断指令
前文見此;
https://blog.csdn.net/bcbobo21cn/article/details/105314444
修改run.bat為:"C:\Program Files (x86)\Bochs-2.6.8\bochsdbg" -q -f bochsrc.bxrc;
然后run.bat,進(jìn)入調(diào)試;
在<bochs:1>停住,此時仿真屏幕是空的,什么也沒顯示;
? ? 此時應(yīng)該是硬盤主引導(dǎo)記錄裝入內(nèi)存,還未開始運(yùn)行;一句指令也沒執(zhí)行;? ??主引導(dǎo)記錄會存入內(nèi)存地址0x7C00;
輸入 vbreak 0x0000:0x7c00,打 c 繼續(xù)執(zhí)行;運(yùn)行到0000:7c00,這里是一條cli指令;CLI指令,禁止中斷發(fā)生;
同時仿真屏幕輸出如下;
打 step 執(zhí)行下一條指令看一下;這是一條jmp指令,屏幕沒有變化;
再step,下一條指令是 mov ax, 0x07c0;
? ? 0x07c0可能是等于0000:7c00,我還不是很清楚;我覺得應(yīng)該是;? ?屏幕沒有變化;
再往后單步,屏幕沒有變化;
根據(jù)資料;?如下兩句是設(shè)置數(shù)據(jù)段基地址;我還不清楚設(shè)置數(shù)據(jù)段基地址為0x07c0的意義;
? ? mov ax,0x07c0
? ? mov ds,ax
再往后單步,一直到如下圖最后一條指令,屏幕沒有變化;
既然有CLI指令,往后將能找到STI指令; STI,允許中斷發(fā)生;到這里還沒看到STI指令;
?
一些資料bochs調(diào)試的情況,0000:7c00處是如下的一條mov指令;跟這里前面不一樣;我想可能是早一些的主引導(dǎo)記錄情況,它沒有關(guān)中斷,直接mov ax, 0x7c0;前面的是先關(guān)了中斷,再?mov ax, 0x7c0
? ? ? ? (0) [0x00007c00] 0000:7c00 (unk. ctxt): mov ax, 0x7c0 ? ? ? ? ? ? ; b8c007
mov ax, 0x7c0 和?mov ax, 0x07c0,應(yīng)該是一樣的;
?
網(wǎng)上有個資料;主引導(dǎo)記錄反匯編以后的內(nèi)容如下;
? ? MBR(Main Boot Record)主引導(dǎo)記錄區(qū)位于硬盤0磁道0柱面1扇區(qū)。
BEGIN:
0000:7C00 FA ? CLI ? ?關(guān)中斷
0000:7C01 33C0 ? XOR AX,AX ? 設(shè)置堆棧段地址為0000
0000:7C03 8ED0 ? MOV SS,AX
0000:7C05 BC007C MOV SP,7C00 ? 設(shè)置堆棧指針為7C00
0000:7C08 8BF4 ? MOV SI,SP ? si=7c00
0000:7C0A 50 ? PUSH AX ?
0000:7C0B 07 ? POP ES ? ES=0000
0000:7C0C 50 ? PUSH AX ?
0000:7C0D 1F ? POP DS ? DS=0000
0000:7C0E FB ? STI ? ?開中斷
0000:7C0F FC ? CLD ? ?清除方向
..........
也是先關(guān)了中斷,這點(diǎn)和前面是一樣的;
總結(jié)
以上是生活随笔為你收集整理的Bochs调试Linux内核初级入门2、bochs调试断点和单步指令、0x7c00、关中断和开中断指令的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C语言函数指针的MFC版本Demo
- 下一篇: powershell 查看WMI信息和几