多任务操作系统的任务切换

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

在学习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直接编程的了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航