Proc_sleep源代码分析

来源:互联网 发布:淘宝快打软件 编辑:程序博客网 时间:2024/05/29 16:29

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();        }

该程序用于唤醒指定的进程,无论其处于睡眠态还是等待态。

该程序首先对传入的参数进行校验,指针无效或者对象是空闲状态都说明代码有误。

在确定参数有效后,则将进程设为运行态。如果这时候进程可抢占,就立即进行调度,因为刚进入运行态的进程可能比当前进程具有更高的优先级。