嵌入式Linux操作系统实时性的研究_第1页
嵌入式Linux操作系统实时性的研究_第2页
嵌入式Linux操作系统实时性的研究_第3页
嵌入式Linux操作系统实时性的研究_第4页
嵌入式Linux操作系统实时性的研究_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、嵌入式Linux操作系统实时性的研究论文摘要:通过分析嵌入式Linux在实时性方面的缺陷和缺乏,针对细化时钟粒度、可抢占式内核体系结构、中断软件模拟和实时调度策略等问题进行研究,提出了相应的实时性改良方法及宏观调度结构,拓展了实时系统的应用范围。论文关键词:嵌入式系统,实时性,抢占,调度策略一、引言Linux以其功能强大、源代码开放、支持多种硬件平台、模块化设计方案及丰富的开发工具支持等特点广泛应用在嵌入式系统领域。作为嵌入式产品的操作系统平台,Linux具有较好的实时性、系统可靠性、任务处理随机性。但由于其在实时应用领域的技术障碍,要应用在嵌入式领域,还必须对Linux内核作必要的改良。本文

2、首先分析了实时系统的特点和Linux内核在实时应用方面的缺乏,然后针对影响操作系统实时性能的假设干方面进行研究,提出解决方案。二、实时系统的分类实时操作系统贵在实时,要求在规定的时间内完成某种操作。因此实时系统最重要的特点就是实时性,即系统的正确性不仅仅依赖于计算的逻辑结果的正确性,还取决于输出结果时间的及时性。从这个角度看,实时系统是一个能够在指定或者确定的时间内完成系统功能和对外部环境做出响应的系统;。按对实时性能要求的程度,实时系统可分为两类:1硬实时系统:要求可确定性强,具有明确的实时约束,在某个限定的时刻之前不能完成任务将造成灾难性的后果。因此,在这类系统的设计和实现过程中,应采用各

3、种分析、模拟及形式化验证方法对系统进行严格的检验,以保证在各种情况下应用的时间需求和功能需求都能够得到满足。2软实时系统:也对时间敏感,当某些应用虽然提出了时间要求,但偶尔发生不能满足严格实时要求的情况也是允许的。因此,某些应用虽然提出了时间需求,但实时任务偶尔违反这种需求对系统的运行以及环境不会造成严重影响。三、Linux在实时应用中的技术障碍尽管Linux本身提供了一些支持实时性的机制,但是由于其最初的设计目标为通用分时操作系统,并且Linux系统是以高的吞吐量和公平性为追求目标,根本上没有考虑实时应用所要满足的时间约束,它只是提供了一些相对简单的任务调度策略。因此,实时性问题是将Linu

4、x应用于嵌入式系统开发的一大障碍,无法在硬实时系统中得到应用,作为一个实时操作系统,Linux仍然存在如下缺陷:1Linux的内核是不可抢占的。Linux分为用户态和核心态两种模式,当进程运行在用户态时,可被优先级更高的进程抢占,但当它进入核心态时,其他用户态进程优先级再高也不能抢占它,这将导致优先级逆转,实时任务执行时间的不确定性,显然不能满足硬实时应用的要求。2Linux系统时钟精度太过粗糙。时钟管理是操作系统的脉搏,任务的执行和中止在很多情况下都是由时钟直接或间接唤起的,它是进程调度的重要依据。Linux的周期模式定时器频率仅为100Hz,使得其时间粒度过大,加大了任务响应延迟,远不能满

5、足实时应用的要求。3Linux采用对临界区操作时屏蔽中断的方式,在中断处理中是不允许进行任务调度的,从而抑制了系统及时响应外部操作的能力。4缺乏有效的实时任务调度机制和调度算法。5Linux虽然给实时进程提供了较高的优先级,但是没有参加时间限制。例如:完成的最后期限、应在多长时间内完成、执行周期等等。同时,其他大量的非实时进程也可能对实时进程造成阻塞,无法确保实时进程的响应时间。四、改良内核实时性的分析与研究针对Linux在实时应用中的技术障碍,将Linux改造成为支持实时任务的嵌入式操作系统,主要从细化时钟粒度、可抢占式内核体系结构、中断软件模拟和实时任务的调度策略这四个方面对嵌入式Linu

6、x内核进行研究,并给出了相应的提高实时性的方法。1细化时钟粒度精确的计时是实时调度器正确操作所必须的,调度器通常要求在一个特定的时刻进行任务切换,计时的错误将导致背离方案的调度,引起任务释放抖动。标准Linux系统时钟精度太过粗糙,时钟中断周期为10ms,不能满足特定嵌入式应用领域中对于响应时间精度的要求。因此,在实时Linux应用中,需要细化其时钟粒度,具体有两种方式可以解决时钟粒度问题:1通过直接修改内核定时参数Hz的初值来细化时钟粒度,如将标准Linux中内核定时参数Hz改为10000,那么时钟粒度可以到达100s,这种方式虽然会增加一些系统开销,但在强周期性环境下,对定时器的设置只需初

