《电子技术应用》
您所在的位置:首页 > 嵌入式技术 > 业界动态 > 最简单IO驱动的智慧

最简单IO驱动的智慧

2015-07-02
作者:周立功致远电子

       摘要:GPIO驱动是嵌入式系统中最简单的驱动,然而有多少电子类高材生在它身上栽了跟头?

图片16.png

       从单片机到ARM7、ARM9、Cortex-A8,从uC/OS到WinCE、Linux,GPIO驱动都是最简单、最易编写的驱动。但看似简单、毫无技术含量的驱动,其是否完整?是否规范?是否安全?

典型案例

       本节将选取两例典型案例,从反、正两个角度进行对比。

反方案例

       以某一源码中XXX驱动为例,截取XXX_IOControl部分的代码,如程序清单1所示;请留意代码突出显示部分。

程序清单1

图片17.png

       从反方案例,实现GPIO电平状态的读或写的功能仅需要几行代码,非常简单。

正方案例

       如程序清单2所示,代码截取自ZLG某核心板GPIO驱动,请留意代码中突出显示部分。

程序清单2

图片18.png

       从反方案例,实现GPIO电平状态的读或写的功能仅需要几行代码,非常简单。

正方案例

       如程序清单2所示,代码截取自ZLG某核心板GPIO驱动,请留意代码中突出显示部分。

程序清单2

图片19.png

图片20.png

图片21.png

图片22.png

何如此大?

案例点评

一、指针使用

       在反方案例中,函数传递进来的指针参数未经判断而直接使用,这种情况下若为空指针或野指针,则程序极可能出现异常甚至崩溃! 

       反方案例在读取操作后,使用“*pBytesReturned = 2;”返回实际读取的字节数,但是,该指针依然未经判断而直接使用!

       而正反案例则在每一项参数使用前均对参数范围、有效性进行判断,从根本上避免了参数异常情况的发生!

二、错误提示

       在反方案例中,XXX_IOControl只是返回TRUE或FALSE,返回FALSE时应用层无从获取或获知是什么原因造成了“FALSE”! 

       对比正方案例,在参数判断时即开始添加错误提示,在return之前,调用SetLastError函数,应用层则可以通过GetLastError获取错误原因,允许用户更快速、准确的定位错误点。

三、注释

反方案例函数体内外几乎无注释;

       而正方案例,无论函数体内的关键位置还是函数体外,均做必要、详细的注释说明,为程序的后期维护带来极大的便利!

       包括最简单的GPIO在内,驱动实现功能非常容易,但驱动的完整性与可靠性却蕴藏着软件工程的大智慧。


本站内容除特别声明的原创文章之外,转载内容只为传递更多信息,并不代表本网站赞同其观点。转载的所有的文章、图片、音/视频文件等资料的版权归版权所有权人所有。本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如涉及作品内容、版权和其它问题,请及时通过电子邮件或电话通知我们,以便迅速采取适当措施,避免给双方造成不必要的经济损失。联系电话:010-82306118;邮箱:aet@chinaaet.com。