中断处理流程
来源:互联网 发布:校园表白墙网站源码 编辑:程序博客网 时间:2024/04/27 22:57
1.cpu执行完一条指令后检查intr线查看是否发生了中断。如果发生的话跳转到第2步。
2.从总线获取中断向量。
3.到idt中找到对应的中断描述符。检查该中断是否合法。首先中断描述符中的段选择符的dpl优先级必须高于等于当前cpu特权级。其次中断描述符中的dpl优先级必须低于等于当前cpu特权级。(限制用户态程序只能经过特定的门)
4.比较中断描述符中的段选择符的dpl和当前的cpu特权级,判断是否从用户台进入了内核态。如果发生了跳转到第5步,否则第6步。
5.从tss段获取内核态的ss,esp装载当前的ss,esp寄存器。然后保存旧的ss,esp到新栈中。(这一步实际上就是用户台到内核态的切换)
6.在栈中保存eflags,cs,eip内容。
7.如果异常产生了一个硬件出错码,将它保存在栈中。
2.从总线获取中断向量。
3.到idt中找到对应的中断描述符。检查该中断是否合法。首先中断描述符中的段选择符的dpl优先级必须高于等于当前cpu特权级。其次中断描述符中的dpl优先级必须低于等于当前cpu特权级。(限制用户态程序只能经过特定的门)
4.比较中断描述符中的段选择符的dpl和当前的cpu特权级,判断是否从用户台进入了内核态。如果发生了跳转到第5步,否则第6步。
5.从tss段获取内核态的ss,esp装载当前的ss,esp寄存器。然后保存旧的ss,esp到新栈中。(这一步实际上就是用户台到内核态的切换)
6.在栈中保存eflags,cs,eip内容。
7.如果异常产生了一个硬件出错码,将它保存在栈中。
8.装载新的cs,eip寄存器(就是中断处理程序的入口,从中断描述符里可以找到)
点击打开链接
0 0
- ARM中断处理流程
- Linux中断处理流程
- linux 中断处理流程
- Linux中断处理流程
- 中断处理流程
- Linux中断处理流程
- STM32中断流程处理
- STM32中断流程处理
- 中断处理流程
- Linux中断处理流程
- Linux中断处理流程
- Linux中断处理流程
- arm处理中断流程
- 中断处理流程
- 中断处理流程分析
- 中断处理流程
- 中断处理流程记录
- ARM中断处理流程
- SharePoint JS Link 之(一) 改变column的颜色
- Building and Running Overview(官方)
- 使用JAVA搭建MySQL数据库
- Mac OX下终端命令行操作大全
- UVa 12333 - Revenge of Fibonacci <大数 字典树>
- 中断处理流程
- Java IO之文件输入、输出流
- matlab函数_常用于连通区域
- 最短路径A
- hdoj1170.
- sk_buff的操作函数
- PAT|中国大学MOOC-翁恺-C语言程序设计习题集29-32
- 23种设计模式之十六(行为模式)Observer模式
- [Leetcode]Sort List