完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
本文看下内核态是如何对 task 进行调度的。
调度的发展历史 O(n)算法虽然历史有点悠久,但很有必要研究,是后续O(1)等算法理解的基础。由于O(n)不是本文重点,建议先去网上了解相关知识点。 O(1) 调度器: O(1) 调度器中引入了per-CPU runqueue的概念。系统中所有的可运行状态的进程首先经过负载均衡模块挂入各个CPU的runqueue,每隔 200ms,处理器都会检查 CPU 的负载是否不均衡,如果不均衡,处理器就会在 CPU 之间进行一次任务均衡操作。然后由主调度器和tick调度器驱动该CPU上的调度行为。每一个优先级的进程被挂入不同链表中。 上图说明了 task 与负载均衡和 runqueue 以及对应调度器之间的关系。每个 runqueue 里又会分为active和expired队列,每个队列中挂载着140个优先级不同的 task 。关于调度器在 runqueue 里的算法实现我们看下面一张图: 可以看出2.6 kernel 里有 140 种优先级,所以我们就用长度为 140 的 array 去记录优先级。每个优先级下面用一个 FIFO queue 管理这个优先级下的 process。 那么,我们怎么找到当前最高优先级下面的可执行的 process 呢?如果从 0 开始一直遍历下去,算法虽然不是 O(N),但是是跟优先级多少相关的 O(M),也不能算作 O(1)。在 2.6 scheduler 里,采用 bitarray。它为每种优先级分配一个 bit,如果这个优先级队列下面有 process,那么就对相应的 bit 染色,置为 1,否则置为 0。问题就简化成寻找一个 bitarray 里面最高位是 1 的 bit(left-most bit),这基本上是一条 CPU 指令的事(fls) 大致的思路齐备,我们来整理下步骤:
虚拟时间: 比如,调度周期是12ms,2个相同优先级的进程A和B,那么每个进程的运行时间各为6ms。倘若进程A,B的优先级nice分别为0和1,那么权重分别是1024和820。它们的关系如下: 权重 = 1024 / 1.25nice(次方) 那么进程A获取的运行时间是12x1024/(1024+820)=6.66ms,进程B获取的运行时间是12x820/(1024+820)=5.34ms。进程A的cpu使用比例是6.66/10=66.6%,进程B的cpu使用比例是5.34/10=53.4%。这里我们看到2个进程的执行时间分别是6.66ms和5.34ms,是不一样的。但是CFS是想让每个进程完全公平调度,这里就引入一个概念——虚拟时间,CFS也是通过虚拟时间相等来保证调度公平的。虚拟时间vriture_runtime和实际时间wall time转换公式如下: 虚拟时间 = 实际时间 * (1024/进程权重) = (调度周期 * 进程权重 / 所有进程总权重) * (1024 / 进程权重) = 调度周期 * 1024 / 所有进程总权重 可以看出虽然进程的权重不同,但是它们的 vruntime增长速度应该是一样的 ,与权重无关。(进程A的虚拟时间=6.66 *(1024/1024)= 6.66ms,进程B的虚拟时间=5.34 *(1024/820)= 6.66ms。这里我们看出虽然进程的优先级不同,但最终的虚拟时间一样。) 总结:谁的vruntime值较小就说明它当前占用cpu的时间较短,受到了“不公平”对待,因此下一个运行进程就是它。这样既能公平选择进程,又能保证高优先级进程获得较多的运行时间。这就是CFS的主要思想了。 就绪队列(runqueue): CFS维护了一个按照虚拟时间排序的红黑树: 任务存储在以时间为顺序的红黑树中(由 sched_entity 对象表示),对处理器需求最多的任务 (最低虚拟运行时)存储在树的左侧,处理器需求最少的任务(最高虚拟运行时)存储在树的右侧。为了公平,调度器然后选取红黑树最左端的节点调度为下一个以便保持公平性。任务通过将其运行时间添加到虚拟运行时, 说明其占用 CPU 的时间,然后如果可运行,再插回到树中。这样,树左侧的任务就被给予时间运行了,树的内容从右侧迁移到左侧以保持公平。因此,每个可运行的任务都会追赶其他任务以维持整个可运行任务集合的执行平衡。 |
|
|
|
只有小组成员才能发言,加入小组>>
810 浏览 0 评论
1161 浏览 1 评论
2535 浏览 5 评论
2871 浏览 9 评论
移植了freeRTOS到STMf103之后显示没有定义的原因?
2719 浏览 6 评论
keil5中manage run-time environment怎么是灰色,不可以操作吗?
1109浏览 3评论
198浏览 2评论
465浏览 2评论
379浏览 2评论
M0518 PWM的电压输出只有2V左右,没有3.3V是怎么回事?
460浏览 1评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-27 04:32 , Processed in 1.100070 second(s), Total 80, Slave 61 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号