中断描述符表IDT以及Linux内核IDT表的初始化的基本情况
IDT,Interrupt Descriptor Table,中斷描述符表是CPU用來處理中斷和程序異常的。
?
一 中斷和IDT表概要
?
? ? 中斷可以由硬件產生(稱為外部中斷),也可以由軟件產生(稱為內部中斷),在程序中寫入int n指令可以產生n號中斷和異常(n從0-ffh)。
? ? 每一種中斷對應一個中斷號。CPU執行中斷指令時,會去IDT表中查找對應的中斷服務程序(interrupt service routine ,ISR)。ISR(為了表述方便用ISR n表示n號中斷的處理程序),x86CPU最大可以支持256種中斷。
? ? 不管運行的是什么操作系統,只要是運行于x86架構,IDT結構必然存在。IDT表中的ISRs應該由操作系統提供。
? ? Intel指定或保留了前32個中斷號的作用,操作系統可以指定其余的中斷號的作用。
? ? 中斷處理過程是由CPU直接調用的,CPU有專門的寄存器IDTR來保存IDT在內存中的位置。程序可以使用LIDT和SIDT指令來讀寫IDTR。
? ? IDT是一個最大為256項的表,每個表項為8字節。也稱為中斷門。
? ? 中斷門和陷阱門描述中斷/異常處理程序的人口點。
?
二 Linux內核IDT表的初始化的基本情況
?
? ? linux內核的中斷描述符表IDT是一個全局的數據,在i386平臺上被定義為:
struct desc_struct idt_table[256] __attribute__((__section__(".data.idt"))) = { {0, 0}, };
摘自arch/kernel/i386/traps.c;
?
? ?其中每一個表項均是一個desc_struct結構,該結構被定以為:
struct desc_struct {
? ? unsigned long a,b;
};
摘自/inlcude/asm-i386/processor.h;
可以看出IDT表共256個表項,每一個表項是8個字節,在idt_table數組被定義時靜態初始化為0。
?
操作系統啟動時,在setup32_up()函數中,會調用setup_idt()函數初始化IDT,該函數使用AT&T匯編寫成,在/arch/i386/kernel/head.S中;
其主要代碼如下:
? ? ......
? ? mov $256,%ecx
? ? rp_sidt:
? ? movl %eax,(%edi)
? ? movl %edx,4(%edi)
? ? addl $8,%edi
? ? dec %ecx
? ? ......
AT&T匯編:
? ? movl:mov long,四個字節;
? ? 引用寄存器要在寄存器號前加百分號%, 如"movl %eax, %ebx";
? ? 使用立即數,要在數前面加符號$, 如"movl $0x04, %ebx";
?
總結
以上是生活随笔為你收集整理的中断描述符表IDT以及Linux内核IDT表的初始化的基本情况的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第一个Node.js实例
- 下一篇: CPU实模式和保护模式、全局描述符表GD