内核调度器原理与分析

介绍

内核中针对task_struct进程描述符专门安排有序执行的模块叫调度器
调度器作用:
1 cpu中央处理器专门管理时间
2 通过进程优先级为依据专门分配时间

当在运行的过程中,某个进程的时间片到了或者缺少某个条件就会发生上下文切换,cpu重新切换一个进程。

调度类

1 调度类结构体sched_class:
内核中提供了一个专门用来调度的进程的类接口sched_class
在内核中,系统中有多个调度类,按调度优先级连接成链表。
kernel/sched/sched.h文件中

struct sched_class {
   
	// 系统当中有多个调度类,按照调度优先级排成一个链表;下一个优先级的调度类
	const struct sched_class *next;
	// 将进程task_struct加入到执行队列当中,将调度实体(进程)存放到红黑树中,
	// 并且对nr_running自动加1
	void (*enqueue_task) (struct rq *rq, struct task_struct *p, int flags);
	// 从执行队列当中删除进程,并且nr_running变量自动减1
	void (*dequeue_task) (struct rq *rq, struct task_struct *p, int flags);
	// 放弃cpu执行权,实际上该函数执行先出队后入队,在这种情况下,它直接将调度
	//实体放在红黑树的最右端
	void (*yield_task) (struct rq *rq);
	bool (*yield_to_task) (struct rq *rq, struct task_struct *p, bool preempt);
	// 用于检测当前进程是否可以被新的进程抢占
	void (*check_preempt_curr) (struct rq *rq, struct task_struct *p, int flags<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丰恒谷

你的鼓励是我最大创作动力!!!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值