LINUX进程调度分析源码,Linux 实时调度(源码分析)

为了弄清楚在多cpu系统中是如何实现实时调度的,先引入以下几个概念:

cpu的状态:

我们知道,在linux系统中,任务的优先级为0~140。

INVALID:(-1)该cpu不可用

IDLE(0):140

NORMAL(1):100~139对应于普通任务的优先级

RT0~RT99(2~102):对应于实时任务的优先级

进程优先级:

在linux内核中,每个进程都有一个task_struct,其中与优先级相关的属性包括

1、prio:对于非实时进程而言prio==normal_prio=99-rt_priority(prio的值越大,则进程的优先级越小)

2、normal_prio:99-rt_priority

3、static_prio:=100+nice

4、rt_priority:0:非实时任务;[1,99]实时任务,值越大,优先级越高。

在调度时使用了prio,其数值0对应最高优先级,99为最低实时优先级。Prio和normal_prio数值越大优先级越小,而rt_priority的数值越大优先级越大。

task balance:

在多cpu系统中,为了保证各个cpu上实时任务的负载均衡,引入了push和pull操作:

1、push操作:

当当前cpu上有多于一个的实时任务,那么需要使用pull操作看看是否可以将还未运行的实时任务移动到其他的cpu上,主要操作由push_rt_task函数完成。static int push_rt_task(struct rq *rq)

{

struct task_struct *next_task;

struct rq *lowest_rq;

int ret = 0;

///如果当前队列不是超载状态,则直接返回

if (!rq->rt.overloaded)

return 0;

///选择rq中下一个进程

next_task = pick_next_pushable_task(rq);

if (!next_task)

return 0;

retry:

......

///如果下一个进程的优先级比当前进程的优先级高,那么需要执行的不是push操作而是重新调度

if (unlikely(next_task->prio curr->prio)) {

resched_task(rq->curr);

return 0;

}

......

///寻找那个cpu的rq符合条件,将其rq上锁

lowest_rq = find_lock_lowest_rq(next_task, rq);

///如果没有找到合适的rq,我们则需要判断:到底还要不要再找,因为在find_lock_lowest_rq函数中释放了当前rq上的锁,因此可能会导致当前rq上没有需要push的任务,在这种情况下我们就不用再试,如果需要push的任务还在,那么则进入retry继续尝试。

if (!lowest_rq) {

struct task_struct *task;

task = pick_next_pushable_task(rq);

if (task_cpu(next_task) == rq->cpu && task == next_task) {

goto out;

}

if (!task)

goto out;

put_task_struct(next_task);

next_task = task;

goto retry;

}

///执行任务迁移相关的工作。

deactivate_task(rq, next_task, 0);

set_task_cpu(next_task, lowest_rq->cpu);

activate_task(lowest_rq, next_task, 0);

ret = 1;

resched_task(lowest_rq->curr);

double_unlock_balance(rq, lowest_rq);

out:

put_task_struct(next_task);

return ret;

}

2、pull操作

与push操作相反,pull操作用于当前cpu的rq比较空闲,想要主动调入实时任务,该操作主要由

pull_rt_task完成。static int pull_rt_task(struct rq *this_rq)

