0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于实时多任务操作系统构建软总线架构模式

电子设计 来源:郭婷 作者:电子设计 2019-08-23 08:01 次阅读

随着大型嵌入式系统向着集成化和多元化方向的发展,嵌入式软件系统的复杂度也日益增大。在集成多个硬件工作模块组成的复杂系统中,要求软件系统能同时测控多个模块的同步工作,软件设计要求做到实时多任务。针对软件设计的要求,采用基于实时多任务操作系统提供的底层任务调度机制,建立软件架构成为较好的选择。本文提出了基于实时多任务操作系统,建立软件架构时采用软总线提供数据驱动层的架构模式。针对实时多任务操作系统,分析任务调度与数据驱动层。针对资源共享与任务进程独立性等问题,提出软总线在共享数据维护上的优势。

2.任务调度、共享资源与软总线结构研究

2.1 嵌入式开发任务调度和资源共享

目前主要的实时多任务操作系统(VxWorks嵌入式Linux,WinCE)的任务调度均采用对于不同优先级抢占式调度,对同优先级采用时间片轮转调度的方法。为使低优先级任务能得到运行,软件需要能阻塞高优先级任务,同时也要能使被阻塞的任务重新就绪运行。操作系统对进程间通信资源的操作能产生这样的效果,所以在架构软件时,常借助进程间通信资源的使用。然而采用这样的方式,调度灵活性较差,同时低优先级任务对进程间通信资源的占用也始终处于劣势。任务进程较多复杂软件系统中,无法避免的会出现多进程共用资源的情况,事实上进程通信资源也是一种多进程共用的资源。进程可以对自身资源进行管理,但对于这些共享的资源,就无法只由共享者中的某一个进行管理。而这个管理却是必要的,否则进程内部的意外可能通过这些资源蔓延到其他进程,如:进程内部意外的对资源地址赋空,就会使其他共享该资源的进程在使用该资源时崩溃。这就要求在系统设计时,有独立于各个进程之外的总体的对资源管理的模块。

2.2 软总线结构

在此,本文提出软总线结构来架构复杂的软件系统,以解决任务调度和资源管理上的困难。软总线是封装了操作系统对于进程间通信资源,共享内存等有多个进程共同使用的资源操作的模块。该模块为任务进程模块提供标准的资源申请、使用及回收接口,任务进程使用该接口及协议的标识进行资源的共享。

首先,软总线封装了各种进程可能共享的资源,独立于进程之外对资源进行管理,使共享资源对于任务进程透明,任务进程无法直接操作资源。这样的处理方式使得资源本身不能被任务进程修改或破坏。任务进程获取的数据,实际是总线上数据的副本,而所有关于总线上数据的更新都需要总线模块的认证,以避免出错。总线模块在操作系统底层调用的基础上,通过封装资源、提供接口,构建了一个数据驱动层。同时,由于软总线的封装,使得在构建软件系统时,对进程的调度需要通过软总线来实施。如果在总线模块处加载系统的调度策略,可以更灵活有效地对每个资源进行任务的调度。使得一方面降低了在开发初期为任务进程设置合理优先级的难度,一方面也使得不同任务能在不同的资源处能有更为灵活的优先策略。

综合以上两点,以软总线架构底层数据驱动的方式构建实时多任务软件系统,可以有效地保护和管理共享资源并更为简单灵活对系统进行调度。

3.软总线软件架构方案

本设计基于Vxworks操作系统,试验平台包括通信、存储、复接、硬件总线与主控计算机等硬件电路板,及与硬件相对应的软件功能模块。

3.1 软件架构整体方案

本设计中,软总线封装的操作系统对于内存、信号量以及消息队列的创建、删除及使用等操作。上层与硬件功能对应的软件任务模块需要通过软总线进行对资源操作。具体的结构如图1 所示:对于功能模块本地化的资源,不强制要求使用软总线操作。

基于实时多任务操作系统构建软总线架构模式

图1 软总线架构设计框图

3.2 软总线详细设计

对于软总线结构的架构方式,设计关键节点就是软总线模块。该模块负责对操作系统的资源封装和上层功能模块的资源使用请求处理。本设计中,将软总线分成两个主要的部分:资源池和管理表。资源池是软总线模块开辟的内存区域,在内存池上进行系统其他功能模块的共享资源的创建。

软总线引入了以下操作特性:资源创建于软总线的资源池,功能模块通过标示符来间接地使用资源,资源使用需要经过软总线的验证,多个进程对同一资源会有不同的操作方式和优先级,不同的资源有不同的调度策略。针对这些特性,就需要有相应的管理系统。该系统需要维护资源与标示符之间的关联、任务进程对资源的相关操作参数、资源特有的调度策略等。本文设计中软总线主要使用四个表格存储关联信息,其详细设计图如图2:

基于实时多任务操作系统构建软总线架构模式

图2 软总线详细设计图

3.3 资源使用调度详细设计

为了保证资源的安全性,系统要求进程在使用资源的时候先进行进程注册和资源申请。同时,系统对资源使用的行为进行比较严格的检测。因此,进程使用资源分为三步:进程注册,进程申请资源及进程使用资源。进程注册是在进程建立的时候,同时将进程信息写入软总线的进程表加以保存。进程申请资源通常在进程建立以后第一次工作时完成,类似对资源的初始化。进程申请资源要求进程在软总线已经注册,同时要求进程对资源的参数限定符合该资源。进程使用标识符来标示所要使用的资源,如果该资源不存在,这以该进程给定的参数在资源池中建立和初始化该资源并关联进程;如果资源存在,比对参数,如果一致,直接关联进程,否则出错处理。出错处理产生以“标识符_进程编号”为标识的副本,以进一步的使用,当然同时会有出错提示。

