当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]利用函数参数和返回值提高嵌入式软件质量

引 言
    提高软件代码的质量是每一个软件设计者都必须考虑的问题,这涉及软件的有效性和经济价值。基于嵌入式系统的软件设计多数是以实时操作系统为平台,这和传统的以WindOWS操作系统为平台的程序设计有很大的不同。前者要求对操作系统有更加深入的了解,要求使用者对自己的处理器和编译器工作原理有相当的理解,能够编写一定量的移植代码实现操作系统和底层硬件的连接。μC/OS—II是一种源代码公开的占先式实时操作系统内核,本文主要结合μC/OS—II的系统函数的应用,说明利用μC/OS—II系统函数的参数和返回值来提高程序设计效率和代码质量的方法。

1 参数和返回值分类
    通过对μC/0S—II的学习和研究,可以发现它提供的系统函数大多是用标准C语言写的;受C语言语法规则的限制,这些函数只有一个返回值。为了在使用μC/0SII的系统函数时得到更多的状态信息,将状态信息保存在函数参数中。这样,μC/OS—II系统函数的参数可以分为两类:第一类是普通的形式参数,这类参数符合传统的使用方法,主要传递实际参数的值,起到数值传递的作用;第二类形式参数在使用时,不传递有效数值,仅是一个变量。系统函数在执行时产生的状态信息就保存在第二类参数里,在系统函数调用结束时通过这类参数的值来查看系统函数执行过程中产生的状态信息。
    本文以函数0SSemPend()为例来介绍。这个函数没有返回值,它每个形式参数的具体含义见参考文献,这里不做具体的描述。其参数可归为上述的两类:OS_EVENT*pevent和INTl6U timeout为第一类,应用程序中的实际参数要给予它们具体的数值;INT8U*err为第二类,应用程序中的实际参数不需要给出具体的数值,在函数代码执行时,会根据不同的情况给INT8U*err赋值,这个值反映了函数的执行情况。如OSSemPend()函数的应用所示。


2 函数参数和返回值中的状态信息
    μC/OS—II的系统函数根据实际情况可以分为没有参数和返回值的函数、有参数没有返回值的函数和既有参数又有返回值的函数。在这里不讨论第一种情况,本文主要研究的是第二和第三种情况。如前所述,μC/OS—II为了增加系统函数执行产生的状态信息和返回值,将状态信息放到函数的参数中。笔者通过对μC/0S—II的系统函数的研究发现,这些函数并不是都将状态信息放到函数的参数中。有的也放到返回值中,如OSsemQtJery()函数,就是用返回值传递的状态信息,而用函数的参数传递的有效信息。这些状态信息反映了在使用μC/OS—II的系统函数时出现的问题,通过读这些状态可以知道系统函数执行的情况。因此,从安全的角度来说,在使用这些系统函数时应该读出所有状态信息,并且根据状态的不同给出相应的处理指令。按照这种思路,对OSSemPend()函数的应用的改进如下:


    可以看到,在调用系统服务函数OSSemPend()时,临时变量err作为实际参数传递给OSSemPend()。在执行这个函数后,err这个临时变量就包含了函数执行时产生的状态信息。这些状态信息使用常量而不用一个常数,是为了增加软件的可读性和通用性。具体的定义和含义如表1所列,其中前两种返回值是正常的:第一种是有信号可用时的情况,进行正常的处理;第二种是在规定的时间内没有信号到来,要做超时处理。后面三种情况是人为错误造成的。在调用OSSemPend()系统函数后要对这个包含状态信息的变量进行分析处理,过程如上述程序所示,由于篇幅关系,这里只是用简单的一句话来代表处理过程。[!--empirenews.page--]

3 状态信息的使用
   
在调用μC/OS—II的每个系统函数时,只要被调用的函数提供状态信息,都应该对这些状态信息进行分析和处理。专业软件设计者信奉这样一个道理:“编写无错代码的最好方法是把防止错误放在第一位”。以调用μC/OS—II的系统函数OSSemPend()为例,用户不需要去改动OSSemPend()函数的代码,假设这部分内容是没有什么问题的。现在我们要做的是检测这个函数执行时的状态,也就是它产生的出错信息。这个函数返回三种结果说明用户使用的错误,如表1所列:0S_ERR_EVENT_TYPE表示用户在调用OSSemPend()函数时提供的指针数据不是指向信号量的,发生了类型错误;OS_ERR_PEVENT_NULL表示用户提供的用作实际参数的指针是一个空指针;OS_ERR_PEND_ISR表示用户在中断服务程序中调用了OSSemPend()函数;这三种状态错误是在软件设计阶段由于用户粗心或者对μC/OS—II系统函数不了解而导致的。只要用户在设计过程中小心谨慎,这类错误可以避免。但是,从防止错误的角度来考虑,对这些错误的状态进行检测和处理是必要的,这样在错误发生时错误处理程序会给出简单的提示甚至对错误进行修改。错误处理程序防止在程序调试过程中反复阅读程序代码,避免了花费很大的精力去查找错误,提高了软件设计效率。
    按照以上方案设计出的嵌入式系统软件可以认为是一个理想的编译器。现在考虑一下,倘若编译程序能够正确地指出代码中的所有问题,那相应程序的错误情况会怎样?这不单指语法错误,还包括程序中的任何问题,不管它多么隐蔽。显然,现在所有的编译器都无法实现这种功能,所以要对编译器的功能进行扩展。这种设计思路可以认为是:软件设计者要设计出编译器的扩展功能,使得在进行软件设计时,编译器能够自己检查错误。如果能够做到,软件设计的劳动量将大大降低。

