有了之前的了解,可以对进程管理进行一个测试。在测试之前,还需要做一些准备工作。
首先,需要增加一个刷新调度因子的程序,如果没有这个程序,调度因子将一直为0。
void Proc_alarm(void)
{
int i;
for( i = 1 ; i < PROC_MAX ; i++)
{
if( !proc_pool[i].proc_stat )
continue;
if( proc_pool[i].proc_alarm ) proc_pool[i].proc_alarm--;
proc_pool[i].proc_sched_factor += 5;
}
}
在每次调用这个程序,调度因子加5,这个函数主要在时钟中断处理程序中调用,所以之前的时钟处理程序也要进行修改。
void Clk_do_clock(void)
{
ticks++;
Clk_msg();
Proc_alarm();
if( --proc_current->proc_cpu_time < 1 ) /* 进程时间消耗完,需要进行调度 */
{
proc_current->proc_cpu_time = 0;
Proc_sched();
}
}
每次时钟中断发生后,首先计算调度因子,然后递减进程的CPU时间,如果进程的CPU时间耗尽,则进行任务调度。
做了以上的准备后,可以进行测试了。
#define STACK_SIZE 512
byte_t stack1[STACK_SIZE];
byte_t stack2[S

本文介绍了在Lenix操作系统中进行进程管理与任务调度的测试过程。首先,通过增加刷新调度因子的程序和修改时钟中断处理,使得调度因子在时钟中断后增加,并在CPU时间耗尽时进行任务调度。接着,使用停机指令减少无任务运行时的能量消耗。测试通过创建两个死循环程序,在屏幕不同位置交替输出字符串,展示了Lenix的多任务管理能力。
最低0.47元/天 解锁文章
505

被折叠的 条评论
为什么被折叠?



