操作系统:中断

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

常见的控制和状态寄存器:程序计数器(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控制权转给中断处理程序:保存相关寄存器信息;分析中断/异常的具体原因;执行对应的处理功能;恢复现场,返回被事件打断的程序;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容