中断来自外部,异常来自内部。
中断/异常:指系统发生某个异步/同步事件后,处理机暂停正在执行的程序,转去执行处理该事件程序的过程。
中断引入:为了开发CPU和通道(或设备)之间的并发操作。
异常引入:用于表示CPU执行指令时本身引发的事件。
中断的分级
分级原因:不同的中断可能在同一时间点发出请求。
解决办法:将中断存起来。提供一个容器:中断寄存器——寄存中断事件的全部触发器。给级别高的中断享有优先响应的权利,这称为中断优先级。
一般的来说,告诉设备的优先级高于慢速设备。
原因:高速设备的中断被处理机优先响应时,可以让处理机尽快地向它发出下一个I/O请求,提高高速设备的利用率。
中断的屏蔽
中断屏蔽原因:为了打破优先等级支配硬件的不灵活性引入。
中断屏蔽:指禁止处理机响应中断或禁止中断出现。
两种实现方法:
硬件实现(由软件设置处理机优先级,硬件按系统设计时的约定,屏蔽那些低优先级中断;
软件实现(由软件按操作系统优先级约定,设置屏蔽寄存器)。
两种屏蔽类型:
硬屏蔽:禁止中断出现的屏蔽方式;
软屏蔽:设备中断,时钟中断等部分硬件中断可以被暂时禁止响应,到屏蔽被解除时再处理。
中断和异常的响应
机制:
外部发中断给CPU中的中断检测机构
异常:是在执行指令的时候,由指令本身原因引发的问题。指令的实现逻辑发现发生异常则转入操作系统内的异常处理程序。
断点和恢复点
断点:检测到中断信号时,处理机刚执行完的那条指令地址即为断点,通常是PC的内容减去前一条指令占的单元长度。
恢复点:断点的逻辑后续指令地址,PC的值。
因为中断是一个暂时的处理,所以在中断前后必须保存和恢复“程序现场”。
现场信息:指在中断那一刻,确保被中断程序能继续运行的有关信息,如PC、通用寄存器、特殊寄存器等的内容
对于异常,返回点不一定是恢复点
1)大部分用户程序出错,则结束进程;
2)系统调用,则返回恢复点继续执行;
3)缺页异常,则处理完异常后,重新执行。
核心态和用户态
引入原因:CPU通常会执行两种程序,一种是操作系统内部程序,一种是操作系统外部程序。为了保证操作系统的安全引用核心态和用户态来保证安全。
核心态(系统状态,监督方式,管态):允许特权指令执行的状态,在此状态下地址空间也较大。
用户态(用户方式,目态):一般用户所运行的状态。
区分方法:在状态字寄存器设置标志位,用0 1 表示用户态和核心态。
中断/异常向量:一个存放中断/异常处理程序入口地址和程序运行所需处理机状态字的内存单元。
中断/异常处理
中断/异常处理的一般过程:
中断,异常进入;
保存现场;
分析原因,转中断(异常)处理程序;
恢复现场。
1、中断,异常进入
硬件自动将当前PC,PS存入暂存寄存器;
2、保存现场
使用“栈的形式进行保存”
3、分析原因,转中断(异常)处理程序
总控程序根据中断/陷入原因,转到各个中断/异常处理程序,同时将返回总空程序的地址保存在栈中。
中断:直接转至其入口地址;
异常:还要根据dev保存的当前发生的陷入
类型,作相应的处理。
4、恢复现场
- 如果是高级中断,且被中断是低级中断,就返回到该低级中断。
- 如果被中断的是用户态,则退出以前考虑的的一次调度选择,挑选更合适当前的新程序。