1.最主要的就是那個jmp dword,一切都是為了Jmp做準備
2.int 13h讀取扇區(qū),既可以讀硬盤,又可以讀軟盤,應該是兩個的驅(qū)動器號不同(這個還沒搞清楚,現(xiàn)在只會讀軟盤)。用硬盤映像的時候,總是說找不到引導設(shè)備,不知道是哪兒的參數(shù)錯了。
一些細節(jié):
>cl是讀取的扇區(qū)號,1就是第1個扇區(qū),并不是從0算起。
>kernel.s生成的就只有16B,所以只讀取16字節(jié)。(其他的好像是0,回來試試看)
>讀取成功了,bochs有時候會告訴你成功了,有時候不會。(一次告訴我讀取了16B,一次告訴我讀取了17個扇區(qū))。
3.復制kernel到0:0處
>0:0處在實模式下放了256個中斷向量號,每個向量號4字節(jié)
>movsb會自動把si,di加1,所以千萬不要inc si,inc di,多此一舉(我畫蛇添足時調(diào)試總是感覺怎么不對勁,si一下增加2了,我還以為inc指令有問題)
>復制完了后,有些中斷向量號就被淹沒了,不能用了。
4加載GDT
>注意lgdt時,加載數(shù)據(jù)的格式。數(shù)據(jù)地址越高,就在高位。
>>如 DW 0X0000 DW gdt+0x7c00,0x0000.最后形成的GDTR內(nèi)容就是0x0000,gdt+0x7c00,0x0000
>gdt是便宜地址,所以要加上這個段的起始地址0x7c00
>代碼段描述符的數(shù)據(jù)格式也要注意
>>DW 0XFFFF 0X0000 0X9E00 0X0000,和GDTR表的地址一樣,高地址在高位(話說,bochs不是模擬x86的嗎?x86的小端不是這樣的吧?這個回來也要看看)
>代碼段的描述符構(gòu)造時也要仔細,小心,要不然bochs會出現(xiàn)一些段保護的錯誤。
5.操作cr0
>那個書上用as86匯編寫的,貌似用了一個lmsw的命令,從來沒見過。自己又是用nasm寫的,開始覺得很不順,什么破書,總是跟自己的不一樣。網(wǎng)上又有人用AT&T匯編格式寫了一遍,下載來看,發(fā)現(xiàn)整體的結(jié)構(gòu)又變了。又看的頭暈,一想自己吃飽了撐的,搞三種匯編干蛋阿,任何一種語法都不熟。就老老實實用nasm。后來想起來《自》的源碼是用nasm格式的,于是下載下來找一下lgdt的用法。一下子就解決問題了(開始我是lgdt gdt,正確的是lgdt [gdt]),再后來發(fā)現(xiàn)用nasm的不少,可以google很多boot.s用nasm寫的。不得不說,這個時候英語確實很重要,雖然google有翻譯功能,但是翻譯的不準,不是很爽。還好英語基本功還是有的,hiahia。在這期間,感覺新浪愛問真是一個很好的中文網(wǎng)站,很多資料上面都有,而且不吭爹,如果有網(wǎng)站投票的話,一定投他。www.nasm.us,一開始百度nasm官網(wǎng)都沒百到。我很奇怪,百度上很多軟件的官網(wǎng)排名還不如寫這個軟件使用心得的博客排名靠前,有的甚至百度不到。還是直接在google上直接英文搜索,很方便了。但是GOOGLE有時候又進不去,唉,惱火。(小技巧:用https://www.google.cn可以進,為什么這個協(xié)議就行的通呢?,不懂)。
6.jmp dword
>這一段屬于16位和32位的混合編程,www.nasm.us上有介紹。
>其中在0x0008:0的8上我又折騰了很久,因為一開始以為第一個描述是0,第二個8,第三個16,第四個24。后來才想起來選擇子的格式。(所以說,先把理論上的搞清楚,該背的要背)。DI13位,TI=0表示GDT,RPL
7.跳到kernel后
>本來是準備用int 10來顯示一下字符串的,但是到了保護模式,中斷向量號應該是8個字節(jié)的了,BIOS提供的應該不能用了吧,得自己寫中斷服務(wù)了。
8.一點感觸
>以前看《自己動手寫操作系統(tǒng)》的時候,看很多人說這本書好,作者以幽默的語言怎么怎么樣。現(xiàn)在覺得真實坑爹,如果你調(diào)試半天還是看不出來哪兒錯了,書上寫的又不詳細,百度百到的零零散散,正確性都沒保障的時候,幽默頂個屁用阿。而且那本書的基礎(chǔ)也不止只需要一點c語言和操作系統(tǒng)的知識,所以我很奇怪難道就沒人跟我一樣的感受嗎?今天百度一些問題的時候,看到了有類似感受的,所以我覺得很奇怪為什么對《自》的評價我看到的都是一種聲音:適合初學者。哼,童話里都是騙人的。
>今天google的時候,發(fā)現(xiàn)國外很多寫OS的小組,貌似國內(nèi)高校就沒這么多的小組額。。。
>英語很重要。即使是寫一個kid os,也要耐心和知識的積累。
>找書很麻煩,比如說對8253這些芯片編程以前沒接觸過,雖然學了匯編。但是不知道看什么書,于是百度吧,但是大家的說法又不統(tǒng)一,Intel的又全是英文,圖書館也沒找到,學校外面又買不到,寫信給intel領(lǐng)免費的三本這種事又覺得麻煩。唉,于是只能瞎找書,最后找到32位微型接口技術(shù)及應用這類書上了,勉強能夠滿足需求。