进程调度之o(1)算法

本文介绍了Linux系统中非实时进程的动态优先级计算方法。通过有效利用sleep_avg参数,将睡眠时间转换为bonus值,进而调整任务的动态优先级。同时,确保动态优先级在合理范围内。

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

bonus和prio的计算方法

static int effective_prio(task_t *p)
{
    int bonus, prio;

    if (rt_task(p))             ;;如果是实时进程则返回(实时进程的动态优先级是由setscheduler()函数设置且一经设置不再改变)
        return p->prio;

    bonus = CURRENT_BONUS(p) - MAX_BONUS / 2; ;;根据睡眠时间设置bonus值

    prio = p->static_prio - bonus; ;;由静态优先级和bonus值来设置动态优先级
    if (prio < MAX_RT_PRIO)        ;;动态优先级范围不能小于MAX_RT_PRIO也不能超过MAX_PRIO,所以此处做下判断。
        prio = MAX_RT_PRIO;
    if (prio > MAX_PRIO-1)
        prio = MAX_PRIO-1;
    return prio;
}

#define CURRENT_BONUS(p) \
    (NS_TO_JIFFIES((p)->sleep_avg) * MAX_BONUS / \ ;;把睡眠时间转化为bonus值
        MAX_SLEEP_AVG)


【内核】非实时进程、实时进程、静态优先级、动态优先级、实时优先级
https://www.cnblogs.com/visayafan/archive/2011/12/08/2280459.html


recalc_task_prio函数

https://blog.youkuaiyun.com/yunsongice/article/details/5526340


Linux进程调度策略的发展和演变--Linux进程的管理与调度(十六) 
https://blog.youkuaiyun.com/gatieme/article/details/51701149

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值