多任務程序結構和工作原理
該模擬內核由兩個程序文件組成,boot.s和 head.s 。 boot.s主要是把head,s中的代碼加載進內存中。
并在設置好臨時GDT表等信息后,把處理器設置成運行在保護模式下,然后跳轉到head代碼處去運行內核代碼。
實際上boot.s程序首先會把這段head代碼移動到內存0開始處,最后設置控制寄存器CR0中的開啟保護運行模式標志,并
跳轉到內存0處開始執行head代碼。
不能讓boot程序把head代碼從軟盤或者映像文件中,直接把代碼加載到內存0處。因為加載過程需要使用rom bios提供的中斷過程,而中斷向量表存儲在
內存的0處,并且在內存的1 KB處是BIOS程序使用的數據區。
1 head.s 代碼初始化的主要工作:
(1) 重新設置GDT表
(2) 設置系統定時器芯片
(3) 重新設置IDT表,并且設置時鐘和系統調用中斷門。
(4) 移動到任務A中執行。

兩個任務在LDT中代碼段和數據段描述符的內容也都設置為 : 基地址為0x0000;段限長值為0x03ff ,實際長度為4MB。
使用IRET 來執行相應的任務
由于處于特權級0的代碼不能直接把控制權轉移到特權級3上的代碼上執行,但中斷返回是可以的。,因此當初始化GDT IDT 和定時器芯片之后,我們就需要用利用中斷返回指令IRET來啟動運行第一個任務。具體實現方法如下:
在初始堆棧init_stack 中人工設置一個返回環境。即把任務0的TSS段選擇符加載到任務寄存器LTR中,LDT段選擇符加載到LDTR中,把任務0的
用戶棧指針和代碼段指針 以及
標志寄存器壓入棧中,然后執行返回指令IRET。 該指令會彈出堆棧上的堆棧指針作為任務0用戶棧指針,恢復假設的任務0的標志寄存器內容,并且彈出棧中代碼指針放入 CS:EIP 寄存器中,從而開始執行任務0的代碼,實現了從特權級0到特權級3的控制轉移。