首页
|
新闻
|
新品
|
文库
|
方案
|
视频
|
下载
|
商城
|
开发板
|
数据中心
|
座谈新版
|
培训
|
工具
|
博客
|
论坛
|
百科
|
GEC
|
活动
|
主题月
|
电子展
注册
登录
论坛
博客
搜索
帮助
导航
默认风格
uchome
discuz6
GreenM
»
FPGA/CPLD可编程逻辑
» 嵌入式Linux系统实时进程调度算法改进之二
返回列表
回复
发帖
发新话题
发布投票
发布悬赏
发布辩论
发布活动
发布视频
发布商品
嵌入式Linux系统实时进程调度算法改进之二
发短消息
加为好友
pengpengpang
(pengpengpang)
当前离线
UID
1023229
帖子
6106
精华
0
积分
3055
阅读权限
90
来自
中国
在线时间
156 小时
注册时间
2013-12-20
最后登录
2016-7-3
论坛元老
UID
1023229
来自
中国
1
#
打印
字体大小:
t
T
pengpengpang
发表于 2015-9-19 11:00
|
只看该作者
嵌入式Linux系统实时进程调度算法改进之二
微软雅黑
,
嵌入式
,
Linux
3.3 链表定义
整个调度算法可以用双链表来描述,即两级队列,分别用两个指针指向。最初,这两部分的头指针都指向“0”,表明这两个队列均为空。其中实时进程的就绪等待队列用一个循环单链表完成。
开始时的一级队列,是新到的比当前运行进程优先级低的实时进程。如果一个进程由于时间片到时或被更高优先级任务抢占,根据它的优先级将其插入到第二级队列。
若当前进程的时间片到时,CPU便选择当前队列中第二个节点的进程来判断,如果它的紧迫度大于1的话,说明这个进程在规定时间内不能完成,它必定夭折,将其放入普通进程队列中,再选择链表的第三个节点判断,如果紧迫度小于等于1便运行它,情况如图1所示。
图1 优化后调度算法的实时进程优先级表
当一级队列为空时,二级队列便升成一级队列。
普通进程的调度通过单链表来实现。如果新来的进程属于普通进程,则根据优先级高低插入普通队列。只有实时队列(一级和二级队列)为空时,普通队列才能被调度。
3.4 实时进程的调度策略算法描述
1)实时就绪队列的初始化
2) 实时进程接收策略
#define K 10
void* pnow;
pnew指向新来的实时进程,pnow指向当前运行的实时进程。
3)实时进程插入策略
说明:根据传来的h值,决定在一级队列h的值是Headl时还是在二级队列h的值是Head2时中查找插入的合适位置。
当P是新来的任务时,h的值是Head1,p被括入一级队列。p2是p1的后继节点。在循环体中,当新来的进程P高于一级队列的进程p2时,停止循环,将P插入到p1的后面;当p1等于Head2时,说明一级队列的节点的优先级都比P节点的高,停止循环,把P插在p1的后面,则该节点便成了一级队列的末尾。
当P是被抢占的任务时,h的值是Head2,p被插入二级队列。在循环体中,当P的优先级高于二级队列的进程p2时,停止循环,将P插入到p1的后面;如果P高于二级队列的所有进程时,也会在p2指向Head时,因(*p).w<=(*p2) .w而停止,则该节点便成了二级队列的末尾。因为((head1).w=-1,而任何进程的优先级数都不会小于1因此当p1,p2在这二级队列中遍历时,一定能有机会停止。
4) 调度等待链表中的一级队列
当前进程完成或时间片到时,调度等待链表中的一级队列中最前面的实时进程:
5)实时进程删除策略
针对目前Linux实时系统调度算法中仅用进程的价值来确定优先级的现象,本文提出了综合考虑进程的重要性和紧迫度来决定优先级的调度算法。算法将进程的截止期和价值两个不相关的概念,通过公式结合在一起,用来计算就绪等待队列中进程的优先级数。
该算法通过双链表来实现。在CPU正常负载的情况下,优化后的调度算法体现了更优的实时性能。
收藏
分享
评分
记录学习中的点点滴滴,让每一天过的更加有意义!
回复
引用
订阅
TOP
返回列表
电商论坛
Pine A64
资料下载
方案分享
FAQ
行业应用
消费电子
便携式设备
医疗电子
汽车电子
工业控制
热门技术
智能可穿戴
3D打印
智能家居
综合设计
示波器技术
存储器
电子制造
计算机和外设
软件开发
分立器件
传感器技术
无源元件
资料共享
PCB综合技术
综合技术交流
EDA
MCU 单片机技术
ST MCU
Freescale MCU
NXP MCU
新唐 MCU
MIPS
X86
ARM
PowerPC
DSP技术
嵌入式技术
FPGA/CPLD可编程逻辑
模拟电路
数字电路
富士通半导体FRAM 铁电存储器“免费样片”使用心得
电源与功率管理
LED技术
测试测量
通信技术
3G
无线技术
微波在线
综合交流区
职场驿站
活动专区
在线座谈交流区
紧缺人才培训课程交流区
意见和建议