计算机操作系统进程切换
发布时间:2009/1/16 0:00:00 访问次数:868
进行进程切换就是从正在运行的进程中收回处理器,然后再使待运行进程来占用处理器。
这里所说的从某个进程收回处理器,实质上就是把进程存放在处理器的寄存器中的中间数据找个地方存起来,从而把处理器的寄存器腾出来让其他进程使用。那么被中止运行进程的中问数据存在何处好呢?当然这个地方应该是进程的私有堆栈。
让进程来占用处理器,实质上是把某个进程存放在私有堆栈中寄存器的数据(前一次本进程被中止时的中间数据)再恢复到处理器的寄存器中去,并把待运行进程的断点送入处理器的程序指针pc,于是待运行进程就开始被处理器运行了,也就是这个进程已经占有处理器的使用权了。
这就像多个同学要分时使用同一张课桌一样9说是要收回正在使用课桌同学的课桌使用权,实质上就是让他把属于他的东西拿走;而赋予某个同学课桌使用权,只不过就是让他把他的东西放到课桌上罢了。
在切换时,一个进程存储在处理器各寄存器中的中间数据叫做进程的上下文,所以进程的 切换实质上就是被中止运行进程与待运行进程上下文的切换。在进程未占用处理器时,进程 的上下文是存储在进程的私有堆栈中的。
从上面的叙述可知,调度器进程切换的代码应有如下功能:
●保存处理器pc寄存器的值到被中止进程的私有堆栈;
●保存处理器psw寄存器的值到被中止进程的私有堆栈;
●保存处理器sp寄存器的值到被中止进程的进程控制块;
●保存处理器其他寄存器的值到被中止进程的私有堆栈;
●自待运行进程的进程控制块取sp值并存入处理器的寄存器sp;
●自待运行进程的私有堆栈恢复处理器各寄存器的值;
●自待运行进程的私有堆栈中弹出psw值并送入处理器的psw;
●自待运行进程的私有堆栈中弹出pc值并送入处理器的pc。
显然,进程的切换可以用中断技术来实现,即当调度器获得了待运行进程的控制块之后,应立即用软中断指令来中止当前进程的运行,并保存当前进程的pc值和psw值。其后,使 用压栈指令把处理器其他寄存器的值压入进程私有堆栈。接下来,就从待运行进程的进程控 制块中取出私有堆栈指针的值并存入处理器的寄存器sp,至此sp就指向了待运行进程的私 有堆栈,于是下面就自待运行进程的私有堆栈中弹出上下文进人处理器。最后,利用中断返回指令来实现自待运行进程的私有堆栈中弹出psw值和自待运行进程的私有堆栈中弹出pc值的功能。
这是一个完整的软中断处理过程,只不过在保护现场和恢复现场工作中,保护的是被中止 运行进程的现场,恢复的是待运行进程的现场,这一切都依赖于堆栈指针的切换。
进程切换时,被中止进程保护断点和待运行进程保护断点的示意图如图所示。
图 调度器进行进程切换的动作
欢迎转载,信息来源维库电子市场网(www.dzsc.com)
进行进程切换就是从正在运行的进程中收回处理器,然后再使待运行进程来占用处理器。
这里所说的从某个进程收回处理器,实质上就是把进程存放在处理器的寄存器中的中间数据找个地方存起来,从而把处理器的寄存器腾出来让其他进程使用。那么被中止运行进程的中问数据存在何处好呢?当然这个地方应该是进程的私有堆栈。
让进程来占用处理器,实质上是把某个进程存放在私有堆栈中寄存器的数据(前一次本进程被中止时的中间数据)再恢复到处理器的寄存器中去,并把待运行进程的断点送入处理器的程序指针pc,于是待运行进程就开始被处理器运行了,也就是这个进程已经占有处理器的使用权了。
这就像多个同学要分时使用同一张课桌一样9说是要收回正在使用课桌同学的课桌使用权,实质上就是让他把属于他的东西拿走;而赋予某个同学课桌使用权,只不过就是让他把他的东西放到课桌上罢了。
在切换时,一个进程存储在处理器各寄存器中的中间数据叫做进程的上下文,所以进程的 切换实质上就是被中止运行进程与待运行进程上下文的切换。在进程未占用处理器时,进程 的上下文是存储在进程的私有堆栈中的。
从上面的叙述可知,调度器进程切换的代码应有如下功能:
●保存处理器pc寄存器的值到被中止进程的私有堆栈;
●保存处理器psw寄存器的值到被中止进程的私有堆栈;
●保存处理器sp寄存器的值到被中止进程的进程控制块;
●保存处理器其他寄存器的值到被中止进程的私有堆栈;
●自待运行进程的进程控制块取sp值并存入处理器的寄存器sp;
●自待运行进程的私有堆栈恢复处理器各寄存器的值;
●自待运行进程的私有堆栈中弹出psw值并送入处理器的psw;
●自待运行进程的私有堆栈中弹出pc值并送入处理器的pc。
显然,进程的切换可以用中断技术来实现,即当调度器获得了待运行进程的控制块之后,应立即用软中断指令来中止当前进程的运行,并保存当前进程的pc值和psw值。其后,使 用压栈指令把处理器其他寄存器的值压入进程私有堆栈。接下来,就从待运行进程的进程控 制块中取出私有堆栈指针的值并存入处理器的寄存器sp,至此sp就指向了待运行进程的私 有堆栈,于是下面就自待运行进程的私有堆栈中弹出上下文进人处理器。最后,利用中断返回指令来实现自待运行进程的私有堆栈中弹出psw值和自待运行进程的私有堆栈中弹出pc值的功能。
这是一个完整的软中断处理过程,只不过在保护现场和恢复现场工作中,保护的是被中止 运行进程的现场,恢复的是待运行进程的现场,这一切都依赖于堆栈指针的切换。
进程切换时,被中止进程保护断点和待运行进程保护断点的示意图如图所示。
图 调度器进行进程切换的动作
欢迎转载,信息来源维库电子市场网(www.dzsc.com)
上一篇:计算机操作系统调度策略(箅法)