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,進入調試;
在<bochs:1>停住,此時仿真屏幕是空的,什么也沒顯示;
? ? 此時應該是硬盤主引導記錄裝入內存,還未開始運行;一句指令也沒執行;? ??主引導記錄會存入內存地址0x7C00;
輸入 vbreak 0x0000:0x7c00,打 c 繼續執行;運行到0000:7c00,這里是一條cli指令;CLI指令,禁止中斷發生;
同時仿真屏幕輸出如下;
打 step 執行下一條指令看一下;這是一條jmp指令,屏幕沒有變化;
再step,下一條指令是 mov ax, 0x07c0;
? ? 0x07c0可能是等于0000:7c00,我還不是很清楚;我覺得應該是;? ?屏幕沒有變化;
再往后單步,屏幕沒有變化;
根據資料;?如下兩句是設置數據段基地址;我還不清楚設置數據段基地址為0x07c0的意義;
? ? mov ax,0x07c0
? ? mov ds,ax
再往后單步,一直到如下圖最后一條指令,屏幕沒有變化;
既然有CLI指令,往后將能找到STI指令; STI,允許中斷發生;到這里還沒看到STI指令;
?
一些資料bochs調試的情況,0000:7c00處是如下的一條mov指令;跟這里前面不一樣;我想可能是早一些的主引導記錄情況,它沒有關中斷,直接mov ax, 0x7c0;前面的是先關了中斷,再?mov ax, 0x7c0
? ? ? ? (0) [0x00007c00] 0000:7c00 (unk. ctxt): mov ax, 0x7c0 ? ? ? ? ? ? ; b8c007
mov ax, 0x7c0 和?mov ax, 0x07c0,應該是一樣的;
?
網上有個資料;主引導記錄反匯編以后的內容如下;
? ? MBR(Main Boot Record)主引導記錄區位于硬盤0磁道0柱面1扇區。
BEGIN:
0000:7C00 FA ? CLI ? ?關中斷
0000:7C01 33C0 ? XOR AX,AX ? 設置堆棧段地址為0000
0000:7C03 8ED0 ? MOV SS,AX
0000:7C05 BC007C MOV SP,7C00 ? 設置堆棧指針為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 ? ?清除方向
..........
也是先關了中斷,這點和前面是一樣的;
總結
以上是生活随笔為你收集整理的Bochs调试Linux内核初级入门2、bochs调试断点和单步指令、0x7c00、关中断和开中断指令的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: G - Eating Plan
- 下一篇: 诗意美句