在实验楼当中进行实验3的实践:主要是针对cpu占用分配,使用时间片轮转算法进行分配
在Shell命令当中输入如下代码:
$ cd ~/LinuxKernel/linux-3.9.4
$ rm -rf mykernel
$ patch -p1 < ../mykernel_for_linux3.9.4sc.patch
$ make allnoconfig
$ qemu -kernel arch/x86/boot/bzImage
可以看到qemu工具进行工程make了之后出现了两个c文件,分别是mymain.c 和 myinterrupt.c一个是主要的时间片轮转算法的实现,另一个则是处理器中断的实现。
void __init my_start_kernel(void)
{
int i = 0;
while(1)
{
i++;
if(i%100000 == 0)
printk(KERN_NOTICE "my_start_kernel here %d
",i);
}
}
可以看到在原生代码当中my_start_kernel() 是系统启动后的函数入口,首先进行初始化和启动0号进程,同时创建其它的进程PCB,以方便后面的调度。 在该系统中,每个进程都执行my_process() 函数,my_process()将会打印出当前进程的 id,方便观察进程的切换。
my_time_handler()函数模拟时间片轮转,该函数周期性地发出中断信号,也就是my_need_sched。my_start_kernel()初始化每个进程,执行my_process()
总结:这次实验是要是对于linux内核当中的时间片轮转算法进行模拟,通过时钟模拟信号中断与否,并且通过两个c文件进行实现,一个是mymain.c,另一个是myinterrupt.c两个文件执行的。
mymain的主要目的是进行循环,在循环当中进行正常工作,而interrupt则是通过时钟信号的模拟,来对main程序进行中断打断,并实现函数。