CN101609417A - 基于VxWorks操作系统的混合任务集调度方法 - Google Patents
基于VxWorks操作系统的混合任务集调度方法 Download PDFInfo
- Publication number
- CN101609417A CN101609417A CNA2009100233617A CN200910023361A CN101609417A CN 101609417 A CN101609417 A CN 101609417A CN A2009100233617 A CNA2009100233617 A CN A2009100233617A CN 200910023361 A CN200910023361 A CN 200910023361A CN 101609417 A CN101609417 A CN 101609417A
- Authority
- CN
- China
- Prior art keywords
- task
- aperiodic
- time
- priority
- scheduling
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Landscapes
- Debugging And Monitoring (AREA)
Abstract
本发明公开了一种基于VxWorks操作系统的混合任务集调度方法,主要克服了许多混合调度方法中非周期任务实时性差,CPU利用率低的问题。其步骤为:创建混合任务集并创建一个特殊周期任务,为该特殊周期任务创建一个信号量;进行任务调度前用改进后的时间需求算法判断混合任务集的可调度性;周期任务根据VxWorks所提供的基于优先级的抢占式调度算法进行调度;在特殊周期任务的运行过程中依次判断非周期任务的运行条件,若满足某非周期任务的运行条件则释放相应信号量使该非周期任务运行,该非周期任务运行完毕后释放信号量使特殊周期任务运行。本发明提高了CPU的利用率,减小了调度非周期任务时的响应时间,可用于对非周期任务较多的混合任务集的调度。
Description
技术领域
本发明属于计算机领域,涉及实时操作系统的任务调度方法,具体涉及了一种基于VxWorks的混合任务集调度方法。
背景技术
VxWorks是美国WindRiver公司开发的具有工业领导地位的高性能实时操作系统,同时也是现今所有独立于处理器的实时系统中最具特色的操作系统之一。
两种经典的调度方法为Liu C L和Layland J在1973年提出的Rate-Monotonic-RM算法和Earliest Deadline First-EDF算法,参照C L Liu,J W Layland.Scheduling Algorithms for Multiprogramming in a Hard Real-TimeEnvironment[J].Journal of the Association for ComputingMachinery,1973,20(1):116~128。RM算法对CPU的利用率不高,且只适用于周期任务集。EDF算法运行开销大,且对任务具有同一优先级的情况考虑不足。所以在这两种算法的基础上,又衍生出一些针对不同系统的不同解决方案。其中对于包含周期和非周期任务的混合任务集的调度主要有三种方法:空闲时间法、后台执行法和轮询法。空闲时间法由Robert Davis在1994年提出,参照RobertDavis.Dual Priority Seheduling:Ameans of Providing Flexibility in Hard Real TimeSystems.DePartment of ComPuter Seienee,University ofYork,Tech ReP:YCS-230,1994:101-122,该算法从周期任务调度的空隙获得时间处理非周期任务,它不能保证非周期任务的实时性要求。后台执行法由J P Lehoczky等人在1987年提出,参照J P Lehoczky,L Sha,J K Stronsnider.Enganced Aperiodic Responsiveness inHard Real Time Environments[C].In:Proc of the 8th IEEE Real Time SystemSymposium.San Jose,California:IEEE Compter Society Press,1987:210~217,该算法对非周期任务的处理时间较少导致其调度性能很差。由T P Baker等人在2005年提出的轮询法,参照T M Ghazalie,T P Baker.A periodic Servers in a DeadlineScheduling Environment[J].Journal ofReal Time Systems,2005,9(1):31-67,该算法周期性的为非周期任务提供时间片,大大优于后台执行法,但是该方法的最大缺点是:如果在为非周期任务提供的时间片内没有非周期任务执行时,则该时间片将被浪费,降低了CPU的利用率。
发明内容
本发明的目的在于克服上述已有调度方法实时性低,运算量大,CPU利用率低的问题,提供一种基于VxWorks操作系统的混合任务集调度方法,以提高CPU利用率,减小调度非周期任务时的响应时间,提高系统实时性。
为了达到上述目的,本发明采用的技术方案包括如下步骤:
(1)在操作系统vxworks的编程环境下调用库函数taskSpawn()创建混合任务集中各任务,并设定各任务的优先级,该混合任务集包含若干周期任务、若干非周期任务和一个特殊周期任务,同时为特殊周期任务创建信号量semIdT,信号量semIdT初始值为满;
(2)对创建的混合任务集进行如下可调度性判断:
2a)求出所有非周期任务的最大执行时间和到来的最小周期;
2b)根据最大执行时间和到来的最小周期,计算各任务的最大响应时间:
其中,i表示混合任务集中的一个任务,k表示混合任务集中周期任务的个数,ti n+1和ti n分别表示迭代到第n+1和第n次时的最大响应时间,Hi表示在时间ti内优先级高于τi并且已就绪的周期任务集,τk为Hi中的任务,Tk和Ck分别是τk的周期和最大执行时间,ψi表示在时间ti内已就绪的非周期任务集,j表示混合任务集中非周期任务的个数,τj为ψi中的任务,Rj′和Cj′分别是τj的最小周期和最大执行时间。
2c)比较各任务的最大响应时间和任务时限:
timax≤Ti(1≤i≤n)
其中,timax表示任务τi的最大响应时间,Ti表示任务τi的时限,若系统中所有任务实例的最大响应时间均小于各自的时限,则系统可调度,否则不可调度;
2d)若任务集不可调度,调整特殊周期任务的周期,跳回步骤2b);若任务集可调度,在保证可调度性的条件下,根据系统的实时性要求调节特殊周期任务的周期;
(3)对混合任务集中的周期任务进行如下调度:
3a)各个周期任务在每一次运行前调用操作系统中vxworks的库函数taskDelay(T)延迟一段时间,T表示任务被延迟的Tick数;
3b)根据操作系统VxWorks所提供的基于优先级的抢占式调度算法调度所有周期任务;
(4)对混合任务集中的非周期任务进行如下调度:
4a)分别为各个非周期任务创建信号量,初始值为空;
4b)执行特殊周期任务,首先判断是否满足第一个非周期任务设定的运行条件,若满足,则释放第一个非周期任务所对应的信号量使该非周期任务运行,第一个非周期任务运行完毕后将再次阻塞,特殊周期任务将继续往下运行;若不满足,则继续判断下一个非周期任务的运行条件,依次类推,直至判断完所有的条件,然后跳回步骤3a)。
本发明与现有技术相比具有如下优点:
(1)本发明由于在任务调度前先判断了混合任务集的可调度性,从而克服了许多混合调度方法中非周期任务调度性能低的问题,提高CPU的利用率。
(2)本发明由于在混合任务集中创建了一个特殊的周期任务来调度非周期任务,从而减小了调度非周期任务时的响应时间,提高系统的实时性。
附图说明
图1是本发明的实现框图;
图2是本发明中对混合任务集进行可调度性判断的流程图;
图3是本发明中周期任务的调度流程图;
图4是本发明中结合信号量机制的非周期任务调度流程图。
具体实施方式
下面结合附图和程序伪码对本发明的具体实施方式进行详细说明。
在具体实施方式中,使用到的特殊周期任务的伪码为:
void Specialtask
{
while(1)
{
taskDelay(periodT);
if(......)
{
semGive(semId[1]);
}
else semGive(semIdT);
semTake(semIdT,WAIT_FOREVER);
if(......)
{
semGive(semId[2]);
}
else semGive(semIdT);
semTake(semIdT,WAIT_FOREVER);
......;/*other cases*/
}
}
参见图1,本发明的实现步骤如下:
步骤1,创建任务。
1a)在操作系统vxworks的编程环境下调用库函数taskSpawn()创建混合任务集中各任务,并设定各任务的优先级,该混合任务集包含若干周期任务、若干非周期任务和一个特殊周期任务,函数taskSpawn()的具体调用方式如下:taskSpawn(″task1″,Priority,0,STACK_SIZE,(FUNCPTR)Task1,0,0,0,0,0,0,0,0,0,0)
其中,task1为任务名,Priority为该任务的优先级,STACK_SIZE为任务分配的堆栈大小,Task1为任务函数的入口地址。
对所有任务设置优先级时包括对周期任务和非周期任务优先级的设定,周期任务根据RM算法确定其优先级,即周期越短,优先级越高;非周期任务的优先级高于混合任务集中其它所有任务的优先级,且每一个非周期任务的优先级都相同;
1b)创建特殊周期任务的信号量,特殊周期任务的信号量置为满。
步骤2,对混合任务集进行可调度性检测。
本步骤的具体实现,参照图2如下:
2a)记录各个非周期任务的开始执行的时间和执行完成的时间,求出所有非周期任务的最大执行时间和到来的最小周期;
2b)根据最大执行时间和到来的最小周期,利用改进后的时间需求法计算各任务的最大响应时间,该时间需求法是用于确定周期任务集可调度性的方法,其基本思想是计算各周期任务实例的最大响应时间,并与任务时限相比较,若系统中所有任务实例的最大响应时间均小于各自的时限,则系统可调度,根据下式计算最大响应时间:
其中,ti n+1和ti n分别表示迭代到第n+1和第n次时的最大响应时间,Hi表示在时间ti内优先级高于τi并且已就绪的周期任务集,τk为Hi中的任务,Tk和Ck分别是τk的周期和最大执行时间,为使此方法用于本发明中混合任务集的可调度性判断,对计算最大响应时间的方法进行改进:
其中,ψi表示在时间ti内已就绪的非周期任务集,j表示混合任务集中非周期任务的个数,τj为ψi中的任务,Tj′和Cj′分别是τj的最小周期和最大执行时间;
2c)将步骤2b)中求出的各个任务的最大响应时间与其任务时限相比较,若所有任务的最大响应时间均小于其任务时限,则系统可调度,否则系统不可调度;
2d)若系统不可调度,适当延长特殊周期任务的周期,再跳到步骤2b)进行判断,循环进行,直到使得特殊周期任务找到一个合适的周期使系统可调度;若系统可调度,在保证系统可调度的条件下,根据实时性要求调整特殊周期任务的周期。
步骤3,对周期任务进行调度。
本步骤的具体实现,参照图3如下:
3a)遍历已经准备就绪的周期任务队列,执行其中优先级最高的周期任务;
3b)调用操作系统vxworks中的库函数taskDelay(T),使得步骤3a)中开始执行的周期任务延时T个ticks,判断是否延时完毕,若延时完毕,则继续往下执行该周期任务;若延时没有完毕,则跳回步骤3a);
步骤4,对非周期任务进行调度。
本步骤的具体实现,参照图4如下:
4a)分别为各个非周期任务创建信号量,初始值为空;
4b)执行特殊周期任务,判断是否满足第一个非周期任务设定的运行条件,若满足,则特殊周期任务释放与第一个非周期任务对应的信号量,使其由空变为满,第一个非周期任务获得信号量后开始运行,因其优先级最高,所以不会被任何任务抢占;若不满足,则释放信号量特殊任务对应的信号量semIdT使其由空变为满,即信号量semIdT由不可用变为可用,特殊周期任务获得信号量semIdT,同时semIdT由满变为空,特殊周期任务由断点处继续往下运行;
4c)继续按照步骤4b)的方法继续判断下一个非周期任务,直到判断完第N个周期任务,然后按照步骤3调用周期任务。
Claims (3)
1.一种基于VxWorks操作系统的混合任务集调度方法,包括以下步骤:
(1)在操作系统vxworks的编程环境下调用库函数taskSpawn( )创建混合任务集中各任务,并设定各任务的优先级,该混合任务集包含若干周期任务、若干非周期任务和一个特殊周期任务,同时为特殊周期任务创建信号量semIdT,信号量semIdT初始值为满;
(2)对创建的混合任务集进行如下可调度性判断:
2a)求出所有非周期任务的最大执行时间和到来的最小周期;
2b)根据最大执行时间和到来的最小周期,计算各任务的最大响应时间:
其中,i表示混合任务集中的一个任务,k表示混合任务集中周期任务的个数,ti n+1和ti n分别表示迭代到第n+1和第n次时的最大响应时间,Hi表示在时间ti内优先级高于τi并且已就绪的周期任务集,τk为Hi中的任务,Tk和Ck分别是τk的周期和最大执行时间,Ψi表示在时间ti内已就绪的非周期任务集,j表示混合任务集中非周期任务的个数,τj为Ψi中的任务,T′j和C′j分别是τj的最小周期和最大执行时间。
2c)比较各任务的最大响应时间和任务时限:
timax≤Ti(1≤i≤n)
其中,timax表示任务τi的最大响应时间,Ti表示任务τi的时限,若系统中所有任务实例的最大响应时间timax均小于各自的时限Ti,则系统可调度,否则不可调度;
2d)若任务集不可调度,适当延长特殊周期任务的周期,跳回步骤2b);若任务集可调度,在保证可调度性的条件下,根据系统的实时性要求调节特殊周期任务的周期;
(3)对混合任务集中的周期任务进行如下调度:
3a)各个周期任务在每一次运行前调用操作系统中vxworks的库函数taskDelay(T)延迟一段时间,T表示任务被延迟的Tick数;
3b)根据操作系统VxWorks所提供的基于优先级的抢占式调度算法调度所有周期任务;
(4)对混合任务集中的非周期任务进行如下调度:
4a)分别为各个非周期任务创建信号量,初始值为空;
4b)执行特殊周期任务,首先判断是否满足第一个非周期任务设定的运行条件,若满足,则释放第一个非周期任务所对应的信号量使该非周期任务运行,第一个非周期任务运行完毕后将再次阻塞,特殊周期任务将继续往下运行;若不满足,则继续判断下一个非周期任务的运行条件,依次类推,直至判断完所有的运行条件,然后跳回步骤3。
2.如权利要求1所述的基于VxWorks的混合任务集调度方法,其中步骤(1)中所述的设定各任务的优先级,包括对周期任务和非周期任务优先级的设定,周期任务的优先级是根据Rate-monotonic-RM算法,即周期越短,优先级越高;非周期任务的优先级高于周期任务的优先级,且每一个非周期任务的优先级都相同。
3.如权利要求1所述的基于VxWorks的混合任务集调度方法,其中步骤4b)中所述的当非周期任务运行完毕后,特殊周期任务将继续往下运行,是指从上次运行的断点处继续往下运行。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN2009100233617A CN101609417B (zh) | 2009-07-17 | 2009-07-17 | 基于VxWorks操作系统的混合任务集调度方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN2009100233617A CN101609417B (zh) | 2009-07-17 | 2009-07-17 | 基于VxWorks操作系统的混合任务集调度方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN101609417A true CN101609417A (zh) | 2009-12-23 |
CN101609417B CN101609417B (zh) | 2012-07-04 |
Family
ID=41483178
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN2009100233617A Expired - Fee Related CN101609417B (zh) | 2009-07-17 | 2009-07-17 | 基于VxWorks操作系统的混合任务集调度方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN101609417B (zh) |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101833477A (zh) * | 2010-05-28 | 2010-09-15 | 浙江大学 | 基于SmartOSEK OS的非周期性任务调度方法 |
CN101872317A (zh) * | 2010-07-16 | 2010-10-27 | 山东中创软件工程股份有限公司 | VxWorks多任务同步与通信方法 |
CN102654843A (zh) * | 2011-03-04 | 2012-09-05 | 北京国科环宇空间技术有限公司 | 嵌入式处理器中非抢占式容错调度方法及嵌入式处理器 |
CN102662744A (zh) * | 2012-04-19 | 2012-09-12 | 上海大学 | 一种基于条件抢占的fpga任务调度方法 |
CN102760187A (zh) * | 2012-06-19 | 2012-10-31 | 上海大学 | 综合时间因素和空间因素的fpga任务放置方法 |
CN106445659A (zh) * | 2016-09-09 | 2017-02-22 | 北京控制工程研究所 | 一种空间飞行器周期性混成随机任务调度方法 |
CN106547721A (zh) * | 2015-09-16 | 2017-03-29 | 晨星半导体股份有限公司 | 例行工作的分配方法及应用其的多核心计算机 |
CN108304257A (zh) * | 2018-02-09 | 2018-07-20 | 中国船舶重工集团公司第七六研究所 | 基于延迟服务器的强实时混合任务调度方法 |
CN113986500A (zh) * | 2021-10-28 | 2022-01-28 | 浙江中控技术股份有限公司 | 多任务系统中的任务确定性调度方法和任务诊断方法 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN100351792C (zh) * | 2004-08-23 | 2007-11-28 | 中兴通讯股份有限公司 | 一种实时任务管理与调度方法 |
US8136111B2 (en) * | 2006-06-27 | 2012-03-13 | International Business Machines Corporation | Managing execution of mixed workloads in a simultaneous multi-threaded (SMT) enabled system |
-
2009
- 2009-07-17 CN CN2009100233617A patent/CN101609417B/zh not_active Expired - Fee Related
Cited By (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101833477A (zh) * | 2010-05-28 | 2010-09-15 | 浙江大学 | 基于SmartOSEK OS的非周期性任务调度方法 |
CN101833477B (zh) * | 2010-05-28 | 2013-06-12 | 浙江大学 | 基于SmartOSEK OS的非周期性任务调度方法 |
CN101872317B (zh) * | 2010-07-16 | 2012-12-26 | 山东中创软件工程股份有限公司 | VxWorks多任务同步与通信方法 |
CN101872317A (zh) * | 2010-07-16 | 2010-10-27 | 山东中创软件工程股份有限公司 | VxWorks多任务同步与通信方法 |
CN102654843A (zh) * | 2011-03-04 | 2012-09-05 | 北京国科环宇空间技术有限公司 | 嵌入式处理器中非抢占式容错调度方法及嵌入式处理器 |
CN102662744A (zh) * | 2012-04-19 | 2012-09-12 | 上海大学 | 一种基于条件抢占的fpga任务调度方法 |
CN102662744B (zh) * | 2012-04-19 | 2014-06-11 | 上海大学 | 一种基于条件抢占的fpga任务调度方法 |
CN102760187A (zh) * | 2012-06-19 | 2012-10-31 | 上海大学 | 综合时间因素和空间因素的fpga任务放置方法 |
CN102760187B (zh) * | 2012-06-19 | 2015-05-27 | 上海大学 | 综合时间因素和空间因素的fpga任务放置方法 |
CN106547721A (zh) * | 2015-09-16 | 2017-03-29 | 晨星半导体股份有限公司 | 例行工作的分配方法及应用其的多核心计算机 |
CN106445659A (zh) * | 2016-09-09 | 2017-02-22 | 北京控制工程研究所 | 一种空间飞行器周期性混成随机任务调度方法 |
CN106445659B (zh) * | 2016-09-09 | 2019-07-12 | 北京控制工程研究所 | 一种空间飞行器周期性混成随机任务调度方法 |
CN108304257A (zh) * | 2018-02-09 | 2018-07-20 | 中国船舶重工集团公司第七六研究所 | 基于延迟服务器的强实时混合任务调度方法 |
CN113986500A (zh) * | 2021-10-28 | 2022-01-28 | 浙江中控技术股份有限公司 | 多任务系统中的任务确定性调度方法和任务诊断方法 |
Also Published As
Publication number | Publication date |
---|---|
CN101609417B (zh) | 2012-07-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN101609417A (zh) | 基于VxWorks操作系统的混合任务集调度方法 | |
CN110287003B (zh) | 资源的管理方法和管理系统 | |
CN102063336B (zh) | 一种分布式计算多应用功能异步并发调度方法 | |
CN106919449B (zh) | 一种计算任务的调度控制方法及电子设备 | |
CN108346010B (zh) | 基于用户需求分析的共享汽车调度方法 | |
US8112644B2 (en) | Dynamic voltage scaling scheduling mechanism for sporadic, hard real-time tasks with resource sharing | |
CN111506430B (zh) | 多任务下数据处理的方法、装置及电子设备 | |
CN101499019B (zh) | 电信级以太网系统及用于该系统的实时任务调度方法 | |
CN103491174A (zh) | 基于延迟服务器的周期/非周期混合实时任务调度方法 | |
CN101339521A (zh) | 一种任务优先级动态调度算法 | |
CN1471376A (zh) | 用于确定周期任务的最好情况响应时间的方法和系统 | |
CN107818012B (zh) | 一种数据处理方法、装置及电子设备 | |
CN109324880A (zh) | 一种适用于实时系统周期任务模型的低功耗调度方法 | |
CN114866563A (zh) | 扩容方法、装置、系统和存储介质 | |
CN110928666B (zh) | 一种Spark环境中基于内存优化任务并行度的方法和系统 | |
CN108563494A (zh) | 一种自适应动态调整的线程调度系统及方法 | |
CN110221914B (zh) | 文件处理方法及装置 | |
CN107797870A (zh) | 一种云计算数据资源调度方法 | |
CN101349975B (zh) | 一种在嵌入式操作系统上实现中断底半部机制的方法及装置 | |
CN108304257A (zh) | 基于延迟服务器的强实时混合任务调度方法 | |
CN108874517B (zh) | 固定优先级待机备用系统利用率划分能耗优化方法 | |
CN105117281A (zh) | 一种基于任务申请信号和处理器内核执行代价值的任务调度方法 | |
CN109426556B (zh) | 一种进程调度方法和装置 | |
CN114138453B (zh) | 一种适合边缘计算环境的资源优化分配方法与系统 | |
CN110032455A (zh) | 通过运行时间合作进行高效通信重叠 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20120704 Termination date: 20210717 |
|
CF01 | Termination of patent right due to non-payment of annual fee |