ucos-ii任务用户接口改善

 
引 言:
  就目前而言,ucos ii称得上是最小的操作系统内核软件。它由Jean J. Labrosse于1992年推出第一版,立刻在嵌入式系统领域引起强烈反响,而其本人也早已成为嵌入式系统会议(美国)的顾问委员会成员。ucos ii最鲜明特点就是源码公开,便于移植和维护,而且对于学校研究完全免费,只有在应用于盈利项目时才需要支付少量的版权费,特别适合一般使用者的学习、研究和开发。自问世以来,μC/OS的稳定性和可靠性得到了广泛认可,现已通过美国FAA认证,并被众多的研究开发者作为操作系统的样板,移植到各种的硬件平台上。

1 ucos ii任务用户接口的缺点  
     ucos ii中任务的用户接口并不友善,与众多程序员熟悉的Windows多任务接口相异较大。
  首先,ucos ii中任务的栈空间完全由用户自行管理,系统只是简单的要求用户创建任务时传入栈地址,而不参与栈空间的申请和释放。为了简化, ucos ii的示例程序以静态数组作为任务栈。栈空间的放任自流在带来一定灵活性的同时也会带来问题。有些用户仿照示例程序,大量以静态数组形式作为任务栈,极大地浪费了嵌入式系统极为珍贵的内存空间;而有些用户在任务开始时申请了栈空间,在任务结束时却忘记释放,造成难以跟踪的内存漏洞。
  其次,在ucos ii中任务结束时,需要手工调用OSTaskDel使该任务进入睡眠态,不能简单的返回。这是因为μC/OSII规定任务必须为无限循环或自销毁形式,而流行的大多数操作系统,任务结束后只是简单的返回,由系统帮助释放任务占据的资源。
  2002年,随着我国相关下游产业,包括移动通信、信息家电以及工业控制等领域的快速发展,嵌入式软件产业迎来了极佳的发展时机。强劲的市场需求带来了研发的快速增长,越来越多的软件公司投入到嵌入式产品的研发中。但是国内嵌入式产品的产业现状是,程序员素质在数量上呈现金字塔状况,高级程序员很少,广大对Windows编程熟悉但对嵌入式开发陌生的普通程序员占据金字塔的底端。
  若希望在数量庞大的普通程序员中应用ucos ii,减少Bug产生的来源,那么对其任务接口作出简化处理是必要的。
2 对ucos ii调度算法的改善 
  本文参考国内程序员很熟悉的Windows多线程接口,对ucos ii任务接口做出改进,增强易用性和用户亲和力。本文在任务创立时帮助用户申请栈空间,并在初始化用户栈时,将任务销毁函数压入栈中,使其能在用户任务返回时自动调用,自动释放栈空间,并调用OSTaskDel使该任务进入睡眠态。
  增加接口OSNewTaskCreate和OSAutoTaskDel。OSNewTaskCreate用于创建任务,该函数在系统内核中代替用户申请栈空间,并在初始化栈内容时压入OSAutoTaskDel地址。改进后的OSNewTaskCreate接口如下:
  INT8UOSNewTaskCreate(任务地址pThead,参数pData,栈大小dwStackSize,优先级prio);
  用户传入需要栈空间的大小(dwStackSize)而不是栈地址,如果dwStackSize为零,则栈空间为系统预设的大小。系统调用 OSMemGet在栈内存分区(MemoryPartition)中申请该空间。该栈内存分区在系统初始化时调用OSMemCreate分配,用来统一管理所有的用户栈。接下来的步骤和ucos ii完全相同,这里不再详述。
栈空间申请了,在哪里释放呢?可以通过修改栈初始化函数OSTaskStkInit,把OSAutoTaskDel地址压入任务栈中。修改前,OSTaskStkInit形成的栈在x86平台上的内容如图1所示。
  任务第一次被调度进入运行态时,系统模仿从中断返回,会开始执行用户任务[1]。图1中“任务开始地址”处,理论上应该为任务的返回地址,但在 μC/OSII中,任务函数必须为无限循环结构或自销毁形式,不能有返回点。因此,仅仅简单添入任务开始地址,如果用户任务返回,则会有不可预料的后果。修改OSTaskStkInit使栈的内容如图2所示。
