操作系统导论(2)

前言

OS中CPU虚拟化的实现主要依赖于

  • 低级机制 决定进程切换的方法
  • 高级策略 决定进程切换的对象

本文就上述低级机制进行具体阐述。

上下文切换(context switch)

OS科学家们为了保证程序运行时高效可控,开发出了一种协议——受限直接执行(limited direct execution)。其中“直接执行”的步骤如下:

① 输入执行命令后,OS首先在其进程列表中为待运行进程创建一个进程条目,为其分配一些内存。

② 将程序代码从磁盘加载到内存中,找到程序运行点(main函数),开始运行代码。运行完毕后return返回值。

③ OS释放进程的内存,删除进程表中此进程条目。

这个过程中存在如下二个问题:

  • 进程在独占CPU时发生高权限行为时该如何处理?(如I/O请求,分配内存请求等)

  • 一个进程的时间片消耗完毕后OS如何重新得到CPU的控制权?

question 1

针对第一个问题,我们能想到的就是能不能给进程加一些限制,比如说给它贴上标签,低权限标签的进程不能执行某些高权限操作,这样便能较好地控制好进程的行为。

实际上计算机也是按这个思路实现的,不过计算机为了保证效果以及后续OS重新得到CPU控制权,采用了OS和硬件协同的方式来处理这一情况。

系统调用

处理器有7种工作模式,可分为用户模式系统模式(图中下方六种模式都能称为“系统模式”),也可称为用户态和核心态。绝大部分的程序都运行在“用户模式”下,而OS运行在“系统模式”下。因此当进程需要完成一些高权限操作时,它需要使处理器运行在“系统模式”下才能完成。

CPU的工作模式可以简单的理解为当前CPU的工作状态,比如:当前操作系统正在执行用户程序,那么当前CPU工作在用户模式,这时网卡上有数据到达,产生中断信号,CPU自动切换到一般中断模式下处理网卡数据(普通应用程序没有权限直接访问硬件),处理完网卡数据,返回到用户模式下继续执行用户程序。

处理器工作模式

由上文可知进程需要通过某个命令或者调用才能让处理器运行在“核心态”。这时需要OS发挥作用了。OS通过向进程暴露一些关键性的接口,例如访问文件,创建和销毁进程,与其他进程通信和分配更多内存等来使处理器进入“核心态”。这些接口被称为系统调用

陷阱

如果处理器运行在“用户”模式下,那么进程不能完全访问硬件资源。需要一个“入口”来负责进程与硬件的沟通。而“系统模式”可以直接访问全部硬件资源,因此进程要从“用户模式”通过一个“入口”进入“系统模式”,这个入口就被称为“陷阱(trap)”。执行系统调用的过程陷入内核态的过程。

当进程在“系统模式”下执行完相应的指令后,OS会调用一个“return-from-trap”的指令从核心态返回到用户态。

我们在程序中写的系统调用都是直接调用一些函数如open(),read()等。这使得系统调用看起来像过程调用。OS怎么知道这是系统调用呢?

原因如下:它其实是一个包含了系统调用的过程调用,调用的是C库中的函数,而C库中函数的具体实现包含了陷入内核的指令(trap)以及一些必须的指令。并且C库中的系统调用的部分是用汇编代码来实现的。这使得我们平时调用的系统调用都是对它们封装。

通过陷阱进入内核之后,此时OS如何知道要运行哪些代码以确保任务完成呢?这时就需要了解中断这一术语了。

中断

中断是指计算机运行过程中,出现某些意外情况需主机干预时,机器能自动停止正在运行的程序并转入处理新情况的程序,处理完毕后又返回原被暂停的程序继续运行。

引起中断发生的事件被称为中断源。中断源向CPU发出的请求中断处理信号称为中断请求,而CPU收到中断请求后转到相应的事件处理程序称为中断响应。

在有些情况下,尽管产生了中断源和发出了中断请求,但CPU内部的处理器状态字PSW的中断允许位已被清除,从而不允许CPU响应中断。这种情况称为禁止中断。CPU禁止中断后只有等到PSW的中断允许位被重新设置后才能接收中断。禁止中断也称为关中断,PSW的中断允许位的设置也被称为开中断。开中断和关中断是为了保证某段程序执行的原子性。

还有一个比较常用的概念是中断屏蔽。中断屏蔽是指在中断请求产生之后,系统有选择地封锁一部分中断而允许另一部分中断仍能得到响应。不过,有些中断请求是不能屏蔽甚至不能禁止的,也就是说,这些中断具有最高优先级,只要这些中断请求一旦提出,CPU必须立即响应。例如,电源掉电事件所引起的中断就是不可禁止和不可屏蔽的。

中断可以分为三类:

  • 外部中断
  • 内部中断
  • 陷阱

第一类是外部中断,如I/O中断、时钟中断、控制台中断等。

第二类是来自CPU的内部事件或程序执行中的事件引起的过程,称作异常,如由于CPU本身故障(电源电压低于1.05V或频率在47~63Hz之外)、程序故障(非法操作码、地址越界、浮点溢出等)等引起的过程。