{

int this_cpu = this_rq->cpu, ret = 0, cpu;

struct task_struct *p;

struct rq *src_rq;

if (likely(!rt_overloaded(this_rq)))

return 0;

///查找每一个超载的cpu

for_each_cpu(cpu, this_rq->rd->rto_mask) {

......

///src_rq:需要pull的cpu。

src_rq = cpu_rq(cpu);

///如果src_rq的下一个任务的优先级高于当前cpu的优先级,则什么都不用做,因为src_cpu会主动执行pull操作。

if (src_rq->rt.highest_prio.next >=

this_rq->rt.highest_prio.curr)

continue;

double_lock_balance(this_rq, src_rq);

///判断是否有需要被pull的任务,没有则退出

if (src_rq->rt.rt_nr_running <= 1)

goto skip;

///找到src_rq上最高优先级的任务

p = pick_next_highest_task_rt(src_rq, this_cpu);

if (p && (p->prio rt.highest_prio.curr)) {

WARN_ON(p == src_rq->curr);

WARN_ON(!p->on_rq);

if (p->prio curr->prio)

goto skip;

ret = 1;

deactivate_task(src_rq, p, 0);

set_task_cpu(p, this_cpu);

activate_task(this_rq, p, 0);

}

skip:

double_unlock_balance(this_rq, src_rq);

}

return ret;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/530249.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux源码文件名,Linux中文件名解析处理源码分析

Linux中文件名解析处理源码分析前言Linux中对一个文件进行操作的时候&#xff0c;一件很重要的事情是对文件名进行解析处理&#xff0c;并且找到对应文件的inode对象&#xff0c;然后创建表示文件的file对象。在此&#xff0c;对文件名解析过程&#xff0c;并且如何找到对应ino…

帝国cms linux伪静态规则,帝国cms7.2伪静态规则怎么写

一、在linux主机下实现伪静态确认虚拟主机是否支持rewrite伪静态.htaccess文件。添加.htaccess 文件&#xff0c;把htaccess 文件放在网站根目录。二、在win主机下实现伪静态确认虚拟主机是否支持rewrite伪静态httpd.ini文件。添加httpd.ini文件&#xff0c;把httpd.ini文件放入…

linux core 永久生效,【调试】Core Dump是什么?Linux下如何正确永久开启?

内容简介【调试】Core Dump是什么&#xff1f;Linux下如何正确永久开启&#xff1f;Core Dump是什么&#xff1f;Linux下如何正确永久开启&#xff1f;Core Dump是什么&#xff1f;Core Dump乍听之下很抽象。当程序运行的过程中异常终止或崩溃&#xff0c;操作系统会将程序当时…

linux故障排查书籍,Linux系统故障排查和修复技巧.docx

fsck -y /cievZhdab(fsck为文件系统检测修复命令&#xff0c;“-y”设定检测到错误自动修复&#xff0c;Zdev/hda6 为发生错误的硬盘分区&#xff0c;请依据具体情况更改此参数) 系统修复完成后&#xff0c;用命令“reboot&#xff0c;重新启动即可? 案例三、GRUB选项设置错误…

用于用户C语言标识符,下列可用于C语言用户标识符的一组是( )

摘要&#xff1a;下列不属于骨肉瘤患者常见护理问题()于C语言用户组Since people send nonverbal signals through multiple channels simultaneously, it is impossible to increase our nonverbal communication competence by becoming more aware of how it operates in sp…

c语言编程常见问题解答,C语言编程常见问题解答之常用函数的包含文件

函数 包含 类别 功能_atold math.h 数学子程序 把字符串转换为浮点数_beginthread process.h 进程控制子程序 启动执行一个新线程_bios_disk bios.h 接口子程序 输出BIOS磁…

c语言猜四位数游戏猜10次,C语言猜数字游戏--随机生成4个不相同的数字从小到大排序,用户开始游戏,如果用户猜对数字和数字对应的位置,界面回馈A,如果数字正确位置不正确,则回馈B...

1.看程序运行截图吧&#xff01;&#xff01;由于博主本人较笨&#xff0c;就不动画演示了&#xff0c;如果动画的话可能将是一个漫长的过程&#xff01;猜数字游戏.png2.游戏题目随机生成4个不相同的数字从小到大排序&#xff0c;用户开始游戏&#xff0c;如果用户猜对数字和数…

双端堆c语言,数据结构——双端堆(C语言)

定义双端堆&#xff1a;是一棵完全二叉树&#xff0c;该完全二叉树要么为空&#xff0c;要么同时满足下列性质&#xff1a;(1) 根节点不包含元素&#xff1b;(2) 左子树是一个最小堆&#xff1b;(3) 右子树是一个最大堆&#xff1b;(4) 如果右子树不空&#xff0c;令i是左子树中…

C语言和我的世界指令哪个难,我的世界难度有什么区别 难度选择指令介绍

我的世界中的难度(Difficulty)可以在Minecraft的选项菜单内切换。更改这个选项将直接影响到游戏本身。选项中并没有设定影响攻击性生物的可生成数量&#xff0c;包括和平模式。目前游戏共有和平、简单、普通和困难4种难度。我的世界难度区别和平&#xff1a;会生成攻击性生物&a…

w ndows10即将停止更新,微软开始警告Windows 10 v1909用户即将停止更新服务

如果您仍在运行Windows 10版本1909&#xff0c;版本1903或更早版本&#xff0c;则可能已经在系统任务栏中注意到一条新消息&#xff1a;Windows 10版本即将终止服务。根据Windows 10 May 2020 Update或2020年10月Update。为了将用户升级到最新版本的Windows 10&#xff0c;“您…

筛法求素数c 语言,位筛法求素数,有段代码看不懂,有大佬可以来说一下

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼就是BITArray[ (i -3)/ CHAR_BIT ]其中i从0开始&#xff0c;那下标不就为负了&#xff1f;而指向的又是哪个数据&#xff1f;下面是完整代码。#include #include #include #include #include #include#include int main( ){unsigne…

c语言中日期间的天数怎么计算,关于计算两个日期间天数的代码,大家来看看...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼这是原贴:http://post.baidu.com/f?kz100411727这是原码:#include "stdio.h"main(){long int i,a[2],b[2],c[2],x[12]{0,31,59,90,120,151,181,212,243,273,304,334},y,z[2];scanf("%ld-%ld-%ld %ld-%ld-%ld"…

linux nf conntrack,Linux基于mark的策略路由以及nf_conntrack RELATED

谈到什么是意义&#xff0c;话题总显得很大&#xff0c;近日每晚都和老城里的朋友聊老城的文化&#xff0c;老城的老房子&#xff0c;老城的叫卖声&#xff0c;老城的方言…进行了很多的思考&#xff0c;也挺充实。至于技术方面&#xff0c;也有跟朋友以及前同事聊过&#xff0…

android 根据资源名称,如何在Android中按名称访问可绘制资源

你可以做这样的事情。public static Drawable getDrawable(String name) {Context context YourApplication.getContext();int resourceId context.getResources().getIdentifier(name, "drawable", YourApplication.getContext().getPackageName());return contex…

Android10不能用谷歌,谷歌真的很严格,一大波老APP将不能在安卓10.0运行

苹果iOS的一大优点就是软件生态&#xff0c;第三方APP都会主动适配新的iOS系统以及手机。虽然说Android的开放性是也是一大优点&#xff0c;但是第三方软件参差不齐的优化适配水平也让安卓的用户非常头疼。不过谷歌每年都在致力于让Android的软件生态更好。根据XDA的报道&#…

android 回归测试,android测试:monkey使用方法

android测试&#xff1a;monkey使用方法Android Sdk给我们提供了Monkey和Monkeyrunner这两个自动化测试工具。一、什么是MonkeyMonkey是一个命令行工具&#xff0c;可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流&#xff0c;实现对正在开发的应用程序进行压…

c语言编程季节输出春夏秋冬,c语言编程题: 用枚类型定义春、夏、秋、冬四个季节...

满意答案bcabcdefg2013.07.28采纳率&#xff1a;49% 等级&#xff1a;12已帮助&#xff1a;5373人#includeenum season{spring 1,summer,autumn,winter,};season GetSeasonByMonth(char month){if(month < 3 && month>1)return spring;else if(month < 6 …

android fragment addtobackstack,Android Fragment Back Stack的问题

我对android片段Backstack的工作方式遇到了一个很大的问题&#xff0c;对于提供的任何帮助将不胜感激。假设您有3个片段[1] [2] [3]我希望用户能够导航[1] > [2] > [3]但在返回的途中(按返回按钮)[3] > [1]。就像我想象的那样&#xff0c;这可以通过addToBackStack(..…

华为升级harmonyos的机型名单,华为鸿蒙 OS 2.0 系统适配名单已出,四月推送,天玑机型暂时无缘...

原标题&#xff1a;华为鸿蒙 OS 2.0 系统适配名单已出&#xff0c;四月推送&#xff0c;天玑机型暂时无缘华为官方在 2020 年发布了旗下自研系统“HarmonyOS 2.0”版本&#xff0c;发布会现场展示了 HarmonyOS 2.0 开发者 Beta 版本&#xff0c;并开启开发者 Beta 的公测。此外…

android如何实现QQ信息通知,android NotificationListenerService监听通知栏(qq 微信 短信)...

【实例简介】android NotificationListenerService 监听通知栏&#xff0c;android NotificationListenerService 监听通知栏 android NotificationListenerService 监听通知栏【实例截图】【核心代码】NLsevice└── NLsevice├── AndroidManifest.xml├── bin│ ├──…