- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
linux 中断处理之初始化
发布者:chinaitlab 日期: 2010-09-03 00:00:00 浏览次数:0 (共有_条评论) 查看评论 | 我要评论
一:引言
在 Intel 的文档中,把中断分为两种.一种是异常,也叫同步同断.一种称之为中断,也叫异常中断.
同步中断指的是由 CPU 控制单元产生,之所以称之为同步,是因为只有一条指令执行完毕后才会发出中断.例如除法运算中,除数为零的时候,就会产生一个异常
异步中断是由外部设备按照CPU 的时钟随机产生的.例如,网卡检测到一个数据到来就会产生一个中断.
二:x86 的中断处理过程
由于中断是开着的,所以当执行完一条指令后,cs 和 eip 这对寄存器中已经包含了下一条将要执行的指令的逻辑地址。在处理那条指令之前,控制单元会检查在运行前一条指令时是否发生了一个中断或异常。 如果发生了一个中断和异常,那么控制单元执行下列操作:
确定与中断或异常关联的向量i(0≤ i ≤255)
读由 idtr 寄存器指向的 IDT 表中的第i 项。
从 gdtr 寄存器获得 GDT 的基地址,并在 GDT 中查找,以读取 IDT 表项中的选择符标识的段描述符。这个描述符指定中断或异常处理程序所在的段的基地址。
确信中断是由授权的(中断)发生源发出的。首先将当前特权级CPL(存放在 cs 寄存器的低两位) 与段描述符(存放在 GDT 中)的描述符特权级DPL 比较。如果 CPL 小于 DPL,就产生一个“通常保护”异常,因为中断处理程序的特权级不能低于引起中断的程序的特权。对于编程异常,则做进一步的安全检查:
比较 CPL 与处于 IDT 中的门描述符的 DPL,如果 DPL 小于 CPL,就产生一个“通常保护”异常,这最后
一个检查可以避免用户应用程序访问特殊的陷阱门和中断门。
检查是否发生了特权级的变化,也就是说,CPL 是否不同于所选择的段描述符的DPL。如果是,控制单元必须开始使用与新的特权级相关的栈,通过执行以下步骤来保证这一点:
读 tr 寄存器,以访问运行进程的 TSS 段。
用与新特权级相关的栈段和栈指针的正确值装载ss 和 esp 寄存器。这些值可以在 TSS 中找到。
在新的栈中保存 ss 和 esp 以前的值,这些值定义了与旧特权级相关的栈的逻辑地址。
如果故障已发生,用引起异常的指令地址装载cs 和 eip 寄存器,从而使得这条指令能再次被执行。
在栈中保存 eflag、cs 和 eip 的内容。
如果异常产生了一个硬件出错码,则将它保存在栈中。
装载 cs 和 eip 寄存器,其值分别是 IDT 表中第i 项门描述符的段选择符和偏移量字段。这些值给出了中断或者异常处理程序的第一条指令的逻辑地址。
控制单元所执行的最后一步就是跳转到中断或异常处理程序。换句话说,处理完中断信号后,控制单 元所执行的指令就是被选中处理程序的第一条指令。
上面的处理过程的描述摘自深入理解 linux 内核,其中有几点值得注意的地方:
1:通过门后,只能提高运行级别.就像上面所述的 “当前特权级 CPL(存放在 cs 寄存器的低两位)与段描述符(存放在 GDT 中)的描述符特权级 DPL 比较。如果 CPL 小于 DPL,就产生一个“通常保护”异常”. 在中断处理中,通常把 IDT 中的相应段选择符设为 KERNEL_CS.即最高的运行级别
2:上面 C 所述:“在新的栈中保存 ss 和 esp 以前的值,这些值定义了与旧特权级相关的栈的逻辑地址”,
那ss,esp 以前的值是如何找到的呢?应该是从TSS 中.在中断发生的时候,如果检测到运行级别发生了改了, 将寄存器 SS,ESP 中的值保存进TSS 的相应级别位置.再加载新的SS,ESP 的值,然后从 TSS 中取出旧的S S,ESP 值,再压栈.
3:堆栈的改变,如下图所示:
从上图中我们可以看到,硬件自动保存的硬件环境是非常少,要在中断后恢复到以前的环境,还需要保存 更多的寄存器值,这是由操作系统完成的.这我们在以后的代码分析中可以看到
中断和异常被处理完毕后,相应的处理程序必须产生一条iret 指令,把控制权转交给被中断的进程, 这将迫使控制单元:
用保存在栈中的值装载 cs、eip 和 eflag 寄存器。如果一个硬件出错码曾被压入栈中,并且在eip
内容的上面,那么,执行 iret 指令前必须先弹出这个硬件出错码。
检查处理程序的 CPL 是否等于 cs 中的低两位的值。如果是,iret 终止返回;否则,转入下一步。
从栈中转载 ss 和 esp 寄存器,因此,返回到与旧特权级相关的栈。
检查 ds、es、fs 及 gs 段寄存器的内容,如果其中一个寄存器包含的选择符是一个段描述符,并且其 DPL 值小于 CPL,那么,清
您可能关注的文档
最近下载
- TSZEIA 014-2023 二手手机出口质量要求.pdf VIP
- 2025年高考湖南卷物理真题 含答案.pdf VIP
- 个股动量效应的识别及“球队硬币”因子构建.pdf VIP
- 微机型母线保护分析与应用.pdf VIP
- (人教版)一年级上册科学 观察物体教案.doc VIP
- 学校EPC工程项目实施的重难点分析及对策.pdf VIP
- 典型事故五:内蒙古泰和煤焦化集团有限公司“4.8”爆炸事故.pdf VIP
- 2020款上汽通用别克君越_汽车使用手册用户操作图解驾驶车主车辆说明书电子版.pdf
- 基于新课标“教学评”一体化的小学语文教学设计与实施 培训课件.pptx
- 陶艺课程--校本特色课程-专题讲座.pptx VIP
文档评论(0)