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