计算动态优先级 -- effective_prio()

effective_prio()函数返回进程p的动态优先级


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

如果进程p是个实时进程,那么直接返回该实时进程的prio(实时进程的动态优先级prio不依赖于静态优先级static_prio,两者是否相等???)
|----------------------------|
|   if ( rt_task(p))          |
|       return p->prio;      |
|----------------------------|

计算红利bonus:
|---------------------------------------------|
|   bonus = CURRENT_BONUS(p) - MAX_BONUS / 2; |
|---------------------------------------------|

根据如下公式计算该进程动态优先级prio:
prio = max ( 100, min(static_prio - bonus + 5, 139) )
|------------------------------------|
|   prio = p->static_prio - bonus;   |
|   if (prio < MAX_RT_PRIO)          |
|       prio = MAX_RT_PRIO;          |
|   if (prio > MAX_PRIO-1)           |
|       prio = MAX_PRIO-1;           |
|------------------------------------|
    return prio;
}








 
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值