第三类是进入核心态的陷阱。与前两类不同是,陷阱是主动、有意的,且其发生时间是确定的。而中断是被动,无意的,它的发生时间是不可预测的。

具体区别如下:

陷阱通常由处理器正在执行的现行指令引起,而中断则是由与现行指令无关的中断源引起的。陷阱处理程序提供的服务为当前进程所用,而中断处理程序提供的服务则不是为了当前进程的。中断是由硬件引起的,而异常是由软件引起的;中断是异步的,而异常是同步的。

按照事件发生的顺序,中断过程包括 :

① 中断源发出中断请求;

② 判断当前处理机是否允许中断和该中断源是否被屏蔽;

③ 优先权排队;

④ 处理机执行完当前指令或当前指令无法执行完,则立即停止当前程序,保护断点地址和处理机当前状态,转入相应的中断服务程序;

⑤ 执行中断服务程序;

⑥ 恢复被保护的状态,执行“中断返回”指令回到被中断的程序或转入其他程序。

上述过程中前四项操作是由硬件完成的,后两项是由软件完成的。

陷阱表

现在回到上述问题,转入到内核态后,OS如何知道要执行哪些代码呢?这通过trap table来实现。我们的计算机开机时,OS会初始化一个陷阱表,表中内容是陷阱指令与对应的陷阱处理程序的地址,每当系统调用时,OS就会到陷阱表中查找对应的处理程序地址。接下来CPU就运行处理程序。

question 2

OS如何获取CPU控制权以完成进程切换呢?我们知道进程在运行时是独占CPU的,此时OS没有运行。那么如何保证之后OS会重新取得CPU的控制权呢?

有如下两种方式:

协作方式:等待系统调用

早期一些OS的设计哲学是:相信进程是合理的。它假定进程会以某种系统调用的方式陷入(trap)OS,从而使OS获取控制权。或者进程会执行了某些引发异常的操作,使得OS重获控制权。这种通过异常或系统调用的方式太过于被动,面对恶意进程时,它将束手无策。我们迫切需要一种更强硬的方法来处理类似情况。

非协作方式:时钟中断

如果使用协作方式,当进程陷入无限循环时,唯一的方法就是重启。而在非协作方式中,可以使用时钟中断(timer interrupt)来使OS重新拿到控制权。这需要硬件来实现。在使用时钟中断这种进程切换方式时,需要2次寄存器的保存和恢复。第1次是中断发生时,将寄存器保存到内核栈。第2次是准备切换时将寄存器保存到进程结构的内存中。

进程切换上下文环境

处理器总处于以下状态中的一种:
1、内核态,运行于进程上下文,内核代表进程运行于内核空间;
2、内核态,运行于中断上下文,内核代表硬件运行于内核空间;
3、用户态,运行于用户空间。

用户空间的应用程序,通过系统调用,进入内核空间。这个时候用户空间的进程要传递很多变量、参数的值给内核,内核态运行的时候也要保存用户进程的一些寄存器值、变量等。所谓的“进程上下文”,可以看作是用户进程传递给内核的这些参数以及内核要保存的那一整套的变量和寄存器值和当时的环境等。

硬件通过触发信号,导致内核调用中断处理程序,进入内核空间。这个过程中,硬件的一些变量和参数也要传递给内核,内核通过这些参数进行中断处理。所谓的“中断上下文”,其实也可以看作就是硬件传递过来的这些参数和内核需要保存的一些其他环境(主要是当前被打断执行的进程环境)。

总结

上下文切换:进程在进行切换时,OS会保存进程A的寄存器的值,然后恢复待执行进程B的寄存器,OS将控制权移交给待执行进程B,进程B开始运行。

系统调用是导致进程切换的一种方式。如果系统调用期间又发生了时钟中断,或是处理一个中断期间又发生了另一个中断,这会发生什么呢?我们会在并发章节学习到这些情况的处理办法。

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

推荐阅读更多精彩内容

  • 计算机系统漫游 代码从文本到可执行文件的过程(c语言示例):预处理阶段,处理 #inlcude , #defin...
    willdimagine阅读 3,579评论 0 5
  • 第一章 A:操作系统:是管理计算机硬件并提供应用程序运行环境的软件 1)资源分配器,管理资源、分配资源 2)控制程...
    ZoeyeoZ阅读 1,105评论 0 4
  • 1.内存的页面置换算法 (1)最佳置换算法(OPT)(理想置换算法):从主存中移出永远不再需要的页面;如无这样的...
    杰伦哎呦哎呦阅读 3,247评论 1 9
  • 陷阱分发 陷阱(trap)指的是这样一种机制,当异常或中断发生时,处理器捕捉到一个执行线程,并且将控制权转移到...
    kotw_zjc阅读 1,226评论 0 0
  • 如果不开车,是没有勇气走进这样的山庄酒店的。 酒店环境优美,装修豪华,配套措施高档,安静,空气新鲜,刚刚过年,现在...
    三湖之春阅读 893评论 14 34