Proc_sleep源代码分析

Proc_sleep是Lenix系统中控制进程状态的程序,用于将进程置于睡眠态,然后调度其他进程。Proc_wakeup负责唤醒睡眠态的进程,进行批量操作,可能导致多个进程意外唤醒。此外,还有一个定点唤醒程序,用于精确唤醒特定进程,会检查参数有效性并根据抢占条件进行调度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值