门描述符
注:DPL - 描述符特權(quán)級
P - 門有效標(biāo)志
D - 門規(guī)模(1 = 32位; 0 - 16位)
這里的段選擇子用來查找GDT和IDT,得到一個代碼段描述符,并最終得到代碼段的基地址,再加上圖中的偏移量就能夠得到中斷處理程序的入口了。由于中斷處理程序是在當(dāng)前任務(wù)的上下文中運行的,因此可能會出現(xiàn)中斷處理程序與被中斷程序特權(quán)級不一致的問題,這時就會發(fā)生堆棧切換。對于由軟中斷所產(chǎn)生的中斷和異常CPU要求,CPL必須小于等于門的DPL。
在整個中斷處理程序中,CPU會將TF置成0,以禁止中斷處理程序單步執(zhí)行,并將NT置成0,以在使用IRET指令返回時是回到同一個任務(wù)。對于中斷門和陷阱門,其就在于對EFLAGS寄存器中IF標(biāo)志的處理方法不同,當(dāng)調(diào)用中斷門時,IF被清除。而調(diào)用陷阱門時則不對IF進行處理。
在從中斷處理程序返回的過程中,如果當(dāng)初是通過陷阱門或中斷門進入的,則從堆棧頂彈出EIP和CS,以及EFLAGS。然后根據(jù)CS寄存器選擇子的RPL字段確定返回后的特權(quán)級。值得注意的是,如果RPL為一個內(nèi)層特權(quán)級,則將會產(chǎn)生通用保護故障。對于需要提供出錯誤碼的中斷處理程序,則必須先人為地從堆棧中彈出出錯誤碼,在執(zhí)行IRET指令返回。
進入中斷和異常還可以通過任務(wù)門,即將中斷處理程序作為一個任務(wù)進行處理,使用該方法即將中斷處理程序當(dāng)成一個任務(wù)來看待,對于這種方式的具體操作在以后的文章中會有討論。而對于調(diào)用門由于其只能出現(xiàn)在GDT和LDT中,因此與我們這里討論的中斷和異常無關(guān)。
總結(jié)
- 上一篇: 一致代码段与非一致代码段
- 下一篇: 不同特权级代码段之间的跳转