其他语言

本类阅读TOP10

·基于Solaris 开发环境的整体构思
·使用AutoMake轻松生成Makefile
·BCB数据库图像保存技术
·GNU中的Makefile
·射频芯片nRF401天线设计的分析
·iframe 的自适应高度
·BCB之Socket通信
·软件企业如何实施CMM
·入门系列--OpenGL最简单的入门
·WIN95中日志钩子(JournalRecord Hook)的使用

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
多任务操作系统的任务切换

作者:未知 来源:月光软件站 加入时间:2005-5-13 月光软件站

在学习OS时,对于多任务操作系统的任务切换,一直不能理解:控制权是怎么么回到调度程序上的?
记得在描述任务切换时,一般都是这么描述的:在每一个时钟滴答,都将检查当前进程是否是一个运
行超过100毫秒的用户进程。如果是,则调用调度程序来查看是否有另一个用户进程在等待CPU,...

我这里举个例子:我用C写了一个程序:helloworld。代码如下:

#code_start
void main(void)
{ puts("Hello world first.");
  puts("Hello world second.");
}
#code_end

我在minix下进行代码,当程序运行到 puts("Hello world first.") 时,便会在屏幕上打印出
Hello world first. 有一点是可以肯定的,CPU现在在我的程序的控制之下。但不巧的时,这时调度
程序发现了另一个程序需要CPU,于是立刻便把CPU从我的helloworld里“取“了回去,并交给另一个程序。

如果调度程序的入口地址是:scheduler。那么,在我的helloworld里总该有一个 jmp scheduler 吧。
这样才能跳转到 scheduler 里去啊。

当然,看minix的源代码是最好的办法,不过,用我现在掌握的知识也可以把 scheduler 摸拟出来。刚才
想到了,于是便马上把它记下来了。

实现很简单,利用中断便可以完成这一功能。

在每一秒钟,中断 0x1c 都被调用18.2次,可以改写这个中断:

#code_start
void new_int_1c(void)
{
 volatile static int count = 0;
 
 if( count++ > 17 )
 {
  count = 0;
  _asm jmp scheduler;  //scheduler是调度程序的入中口
 }

#code_end

于是,每隔大约一秒钟,控制权就会重新回到调度程序,再就可以由调度决定CPU的控制权了。

当然,用0x1c只是为了好写代码而已,真正的OS,就是对5253/8254直接编程的了。




相关文章

相关软件