8086保護(hù)模式之七----------多任務(wù)內(nèi)核實(shí)例
多任務(wù)程序結(jié)構(gòu)和工作原理該模擬內(nèi)核由兩個(gè)程序文件組成,boot.s和 head.s 。 boot.s主要是把head,s中的代碼加載進(jìn)內(nèi)存中。
并在設(shè)置好臨時(shí)GDT表等信息后,把處理器設(shè)置成運(yùn)行在保護(hù)模式下,然后跳轉(zhuǎn)到head代碼處去運(yùn)行內(nèi)核代碼。
實(shí)際上boot.s程序首先會(huì)把這段head代碼移動(dòng)到內(nèi)存0開始處,最后設(shè)置控制寄存器CR0中的開啟保護(hù)運(yùn)行模式標(biāo)志,并
跳轉(zhuǎn)到內(nèi)存0處開始執(zhí)行head代碼。

不能讓boot程序把head代碼從軟盤或者映像文件中,直接把代碼加載到內(nèi)存0處。因?yàn)榧虞d過(guò)程需要使用rom bios提供的中斷過(guò)程,而中斷向量表存儲(chǔ)在
內(nèi)存的0處,并且在內(nèi)存的1 KB處是BIOS程序使用的數(shù)據(jù)區(qū)。
1 head.s 代碼初始化的主要工作:
(1) 重新設(shè)置GDT表
(2) 設(shè)置系統(tǒng)定時(shí)器芯片
(3) 重新設(shè)置IDT表,并且設(shè)置時(shí)鐘和系統(tǒng)調(diào)用中斷門。
(4) 移動(dòng)到任務(wù)A中執(zhí)行。

兩個(gè)任務(wù)在LDT中代碼段和數(shù)據(jù)段描述符的內(nèi)容也都設(shè)置為 : 基地址為0x0000;段限長(zhǎng)值為0x03ff ,實(shí)際長(zhǎng)度為4MB。
使用IRET 來(lái)執(zhí)行相應(yīng)的任務(wù)
由于處于特權(quán)級(jí)0的代碼不能直接把控制權(quán)轉(zhuǎn)移到特權(quán)級(jí)3上的代碼上執(zhí)行,但中斷返回是可以的。,因此當(dāng)初始化GDT IDT 和定時(shí)器芯片之后,我們就需要用利用中斷返回指令I(lǐng)RET來(lái)啟動(dòng)運(yùn)行第一個(gè)任務(wù)。具體實(shí)現(xiàn)方法如下:
在初始堆棧init_stack 中人工設(shè)置一個(gè)返回環(huán)境。即把任務(wù)0的TSS段選擇符加載到任務(wù)寄存器LTR中,LDT段選擇符加載到LDTR中,把任務(wù)0的用戶棧指針和代碼段指針
以及標(biāo)志寄存器壓入棧中,然后執(zhí)行返回指令I(lǐng)RET。 該指令會(huì)彈出堆棧上的堆棧指針作為任務(wù)0用戶棧指針,恢復(fù)假設(shè)的任務(wù)0的標(biāo)志寄存器內(nèi)容,并且彈出棧中代碼指針?lè)湃?CS:EIP 寄存器中,從而開始執(zhí)行任務(wù)0的代碼,實(shí)現(xiàn)了從特權(quán)級(jí)0到特權(quán)級(jí)3的控制轉(zhuǎn)移。
posted on 2010-09-24 19:18 kahn 閱讀(443) 評(píng)論(0) 編輯 收藏 引用