中断通常被定义为一个打断CPU芯片指令执行的事件,该事件对应到对应到CPU芯片内部或者外部的电路产生的电子信号。
中断信号可以被划分为同步中断和异步中断:
- 同步中断,该类型中断由CPU的控制单元在执行指令的时候产生,并且是在当前指令执行完毕下一个指令执行之前产生。
- 异步中断,该类型中断由其他硬件设备在任意的时间产生,并且遵循CPU的时钟信号传递给CPU。
对于Intel的CPU而言,它将同步中断称作异常,而将异步中断称作中断。
通常中断(即异步中断)由时钟定时器或者其他I/O设备产生,如键盘接收到敲击某个按键的信号后产生的中断信号。而异常(即同步中断)则通常由于编程错误或者由CPU检测到异常条件需要内核进行处理而产生,如熟悉的Page Fault Exception,异常可以由程序通过int或者sysenter指令主动产生。
对于Intel x86 CPU而言,它将中断和异常进行了如下归类:
- 中断,即异步中断,中断信息随着CPU的时钟信号传递到CPU内部。
- 可屏蔽中断,所有由I/O设备产生的IRQ请求都被归为可屏蔽中断。一个可屏蔽中断可以有两种状态,屏蔽或者不屏蔽,当一个中断被屏蔽时,该中断信号将被对应的控制单元所忽略。
- 不可屏蔽中断,即控制单元无法忽略该类型的中断信号,CPU肯定会接收到该类型的中断,一般对应到一些紧要的事件,比如硬件错误。
- 异常,即同步中断,中断信号在CPU执行完某个指令后产生并接收到。
- 处理器检测到的异常,即当CPU执行指令的时候检测到硬件上存在一些异常条件的时候就会产生该信号。这种类型的异常根据产生时在内核堆栈中保存的EIP寄存器的值(即异常恢复后CPU重新执行的位置)进行细分:
- Faults,该异常可以被内核正确纠正,并且纠正后重新执行引起该异常的指令时不会造成程序的中断或者功能的异常。这时候保存到EIP寄存器的值是引起异常的指令的地址,故异常恢复的时候会重新执行该指令,如Page Fault Exception,当
- 处理器检测到的异常,即当CPU执行指令的时候检测到硬件上存在一些异常条件的时候就会产生该信号。这种类型的异常根据产生时在内核堆栈中保存的EIP寄存器的值(即异常恢复后CPU重新执行的位置)进行细分: