操作系统:中断

作者: SeanC52111 | 来源:发表于2017-03-25 22:17 被阅读257次

控制和状态寄存器:用于控制处理器的操作,通常由操作系统代码使用,在某种特权级别下可以访问、修改

常见的控制和状态寄存器:程序计数器(program counter),记录将要取出的指令的地址;指令寄存器(Instruction Register),记录最近取出的指令;程序状态字(Program Status Word)记录处理器的运行状态如条件码、模式、控制位等信息。

操作系统的需求——保护:实现保护与控制;需要硬件提供基本运行机制:处理器具有特权级别,能在不同的特权级运行的不同指令集合;硬件机制可将OS与用户程序隔离。

特权指令和非特权指令:

操作系统需要两种CPU状态:1.内核态:运行操作系统程序;2.用户态:运行用户程序;

特权指令:只能由操作系统使用、用户程序不能使用的指令。

非特权指令:用户程序可以使用的指令。

操作系统可以执行特权指令和非特权指令

特权指令:启动I/O 内存清零 修改程序状态字 设置时钟 允许/禁止中断 停机

非特权指令:控制转移 算数运算 防管指令 取数指令

X86处理器支持4个处理器特权级别

特权环:R0,R1,R2,R3

从R0到R3,特权能力由高到低,R0相当于内核态;R3相当于用户态;R1和R2则介于两者之间

CPU状态之间的转换:

用户态->内核态 唯一途径是中断/异常/陷入机制

内核态->用户态 设置程序状态字PSW

中断/异常的概念:

CPU对系统发生的某个事件做出的一种反应

CPU暂停正在执行的程序,保留现场后自动转区执行相应事件的处理程序,处理完成后返回断点,继续执行被打断的程序。

事件的发生改变了处理器的控制流,特点是随即发生的,自动处理的,可恢复的

为什么引入中断与异常?

中断的引入:为了支持CPU和设备之间的并行操作,当CPU启动设备进行输入/输出后,设备便可独立工作,CPU转去处理与此次输入/输出不相关的事情;当设备完成输入/输出后,通过向CPU发中断报告此次输入/输出的结果,让CPU决定如何处理以后的事情。

异常的引入:表示CPU执行指令时本身出现的问题。如算数溢出、除零、取数时的奇偶错,访内存地址时越界或执行了陷入指令等,这时硬件改变了CPU当前的执行流程,转到相应的错误处理程序或异常处理程序或执行系统调用。

事件包括中断(外中断)和异常(内中断)

中断:外部事件,正在运行的程序所不期望的。I/O中断(键盘上按Ctrl+C,网卡接收数据包,打印机结束,读盘结束),时钟中断(设定定时器到点,CPU运行时间片到了),硬件故障(笔记本电池低电量,内存奇偶校验错)

异常:由正在执行指令引发。系统调用,页故障/页错误,保护性异常(只读内容写操作,地址访问越界),断点指令(单步调试),其他程序性异常(算数溢出)

中断/异常机制工作原理:

中断/异常机制是现代计算机系统的核心机制之一,硬件和软件相互配合而使计算机系统得以充分发挥能力

硬件该做:捕获中断源发出的中断/异常请求,以一定方式相应,将处理器控制权交给特定的处理程序(中断/异常的相应)

软件要做:识别中断/异常类型并完成相应的处理(中断/异常处理程序)

中断响应过程:在每条指令执行周期的最后时刻扫描中断寄存器,查看是否有中断信号。若有中断,中断硬件将该中断触发器内容按规定编码送入PSW的相应位,称为中断码,通过查中断向量表引出中断处理程序。

中断向量表由中断向量构成。

中断向量:一个内存单元,存放中断处理程序入口地址和程序运行时所需的处理机状态字。

执行流程按中断号/异常类型的不同,通过中断向量表转移控制权给中高端处理程序。

中断响应示意图:1.设备发中断信号 2.硬件保存现场 3.根据中断码查表 4.把中断处理程序入口地址等推送到相应寄存器 5.执行中断处理程序

中断处理程序

设计操作系统时,为每一类中断/异常事件编好相应的处理程序,并设置好中断向量表。

系统运行时若响应中断,中断硬件部件将CPU控制权转给中断处理程序:保存相关寄存器信息;分析中断/异常的具体原因;执行对应的处理功能;恢复现场,返回被事件打断的程序;

相关文章

  • 操作系统拾遗-中断与系统调用

    中断 概念 操作系统是中断驱动的,整个操作系统离不开中断机制,所谓的中断机制,宏观上讲就是cpu在执行某件事情时可...

  • 操作系统:中断

    控制和状态寄存器:用于控制处理器的操作,通常由操作系统代码使用,在某种特权级别下可以访问、修改 常见的控制和状态寄...

  • 操作系统中断

    1 中断机制的产生 早期计算机各个程序只能串行执行、系统资源利用低。为了解决上述问题,人们就发明了操作系统,引入了...

  • 操作系统笔记5-导论(五)

    操作系统的执行 现代操作系统是由中断驱动的,在没有用户需要响应时,操作系统会等待直到某个事件的发生。事件总是由中断...

  • 每日记录之操作系统的中断

    操作系统的中断 计算机遇到一些更紧急的工作,中断当前的工作,去处理更紧急的工作 中断的类别 外部中断,内部中断,软...

  • windows异常

    异常处理 异常和中断是由CPU触发的.操作系统怎么接收到异常的?IDT表, 操作系统在启动时,就会将中断处理的地址...

  • 1. 操作系统的实时性

    核心在于,内核是否可以无条件的被中断被抢占。 真正的实时操作系统内核是可中断可抢占的。而非实时的操作系统通常...

  • Linux IO多路复用底层原理(刚接触,知识还不成体系,等懂得

    Linux 操作系统中断 什么是系统中断系统处理中断的过程: 首先由需要紧急处理的程序向处理器发送中断请求,处理器...

  • 操作系统中断机制

    什么是中断 操作系统需要对连接到计算机上的所有硬件设备进行管理,要管理这些设备,首先得和它们互相通信才行,一般有两...

  • CPU外设中断

    中断向量和中断服务例程的对应关系主要是由 IDT(中断门描述符表)来描述。操作系统在IDT 中设置好各种中断向量对...

网友评论

    本文标题:操作系统:中断

    本文链接:https://www.haomeiwen.com/subject/nhacottx.html