Proc_sleep程序是Lenix进程状态控制程序中的一个,与其对应的是Proc_wakeup程序。
其代码
void Proc_sleep(void)
{
if( proc_current == proc_lenix )
Sys_halt("Lenix try to sleep.");
proc_current->proc_stat = PROC_STAT_SLEEP;
Proc_sched();
}
程序首先判断当前进程是否为系统进程,如果是系统进程,说明程序有误,显示提示信息后死机。
程序将自身状态设为睡眠态,然后执行调度程序,切换到其他进程。如果没有其他进程唤醒,该进程将不会再次参与调度。
如果要唤醒进程,要通过Proc_wakeup
其代码为:
void Proc_wakeup(void)
{
int i;
Disable_irq();
for( i = 1 ; i < PROC_MAX ; i++)
{
if( PROC_STAT_SLEEP == proc_pool[i].proc_stat )
proc_pool[i].proc_stat = PROC_STAT_RUN;
}
Enable_irq();
if( PROC_CAN_SEIZE() )
Proc_sched();
}
该程序的做法为:从头开始遍历进程池,将所有处于睡眠态的进程全部设为运行态,以达到唤醒进程的目的。注意,该程序是一个批量唤醒操作。如果当系统中存在多个处于睡眠态的进程,该程序都会将其唤醒。其产生的效果是:处于睡眠态的进程会在意想不到的地方被唤醒。可能是由于某个进程调用了Proc_wakeup。
Lenix还提供了一个定点唤醒的程序
void Proc_wakeup_proc(proc_t * proc)
{
if( PROC_IS_INVALID(proc) || PROC_STAT_IS_FREE(proc) )
Sys_halt("try to wakeup null process\n");
proc->proc_stat = PROC_STAT_RUN;
if( PROC_CAN_SEIZE() )
Proc_sched();
}
该程序用于唤醒指定的进程,无论其处于睡眠态还是等待态。
该程序首先对传入的参数进行校验,指针无效或者对象是空闲状态都说明代码有误。
在确定参数有效后,则将进程设为运行态。如果这时候进程可抢占,就立即进行调度,因为刚进入运行态的进程可能比当前进程具有更高的优先级。