http://blog.csdn.net/yxc135/article/details/8734452
点击打开链接
该篇文章主要介绍中断向量表和中断描述符表的区别和形成,摘录了几句(这几句可是解决了我好长时间的困惑),如下:
(一)、当80x86微机启动时,ROM BIOS中的程序会在物理内存开始地址0x0000:0x0000处初始化并设置中断向量表,而各中断的默认中断服务程序则在BIOS中给出。
(二)、对于Linux系统,除了在刚开始加载内核时需要用到BIOS提供的显示和磁盘读操作中断功能(在阅读Linux内核源码时,发现(bootsect.s,setup.s,head.s)这三个汇编程序最终会将内存中0x0000:0x0000地址之后的一片内存区域覆盖掉,当时感觉怎么会这样,因为在0x0000:0x0000之后的1024个字节内都是中断向量表,覆盖了之后,Linux系统该如何调用中断服务程序了,当时就很困惑,之后,自己查了些资料,感觉找这个原因就像是大海捞针一般,之后想明白了,原来是Linux内核又重新写了相应的中断,不用BIOS里的中断服务程序了),在内核正常运行之前则会在setup.s程序中重新初始化8259A芯片并且在head.s程序中重新设置一张中断向量表(中断描述符表)。完全抛弃了BIOS所提供的中断服务功能。
(三)、IDT表可以驻留在线性地址空间的任何地方,处理器使用IDTR寄存器来定位IDT表的位置。
(四)、个人感觉:中断向量表和中断描述符表都是用来查询中段服务程序的入口地址的,所以说从功能上来说都是一样的,只不过是中断向量表是在实模式下的名字,而中断描述符表是32位保护模式下的名字。
http://book.51cto.com/art/200812/103255.htm
点击打开链接
该篇文章主要介绍中断描述符表和IDTR寄存器的关系(通过IDTR寄存器中的IDT基地址[32位]和IDT限长[16位]来分析)
https://www.ibm.com/developerworks/cn/linux/l-cn-linuxkernelint/#toggle
点击打开链接
本篇文章中从两类中断控制器(8259A、APIC)的角度来分析中断,不过就是文章后面的部分领会不了。
http://www.ibm.com/developerworks/cn/linux/l-assembly/
点击打开链接
http://www.ibm.com/developerworks/cn/linux/sdk/assemble/inline/index.html
点击打开链接
http://docs.cs.up.ac.za/programming/asm/derick_tut/syscalls.html#size_t
点击打开链接
http://blog.csdn.net/xiaominthere/article/details/17190685
点击打开链接
http://guoshaoguang.com/blog/tag/bios/
点击打开链接
http://chuanwang66.iteye.com/blog/1069889
点击打开链接
点击打开链接
http://blog.csdn.net/jason314/article/details/5640969
点击打开链接