结论分析
- 不能的policy之间是可以抢占的,比如sched_normal policy可以抢占sched_idle policy 的任务。 sched_batch 不抢占
- 唤醒时的唤醒任务和被幻想任务,如果两个特性 next_buddy 以及 last_buddy被打开的话,是可以支持抢占的
- 如果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

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

被折叠的 条评论
为什么被折叠?



