每日阅读4之linux内核设计与实现——linux调度实现之调度器入口

Linux调度的入口函数schedule()定义于kernel/sched.c,它作为进程调度器的接口,根据不同的调度类选择优先级最高的进程执行。当只有一个调度器类时,会直接调用fair_sched_class的pick_next_task()函数。否则,将遍历所有调度类,从最高优先级类开始选取任务。

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

linux调度的入口函数时schedule(),定义在文件kernel/sched.c

是内核其它部分用于调用进程调度器的入口:选择哪个进程可以运行,何时将其投入运行

通常需要和一个具体的调度类相关联,一般是优先级最高的,每个调度类都有一个自己的可运行队列

这个函数唯一的作用就是调用pick_next_task,依次检查每个调度器类,并且从最高优先级的调度器类中选择最高优先级的进程运行。。

/*
 * Pick up the highest-prio task:
 */
static inline struct task_struct *
pick_next_task(struct rq *rq)
{
const struct sched_class *class;
struct task_struct *p;


/*
* Optimization: we know that if all tasks are in
* the fair class we can call that function directly:
*/
if (likely(rq->nr_running == rq->cfs.nr_running)) { //这里做了个优化,如果只有一个调度器类( 每一个调度器类都实现了自己的pick_next_task函数,普通进程的调度器类为CFS),
p = fair_sched_class.pick_next_task(rq);
if (likely(p))
return p;
}


class = sched_class_highest;
for ( ; ; ) {
p = class->pick_next_task(rq); //从最高优先级的调度类开始,选择每个最高优先级调度器类中的那个进程
if (p)
return p;
/*
* Will never be NULL as the idle class always
* returns a non-NULL p:
*/
class = class->next;
}
}


OVER!!!

下一章是睡眠与唤醒


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值