cfs调度的抢占

本文解析了Linux内核中CFS调度器的特性,探讨了不同policy之间的抢占规则,如sched_normalpolicy和sched_idlepolicy,以及唤醒任务的处理方式。重点介绍了check_preempt_wakeup和place_entity等关键函数在抢占决策中的作用。

结论分析

  1. 不能的policy之间是可以抢占的,比如sched_normal policy可以抢占sched_idle policy 的任务。 sched_batch 不抢占
  2. 唤醒时的唤醒任务和被幻想任务,如果两个特性 next_buddy 以及 last_buddy被打开的话,是可以支持抢占的
  3. 如果wakeup任务的vruntime时间小于curr的vruntime时间,差值大于sysctl_sched_wakeup_granularity, 则设置next_buddy (set_next_buddy)

#涉及的函数
check_preempt_wakeup 可能会设置NEXT_BUDDY 和 LAST_BUDDY, cfs_rq里面有next和last 指针,支持抢占
place_entity (会对睡眠进程以及新创建的进程分配vruntime时间片)
pick_next_entity

主要函数分析

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值