此时,用户任务的栈内容与OSAutoTaskDel函数用pdata作参数调用它的栈内容完全相同。所以在用户任务返回时,自动调用 OSAutoTaskDel函数,省去了手工调用OSTaskDel的麻烦。在OSAutoTaskDel中,先释放栈空间,之后调用OSTaskDel 使该任务进入睡眠态。
结语
  本文对ucos ii中任务的用户接口进行了改善,使之更加方便易用、易于维护,并减少了错误出现的机会。通过以上方法,希望能使ucos ii为普通嵌入式程序员所接受。
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: STM32 uCOS-II任务实验是一种基于STM32微控制器和uCOS-II操作系统的多任务应用程序实验。该实验旨在通过使用uCOS-II操作系统,实现多个任务同时运行,提高系统的效率和可靠性。 在该实验,我们可以使用STM32开发板和uCOS-II操作系统,创建多个任务并分配不同的优先级。每个任务可以执行不同的操作,例如读取传感器数据、控制外设、处理数据等。通过使用uCOS-II操作系统的任务调度机制,可以确保每个任务按照其优先级顺序执行,从而实现多任务并发执行的效果。 在实验过程,我们需要学习uCOS-II操作系统的基本概念和使用方法,包括任务创建、任务调度、信号量、消息队列等。同时,还需要了解STM32微控制器的硬件资源和编程方法,以便实现任务的具体功能。 总之,STM32 uCOS-II任务实验是一种非常有意义的实验,可以帮助我们深入了解嵌入式系统的多任务编程和操作系统原理,提高我们的实际应用能力。 ### 回答2: stm32是一款基于arm cortex-m内核的微控制器,其具有高性能和低功耗的优点,可广泛应用于嵌入式系统、智能家居、机器人等领域。同时,ucos-ii是一款实时操作系统,能够提供多任务管理、资源管理、时间管理等功能,可帮助开发人员快速构建嵌入式系统。 stm32 ucos-ii任务实验是指在stm32平台上实现ucos-ii操作系统的多任务管理功能,以实现任务之间的并发执行。该实验通常包括以下几个步骤: 1.准备工作:在开发板上搭建环境,包括stm32开发环境、ucos-ii环境以及相关工具的配置。 2.任务定义:定义多个任务,每个任务都是一个独立的程序模块,应包括任务的初始化、任务功能、任务清理等步骤。 3.任务调度:ucos-ii操作系统会根据任务的优先级、状态等因素进行任务调度,确保任务可以及时得到执行。 4.任务通信:在多任务实验,由于各个任务之间具有相互制约关系,因此需要进行任务通信,以确保任务能够协同工作。 5.调试测试:在实现多任务后,需要进行调试测试,确保各个任务能够正常运行,系统具有稳定性和健壮性。 综上所述,stm32 ucos-ii任务实验可以帮助开发人员深入了解stm32的基本功能和ucos-ii实时操作系统的特点,提高系统的并发处理能力,为嵌入式系统的开发和应用提供有力支持。 ### 回答3: STM32 uCOS-II任务实验是一种在STM32芯片上使用uC/OS-II操作系统进行多任务开发的实验。该实验旨在帮助学生和工程师熟悉uC/OS-II操作系统,学习多任务的开发和调试技术。 在这个实验,我们需要使用一些基本的硬件和软件,如STM32开发板、uC/OS-II操作系统、Keil或者IAR嵌入式开发工具、以及一些基本的电子元器件。我们需要编写一些任务代码,在uC/OS-II操作系统上进行多任务的协作开发。我们需要学习如何在uC/OS-II操作系统上创建任务、删除任务、挂起任务、恢复任务、设置任务优先级等等。 在进行STM32 uCOS-II任务实验时,我们需要注意一些事项。首先,我们需要根据实际需要分析任务的资源需求和优先级,为每个任务分配适当的资源和优先级。其次,我们需要了解uC/OS-II操作系统的机制和原理,例如任务调度、消息传递、事件通知等等,以便正确使用和调试操作系统的各种功能。 总之,STM32 uCOS-II任务实验是一个非常有价值和有意义的实验,它能够帮助我们提高多任务开发和调试的能力。通过这个实验,我们能够掌握uC/OS-II操作系统的使用方法和技能,提高我们的嵌入式开发能力和技术水平。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值