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寄存器(就是中断处理程序的入口,从中断描述符里可以找到)