7、始化一次,在一定程度上保证了处理效率。2通过对可编程中断定时器8254或先进的可编程中断控制器进行编程来改良Linux时钟机制,以提高其时钟的分辨率,使毫秒级的粗粒度定时器变成微秒级的细粒度定时器。2增强Linux可抢占性内核机制标准Linux内核是不可抢占的,导致较大的延迟,增强内核的可抢占性能,可提高系统内核对实时任务的响应能力。为了解决Linux实现硬实时的最大障碍,使Linux内核成为完全可被抢占实时内核,典型的实现方案是双核结构。使用实时核来运行实时任务,Linux内核来运行非实时任务。如图1所示。图1双内核结构对于Linux内核的修改主要集中在三方面:1在Linux内核中影响实时性

8、的地方增加控制点,使内核在控制点可以被抢占,减少内核抢占延迟。3根据实际需要,增加局部功能。3中断软件模拟响应时间的分析及解决方法:任务的响应时间被定义为一个事件的发生和任务响应这一事件开始执行之间的间隔时间,通常有以下几个因素影响任务的响应时间。1中断分配时间IDTinterruptdispatchtime:当一个中断产生时,在调用中断处理程序占用CPU以前,操作系统用来保存所有的存放器中的内容和系统中其他的关于这一任务状态的时间。2中断效劳时间ISTinterruptservicetime:中断效劳程序用来从硬件设备读取信息或从操作系统收集信息所用的时间。3内核抢占时间KPTkernelp

9、reemptiontime:在操作系统意欲抢占当前进程与抢占实际上发生之间的时间间隔。4调度延迟SDscheduledelay:调度程序用来调度另一个线程投入运行的时间。5进程切换时间CSTcontestswitchingtime:当前线程用来保存存放器和系统状态的时间与将要运行的线程恢复存放器中的内容和系统状态的时间总和。6系统调用返回时间RSTreturnfromsystemcall:处于内核态的线程在它返回用户态之前检查一些状态所用的时间。其中,SD、CST和RST总是固定不变的,如果Linux内核设计得当的话,IDT、IST和KPT可以有效的减少。在实时应用的环境中,假设干个中断同时发

10、生的情况是完全可能存在的。这时任务的响应时间最多将包含NIDT+IST,N为中断数。中断软件模拟被用来解决多个中断同时发生的情形。当一个硬件中断发生时,系统只是简单的在时间表中报告这一时间的发生,然后立即将CPU的控制权返回给操作系统,完全略过查中断向量表并执行相应的中断效劳程序。系统在Linux内核之前截获了所有硬中断信号,并根据当前实时任务的需要,由软中断模拟机制处理或挂起该中断。采用这个方法,可以减少当多个中断同时发生时任务的响应时间,最长的延迟时间为N*IST。4改善Linux内核实时任务的调度策略常用的实时调度算法有:1基于优先级的调度算法。基于优先级的调度算法调度器以优先级作为寻求

11、下一个任务执行的依据。可分为两种类型:静态优先级调度算法:该算法给系统中所有进程都静态的分配一个优先级。静态优先级的分配可以根据应用的属性来进行。动态优先级调度算法:该算法根据任务的资源需求来动态的分配任务的优先级。EDF算法是一种典型的动态优先级调度算法,该算法根据就绪队列中各个任务的截止期限来分配优先级,具有最近截止期限的任务的优先级最高。2基于时间驱动的调度算法。该算法本质上是一种设计时就确定下来的离线的静态调度方法。在系统的设计阶段,在明确系统中所有处理的情况下,对于各个任务的开始、切换以及结束时间等事先组出明确的安排和设计。3基于比例共享的调度算法。这是一种越来越受到关注的实时调度模

12、式,基于GPS的算法。其根本思想就是按照一定的权重CPU使用的比例对一组需要调度的任务进行调度,使其执行时间与权重完全成正比。可以通过两种方法实现:调节各个就绪进程出现在当前调度队列队首的频率,并调度队首的进程执行。逐次调度就绪队列中的各个进程投入运行,但根据分配的权重调节分配给每个进程的运行时间片。针对每一种调度策略都有自己的优越性和缺乏。通过设计和构造多属性和多调度器的选择机制,使三种实时调度策略的应用都得到支持,相对于只对单种调度策略提供支持的方案,拓展了系统的可使用范围,提出了一种宏观调度结构。如图2。图2宏观调度结构其中给每一个实时任务定义了4个调度属性:priority优先级:限制

13、该任务比相关联的其他任务的优先权、starttime起始时间:任务开始执行时间、finishtime截止时间:任务停止时间和budget预设值:任务允许执行时间,不同属性的数据对应不同的调度策略。宏观调度结构分为两个模块:属性分配模块和调度器选择模块。属性分配模块给每一个实时任务分配多个属性值,并通过其中的一两个属性值决定哪个属性优先,这样调度器选择模块就可以根据属性的优先级别选择不同的调度器。五、结束语嵌入式技术具有广阔的应用前景,渗透于社会生活的诸多领域,把Linux应用于嵌入式系统,将其自身固有的优越性融入嵌入式技术,是嵌入式技术开展的一个重要方向。然而,由于Linux在实时应用领域的技术障碍,要将其应用在嵌入式领域还必须修改Linux内核中的各个模块以到达满足嵌入式实时应用的需求。Linux实时性能的逐步完善、应用的需要也会进一步催促我们应该及时跟踪国内外Linux开展动态,同时积累此领域的开发经验,走出自己的路。参考文献1 骆耀祖. L

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论