4 软件的调试版与交付版
   
前面的改进程序对OSSemPend()函数调用产生的所有可能状态进行了处理,而这部分代码中的大部分都是冗余代码,为的是便于软件的设计和调试。使用实时操作系统μC/0S—II进行嵌入式软件设计,用到的系统函数当然不止OSSemPend()一个,如果每个函数调用结束后都像程序中那样处理,代码的空间会迅速增加,程序的效率则会大大降低。
    为了解决这个问题,首先考虑,如果非常谨慎小心进行程序设计,多数的状态检测处理过程就可以省略。之所以对每个状态信息进行检测处理是为了提高软件设计调试的效率。在软件调试通过后,有些状态信息的检测就没有必要了。这就像乘坐飞机出行前要买保险,等航班到达目的地后,保险就没有什么用处了。软件最终是作为一个产品提供给客户的。这个产品是最终版本(当然还会不断升级)。在进行产品设计时会有一个调试版本,这个调试版要贯穿整个软件的生存周期。调试版是为了软件的设计、调试和升级使用,不会提供给用户,更不会出现在产品中。
    具体到嵌入式系统软件设计问题,仍然以调用OS—SemPend()函数的代码为例来说明问题。调用OSSem—


    通过观察上述程序和前面的改进发现,本段程序中加了几个条件编译指令。如果没有定义TEST标志,则有一部分代码将不会被编译,这就是交付版软件。反之,如果定义了TEST标志,则表示为调试版,所有的指令代码都会被编译。通过比较这两个版本看到:交付版的代码比调试版的代码在数量上大大减少。而且通过分析知道,在软件调试通过以后,就不存在OS_ERR_EVENT_TYPE、0S_ERR_PEND_ISR和OS_ERR_PEVENT_NULL的错误了,这两个版本实现的功能完全相同,这部分代码确实没有编译的必要了。

结 语
    嵌入式系统软件设计过程中,大部分场合会用到嵌入式实时操作系统。用户在保证自已设计代码质量的前提下,还要充分考虑调用系统函数时产生的状态信息,并进行适当的处理。只有这样,才能够提高软件的设计效率,缩短设计周期。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

强生公司(Johnson & Johnson)公布最近结束的季度销售额和利润实现增长,即使美元走强和劳动力成本上升削弱了业绩。这家保健用品公司周二下调了全年销售指引,因美元相对于全球其他货币的上涨带来的持续影响。...

关键字: JOHNSON SE OS

成都2022年10月19日 /美通社/ -- 近期,平安养老险积极筹备个人养老金的产品设计和系统开发工作,发展多样化的养老金融产品,推动商业养老保险、个人养老金、专属商业养老保险等产品供给。 搭养老政策东风 ...

关键字: 温度 BSP 东风 大众

广东佛山2022年10月19日 /美通社/ -- 空间是人居生活的基础单元,承载着生存与活动的最基本功能。而对于理想空间的解构意义却在物理性容器之外,体现出人们对于空间和生活深层关系的思考,同时也塑造着人与空间的新型连接...

关键字: 温度 BSP 智能化 进程

上海2022年10月19日 /美通社/ -- 10月17日晚间,安集科技披露业绩预告。今年前三季度,公司预计实现营业收入7.54亿元至8.33亿元,同比增长60.24%至77.03%;归母净利润预计为1.73亿...

关键字: 电子 安集科技 BSP EPS

北京2022年10月19日 /美通社/ -- 10月18日,北京市经济和信息化局发布2022年度第一批北京市市级企业技术中心创建名单的通知,诺诚健华正式获得"北京市企业技术中心"认定。 北京市企业技...

关键字: BSP ARMA COM 代码

北京2022年10月18日 /美通社/ -- 10月14日,国际数据公司(IDC)发布《2022Q2中国软件定义存储及超融合市场研究报告》,报告显示:2022年上半年浪潮超融合销售额同比增长59.4%,近5倍于...

关键字: IDC BSP 数字化 数据中心

上海2022年10月18日 /美通社/ -- 2022年9月5日,是首都银行集团成立60周年的纪念日。趁着首都银行集团成立60周年与首都银行(中国)在华深耕经营12年的“大日子”,围绕作为外资金融机构对在华战略的构想和业...

关键字: 数字化 BSP 供应链 控制

东京2022年10月18日  /美通社/ -- NIPPON EXPRESS HOLDINGS株式会社(NIPPON EXPRESS HOLDINGS, INC.)旗下集团公司上海通运国际物流有限公司(Nipp...

关键字: 温控 精密仪器 半导体制造 BSP

广州2022年10月18日 /美通社/ -- 10月15日,第 132 届中国进出口商品交易会("广交会")于"云端"开幕。本届广交会上高新技术企业云集,展出的智能产品超过140,...

关键字: 中国智造 BSP 手机 CAN

要问机器人公司哪家强,波士顿动力绝对是其中的佼佼者。近来年该公司在机器人研发方面获得的一些成果令人印象深刻,比如其开发的机器人会后空翻,自主爬楼梯等。这不,波士顿动力又发布了其机器人组团跳男团舞的新视频,表演的机器人包括...

关键字: 机器人 BSP 工业机器人 现代汽车

嵌入式教程

6897 篇文章

关注

发布文章

编辑精选

技术子站

关闭