- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微型抢占式多任务实时内核的设计
微型抢占式多任务实时内核的设计
; 摘要:介绍引入事件驱动观念的抢占式多任务微型实时内核——microstar的设计与实现;提出基于事件的优先级这一新概念。; 关键词:事件驱动 优先级 任务管理 消息 信号 同步; 市面上有很多优秀的嵌入式实时操作系统(rtos),但在中低端微控制器(mcu)上运行性能良好的rtos内核并不多。在高档机下,功能强大、运行极好的嵌入式实时操作系统,移植到中低端机上时性能很可能大幅度下降。一个很重要的原因就是它的大部分功能对中低档系统来说是不需要的,反而成为制约性能的累赘。中低档微控制器与高档机相比,一方面,寻址能力有限,处理速度慢,在相同的实时性能要求下,对内核的代码效率的要求更为严格;另一方面,中低档机完成的任务相对简单,减少了对内核的功能需求,比如可以不需要内存管理。从嵌入式系统的共性来说,大多数情况下用户程序和系统内核是紧密结合在一起的,运行时存储器容量消耗、任务的数量、执行时间和结果都是可以预计的,这可进一步缩小对内核的功能需求。; 牐犑录驱动的观点认为,任务应该是被动地响应外界发生的各种事件,而不是主动地去“查询”,浪费处理器时间。采用事件驱动编程的方法,不仅提高了运行效率,而且降低了事件处理之间的耦合,使程序流程非常清晰,从而可大大提高开发效率。; 牐牫浞挚悸侵械投宋⒖刂破鞯挠布特点和嵌入式系统软件的需求,引入“事件驱动”的观念,笔者开发了一个微型的抢占式多任务rtos内核——microstar。支持任务的动态创建、删除、睡眠、挂起和恢复,提供消息(message)和信号(signal)两种任务间的通信方案、完善的定时器服务和功能齐全的任务同步函数库。限于篇幅,着重论述几个与众不同的设计思路和实现难点。; 1 调度策略; 1.1 基于事件的优先级; 牐牰阅诤说氖凳毙阅芾此担调度策略是关键。好的调度策略,既要体现各任务因所处理的事件对实时性的不同要求而带来的优先级差异,又要保证一定的公平性,避免出现低优先级任务长时间得不到执行的极端情形。常用的调度策略有两种:一种是按时间片轮转(round robin)调度,如rtx51;另一种是严格按优先级的占先式调度,如μc/os。; 牐牥词奔淦轮转调度能很好地保证公平,但优先级的差异是通过对处理器的占用时间的多少来体现的。如果各个任务都不主动放弃执行,高优先级的任务能够比低优先级任务获得更多的处理器时间;但在嵌入式系统中,某个事件要求实时处理,并不意味着该处理需要较长的时间,而往往是要求尽快响应。因此,采用按时间片轮转调度,实时性不会太好。; 牐犎绻严格按任务的优先级来调度,可极大地提升系统的实时性,但却欠缺公平。如果高优先级任务是个无等待的死循环,低优先级任务就无法获得执行机会。; 牐犚桓龊玫陌旆ㄊ橇秸叩慕岷希即可由任务的优先级产生调度,也可以由时间片到产生新的任务调度,如vxworks;但是实现起来较为复杂,不一定适合中低档mcu。为此,基于以下事实,提出“基于事件的优先级(events based priority)”这一新观念。; 牐牏 一个任务往往处理多个事件,各个事件对实时性的要求不尽相同。一般的rtos下,任务的优先级是根据这些事件中对实时性要求最高的一个来确定的。因此,高优先级任务在处理对实时性要求不高的事件时,完全可能会妨碍低优先级任务处理具有一定实时性要求的事件。; 牐牏 有些情况下,对同一事件的处理可分为前台处理和后台处理:前台处理所需时间短,对实时性有较高的要求;后台处理花费时间长,对实时性则无多大要求。; 牐犎绻根据正在处理和等待处理的事件对实时性的不同要求,更细致地按事件处理的前后台阶段,动态地调整任务的优先级,采用优先级调度策略,既可发挥实时性好的优点,又可在一定限度内保证公平。这种情况下,任务的优先级不再是一成不变的,而是动态地取决于所处理的事件和处理阶段,这就是所谓的“基于事件的优先级”。; 1.2 在microstar中的实现; 牐燤icrostar中任务的优先级是由静态优先级和动态优先级共同决定的。静态优先级等同于其它rtos中的优先级;动态优先级为基于事件的优先级——由内核根据任务正在处理和等待处理的事件动态调整。静态优先等级限定为0~15级,不允许创建静态优先级相同的任务。动态优先等级目前只有0(亦称紧急级)、1(亦称普通级)两级。任务的实际优先等级可由下式来计算:; 牐犁畔鹊燃叮蕉态优先等级×16 + 静态优先等级。; 牐犁畔鹊燃吨翟酱螅优先级越低。可以看出,动态优先级起决定作用。; 牐犜跹实现优先级动态可调呢?首先简要介绍macrostar中任务的四个状态:; 牐犘菝(dormant)——任务因调用睡眠函数、挂起函数或者等待内核同步对象而进入休眠态;; 牐牭却(waiting)——任务因等待消
您可能关注的文档
- 网络技术特色的机电专业c语言教学改革和实践.doc
- 网络技术应用背景下的公共治理.doc
- 网络技术在电力信息通信中应用的策略研究.doc
- 网络技术在施工管治中的应用问题.doc
- 网络交际的基本特征及其规制.doc
- 网络交际的语用探讨.doc
- 网络交际的语用原则探析.doc
- 网络交际与语言学研究新视角.doc
- 网络交际对大学生心理发展的负面影响.doc
- 网络交际障碍的形成和排除.doc
- DB44_T 2611-2025 城市排水管网有毒有害气体监测与风险分级管理技术标准.pdf
- DB44_T 2612-2025 竞赛类科普活动策划与实施服务规范.pdf
- DB43_T 2947-2024 烟草种子质量控制规程.pdf
- DB37_T 4836-2025 煤矿风量实时监测技术要求.pdf
- 叉车防撞系统,全球前22强生产商排名及市场份额(by QYResearch).docx
- 超滤膜,全球前18强生产商排名及市场份额(by QYResearch).docx
- DB62T 4172-2020 玉米品种 酒623规范.pdf
- DB62T 4160-2020 在用真空绝热深冷压力容器综合性能在线检测方法.pdf
- DB62T 4164-2020 辣椒品种 酒椒1号.pdf
- DB62T 4133-2020 公路隧道地质超前预报机械能无损探测技术规程.pdf
文档评论(0)