资源使用要求进程和资源已经关联。同时使用的过程中,进程操作的是数据的副本,而对资源的更新是要受到系统的检测的。这次,副本数据的更新是实时的,这样就避免出现同步的问题。资源调度也会在资源获取前依据资源调度表中的信息进行。进程对资源申请和使用的详细调度如图 3 所示:

基于实时多任务操作系统构建软总线架构模式

图3 进程对资源申请和使用的详细调度图

3.4 系统验证和安全性模拟实验

经过验证,该系统*能模块使用软总线提供的接口操作资源,其速度和效率不低于使用未封装的资源。同时,软总线的封装使得资源对功能模块透明,而且使用资源时还要求对其进行较强的验证,因此资源的安全性及系统的健壮性得到了较大幅度的提高。为了验证系统的安全性健壮性,我们进行了安全测试。在测试中,模拟了系统可能出现的各种安全漏洞。同时,与使用非软总线结构,对资源不进行强验证的系统进行比较。结果如表1:

基于实时多任务操作系统构建软总线架构模式

如上表所示,使用软总线架构,系统具有更强的安全性和健壮性。

4.结束语

本文介绍了使用软总线封装系统资源,设计实时多任务嵌入式软件的架构方式。通过实际的工程实践,给出软总线的设计方案。文章通过理论分析和实验对比指出了这种架构方式在处理多任务调度和资源共享上相对普通架构的优势。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5089

    文章

    19167

    浏览量

    306708
  • 封装
    +关注

    关注

    127

    文章

    7968

    浏览量

    143218
  • Linux
    +关注

    关注

    87

    文章

    11333

    浏览量

    210054
收藏 人收藏

    评论

    相关推荐

    嵌入式实时多任务操作系统培圳教材

    嵌入式实时多任务操作系统培圳教材:以VRTX为对象详细介绍了嵌入式实时操作系统的原理和应用,特别是第一部分关于嵌入式
    发表于 04-19 22:02

    实时多任务操作系统

    实时多任务操作系统(Real Time multi-tasking Operation System, RTOS)实时多任务
    发表于 08-12 14:31

    关于嵌入式实时多任务软件的总线结构设计你想知道的都在这

    本文提出了基于实时多任务操作系统,建立软件架构时采用总线提供数据驱动层的
    发表于 04-23 06:26

    实时多任务操作系统(RTOS)

    任务、进程和线程。实时多任务操作系统(RTOS)是嵌入式应用软件的基础和开发平台,它是根据操作系统的工作特性
    发表于 08-24 06:34

    为什么要在单片机中使用实时多任务操作系统

    为什么要在单片机中使用实时多任务操作系统该视频在113分10秒之后,讲了实时操作系统的使用价值。老师讲得非常好,我就不过多赘述了。(这个视频
    发表于 08-24 06:02

    实时多任务操作系统的相关资料推荐

    实时多任务操作系统美国的火星表面登陆的火星探测器上使用的嵌入式操作系统是VxworksμC/OS-II是“MicroController Operating System”的缩写,它是
    发表于 12-22 06:48

    VxWorks操作系统实时多任务程序设计

    VxWorks操作系统实时多任务程序设计
    发表于 03-25 10:38 13次下载

    嵌入式实时多任务软件的总线结构设计

    本文提出在嵌入式实时操作系统上建立实时多任务软件系统时,使用
    发表于 09-12 17:09 20次下载

    采用Protothread实现实时多任务系统

    采用Protothread实现实时多任务系统 在许多系统资源非常紧张的单片机应用中,使用实时操作系统
    发表于 03-29 15:10 1466次阅读
    采用Protothread实现<b class='flag-5'>实时</b><b class='flag-5'>多任务</b><b class='flag-5'>系统</b>

    DSP实时多任务操作系统设计与实现

    DSP实时多任务操作系统设计与实现又需要的下来看看。
    发表于 05-09 10:15 0次下载

    51单片机多任务操作系统的原理与实现

    51单片机多任务操作系统的原理与实现,在51单片机上模拟操作系统
    发表于 02-28 15:09 16次下载

    实时多任务嵌入式软件的架构方式的设计应用

    测控多个模块的同步工作,软件设计要求做到实时多任务。针对软件设计的要求,采用基于实时多任务操作系统提供的底层
    发表于 10-25 14:46 1次下载
    <b class='flag-5'>实时</b><b class='flag-5'>多任务</b>嵌入式软件的<b class='flag-5'>架构</b>方式的设计应用

    基于实时操作系统的单片机多任务应用程序设计

    基于实时操作系统的单片机多任务应用程序设计
    发表于 10-27 15:21 49次下载
    基于<b class='flag-5'>实时</b><b class='flag-5'>操作系统</b>的单片机<b class='flag-5'>多任务</b>应用程序设计

    总线架构实时多任务软件系统中的设计应用

    多任务。针对软件设计的要求,采用基于实时多任务操作系统提供的底层任务调度机制,建立软件架构成为较
    发表于 11-30 12:29 591次阅读
     <b class='flag-5'>软</b><b class='flag-5'>总线</b><b class='flag-5'>架构</b>在<b class='flag-5'>实时</b><b class='flag-5'>多任务</b>软件<b class='flag-5'>系统</b>中的设计应用

    RTOS实时操作系统怎么执行多任务的?

    在RTOS实时操作系统中是怎样实现多任务的?
    的头像 发表于 03-03 13:49 4686次阅读
    RTOS<b class='flag-5'>实时</b><b class='flag-5'>操作系统</b>怎么执行<b class='flag-5'>多任务</b>的?