[OS64位][004]源碼調(diào)試:使用工具 nasm 、bochs 驗(yàn)證 org 0x7c00 對(duì)標(biāo)號(hào)StartBootMessage 最終數(shù)值的影響

學(xué)習(xí)筆記

使用教材(配書源碼以及使用方法)
《一個(gè)64位操作系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)》
http://www.ituring.com.cn/book/2450
http://www.itdecent.cn/p/28f9713a9171

使用源碼

[OS64位][002]源碼閱讀:程序3-1 boot.asm 主引導(dǎo)扇區(qū)程序,顯示字符串
http://www.itdecent.cn/p/8bbeb6e8e03f

解決問題

  • 驗(yàn)證 org 0x7c00 對(duì)標(biāo)號(hào)StartBootMessage 最終數(shù)值的影響

調(diào)試記錄 (org 0x7c00)

1、使用nasm生成源碼的.lst文件

[anno@localhost Desktop]$ nasm boot.asm -o boot.bin -l boot.lst

2 、在.lst文件中找到標(biāo)號(hào)StartBootMessage 讀出字節(jié)數(shù)是 0x0043

.lst文件 查看標(biāo)號(hào)的字節(jié)數(shù).png

3、打開bochs

  • [anno@localhost Desktop]$ bochs -f ./bochsrc
  • 輸入 6
  • 按下【回車鍵】
    現(xiàn)在要進(jìn)行調(diào)試,而不是直接查看結(jié)果,我們需要繼續(xù)輸入的不是命令c,而是命令s,表示單步執(zhí)行

4、開始bochs調(diào)試

(1)s 進(jìn)入單步調(diào)試
(2)b 設(shè)置斷點(diǎn)0x7c00
(3)c 直接運(yùn)行到斷點(diǎn)處
(4)sreg 查看全部段寄存器的數(shù)值,發(fā)現(xiàn)全部自動(dòng)清零

查看全部段寄存器的數(shù)值,發(fā)現(xiàn)全部**自動(dòng)清零**

(5)u 反匯編代碼,查看標(biāo)號(hào)最終被解釋成的數(shù)值
讀出 00007c36: ( ): mov bp, 0x7c43 ; bd437c
0x7c43 = 0x7c00+0x0043
正是org 0x7c00標(biāo)號(hào)代表字節(jié)數(shù)共同作用的結(jié)果
反匯編代碼,查看標(biāo)號(hào)最終被解釋成的數(shù)值

bochs 調(diào)試過程(1)~(5)
<bochs:1> s
Next at t=1
(0) [0x0000000fe05b] f000:e05b (unk. ctxt): xor ax, ax                ; 31c0

<bochs:2> b 0x7c00

<bochs:3> c
(0) Breakpoint 1, 0x0000000000007c00 in ?? ()
Next at t=14040250
(0) [0x000000007c00] 0000:7c00 (unk. ctxt): mov ax, cs                ; 8cc8

<bochs:4> sreg
es:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
    Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
cs:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
    Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
ss:0x0000, dh=0x00009300, dl=0x0000ffff, valid=7
    Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
ds:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
    Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
fs:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
    Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
gs:0x0000, dh=0x00009300, dl=0x0000ffff, valid=1
    Data segment, base=0x00000000, limit=0x0000ffff, Read/Write, Accessed
ldtr:0x0000, dh=0x00008200, dl=0x0000ffff, valid=1
tr:0x0000, dh=0x00008b00, dl=0x0000ffff, valid=1
gdtr:base=0x00000000000fa1f7, limit=0x30
idtr:base=0x0000000000000000, limit=0x3ff


<bochs:5> u 0x7c00 0x7c4d
00007c00: (                    ): mov ax, cs                ; 8cc8
. . .
00007c36: (                    ): mov bp, 0x7c43            ; bd437c
. . .

參考資料

  • [OS64位][003] org 0x7c00 有什么用?

http://www.itdecent.cn/p/dbbbc714f942

  • [067][x86匯編語(yǔ)言]Bochs調(diào)試命令整理

http://www.itdecent.cn/p/c98c113772db

  • [OS64位][001]Boot:使用bochs制作虛擬軟盤鏡像boot.img、啟動(dòng)并運(yùn)行boot程序

http://www.itdecent.cn/p/1c0bcee05714

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容