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

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

3天内不再提示

给嵌入式项目也来个分层试试

h1654155971.7688 来源:未知 作者:李倩 2018-05-11 09:18 次阅读

在一个初学者从入门走向精通的途中,像这种 发现问题 → 投入思考 → 提出方案 的学习模式是非常有效的。

一 遇到的问题

通过这一段时间的编码实践,积累了一些编码经验,但也体会到了之前的代码结构的缺陷:

(1)开发效率低:每次使用片内的某一资源(例如定时器等),笔者都要去查询技术手册,比较eggache~

(2)代码重复较多:每个实验源码中,诸如xtal_init,led_init等初始化函数每次都要编写

(3)不易修改:代码中的业务逻辑与SFR的操作混在一起,可读性较差,修改起来也费力

正是由于以上问题,笔者决定暂停了该系列博文的续写,抽出时间来思考一下解决办法。

二 由网站分层引起的思考

笔者在学习嵌入式编程之前,曾有过 ASP.NET 网站开发经验,对其分层理论也有所实践,下面简单提一下:

一般的有一定复杂度的网站可分为以下三层:

(1)数据接入层(DAL):负责与数据库的交互,供业务逻辑层调用

(2)业务逻辑层(BLL):调用数据接入层以获取数据,并为具体的业务需求提供支持

(3)用户界面层(UIL):负责呈现最终的用户界面

相信博客园中很大一部分朋友都对此非常熟悉,在此不再赘述。总之,分层以后,大大提高了代码的复用性与扩展性。

那么在嵌入式开发中,能否也利用分层的思想,来提高开发效率,增强其可维护性与可扩展性呢?下面,是一些笔者思考后的浅见。

三 嵌入式项目也来个分层

当然不能照搬ASP.NET 的具体分层思想,具体问题得具体分析嘛~

首先,嵌入式开发的核心就是芯片,它提供固定的片内资源共开发者使用。而且它具有一个很重要的特点就是,不随项目的需求变动而变动。所以应将其作为最底层,为上层提供基础支持。我们将其命名为硬件抽象层(Hardware Abstract Layer)。

芯片有了当然还不够,通常我们会在片外扩展一些功能模块来满足具体的项目需求,例如:传感器、键盘、LCD屏等。这一层的特点是,随项目的变动而以模块为单位动态增减。这一层的运作需要芯片内部资源的支持,所以应处于硬件抽象层之上,并为上层调用。我们将其命名为功能模块层(Functional Module Layer)。

OK,现在原材料都准备齐了:芯片+扩展模块,接下来就要开始真正的加工了:我们需要灵活调用之前两层所提供的接口,实现具体的项目需求。我们将其命名为应用程序层(Application Layer)。

图文:

(1)硬件抽象层(HAL)

实现对片内资源 (如定时器、ADC、中断、I/O等) 的通用配置,隐藏具体的SFR操作细节,为上层提供简单清晰的调用接口。

(2)功能模块层(FML)

通过调用 HAL,实现项目中所涉及到的各片外功能模块,隐藏具体的模块操作细节,并为上层提供简单清晰的调用接口。

(3)应用程序层(APL)

通过调用HAL与FML,实现最终的应用功能。

四 小试牛刀

OK,我们举一个具体的例子,来说明分层思想的运用。

之前,笔者需要完成一个略带综合性的小实验“温度监测系统”,需求分析大概如下:

•CC2430节点实现对温度的定时采集,并可通过LED灯指示其采样频率

•节点将数据传送至PC端

•节点可以接收来自PC的控制指令,以调整采样速率和电源模式

•具备停机自动复位能力

• 可进入睡眠状态,并可由按键唤醒

从上面的需求中我们可以看出,本实验的核心芯片为CC2430,需要的片外扩展模块为LED灯与按键,预期要达到具体项目需求即以上五点。

接下来,我们利用上面提到的分层理论小试牛刀,对“温度监测系统”这一实验的代码结构进行规划:

(1)应用程序层(APL)

[main.c] 引用hal.h、ioCC2430.h与module.h,实现温度采集、与PC互通信、停机复位等具体的应用需求

(2)功能模块层(FML)

[module.h] 定义了一系列片外功能模块(LED、按键),以及一系列的相关函数的声明

[module.c] 引用 hal.h,实现各片外模块(LED、按键)的功能

(3)硬件抽象层(HAL)

[ioCC2430.h](系统自带):定义了CC2430的所有SFR 、中断向量

[hal.h] 包括常用类型定义、常用赋值宏、以及CC2430片上资源的配置(I/O、串口通讯、ADC、定时器、电源管理等)

(注:由于本实验所涉及的片外模块——LED与按键——的使用极其简单,所以笔者将其合并入了单个源文件。若遇到较复杂的模块,可以单独新建 .h 与 .c 文件来实现,如LCD.h、LCD.c)

经此设计,其优点逐渐浮出水面:

• 高效的开发速率:编完 HAL 层中的hal.h之后,我们就可以很方便地调用,而不必反复地去查询SFR的具体设置细则

• 快速扩展:若需要加强系统功能,只需在 FML 层添加相应功能模块(即 .c 文件),并在main.c 中调用即可

• 较高的代码重用性:HAL 层所提供的SFR操作可供通用,而且该层几乎不用修改就可直接用于新的CC2430项目中

• 较好的可维护性:项目代码结构清晰,HAL 与 FML 几乎不需要修改,只需修改 APL 即可

五 结论

可能对于嵌入式编程高手来说,上述理论可能完全算不得什么,甚至还存在着很大的错误。不过在一个初学者从入门走向精通的途中,像这种发现问题 →投入思考 →提出方案的学习模式,我相信是值得而且很有必要的。就像很多人说的那样:过程比结论更重要。

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

    关注

    4976

    文章

    18245

    浏览量

    287919
  • CC2430
    +关注

    关注

    1

    文章

    96

    浏览量

    42540

原文标题:这个思路不错 给嵌入式项目代码来个结构分层

文章出处:【微信号:weixin21ic,微信公众号:21ic电子网】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    南昌大学_2007~2008学年嵌入式期末考试试卷A卷

    南昌大学_2007~2008学年嵌入式期末考试试卷A卷
    发表于 08-20 09:50

    嵌入式系统的分层及对口专业要求

    `嵌入式系统的分层及对口专业要求,嵌入式系统分为4层,硬件层、驱动层、操作系统层和应用层。硬件层比较适合于电子、通信、自动化、机电一体、信息工程类专业的人来搞。需要掌握的专业基础知识,有:单片机原理及接口技术、微机原理及接口技术
    发表于 05-07 16:39

    嵌入式linux初学者的建议

    嵌入式linux初学者的建议 目前,Linux作为嵌入式系统的主力军,广泛应用于消费类电子、工业控制、军工电子、电信/网络/通讯、航空航天、汽车电子、医疗设备、仪器仪表等相关行业。随着嵌入
    发表于 05-28 09:54

    嵌入式学习路线 嵌入式新手最正确的指引

    ;  嵌入式 Linux并发程序设计;  嵌入式 Linux网络编程;  嵌入式数据库开发;  嵌入式 Linux应用综合项目;  ARM处
    发表于 05-26 16:34

    嵌入式代码来个分层

    嵌入式代码来个分层 一、遇到的问题代码结构会有缺陷:(1)开发效率低:每次使用片内的某一资
    发表于 03-23 13:54

    怎么利用分层思想进行嵌入式项目设计

    利用分层思想进行嵌入式项目设计,你试过吗?
    发表于 05-22 10:16

    哪个有嵌入式/单片机工程师面试试题和答案的?分享下

    哪个有嵌入式/单片机工程师面试试题和答案的?分享下
    发表于 08-06 17:19

    GitHub 嵌入式项目 精选资料分享

    GitHub 上有什么嵌入式方面的项目?关注问题写回答嵌入式系统...
    发表于 08-09 08:39

    嵌入式程序怎么划分结构更清晰、符合规范?

    最近在写自己的第一个基于Linux嵌入式项目,本来想着边看边敲,可是教程的代码风格实在让我感到很不舒服:程序是不难,容易看懂,但是程序的耦合太大,不易扩展,结构混乱。所以,我想知道,嵌入式
    发表于 09-05 17:24

    嵌入式分层架构的相关资料分享

    最近重新进入嵌入式领域,有必要对嵌入式分层架构有一个清晰的理解。经过多方查阅以及个人的理解,本人对嵌入式分层架构概括总结如下:比较细的层次由
    发表于 10-28 08:42

    嵌入式软件开发过程之程序代码分层

    嵌入式软件开发过程中,在程序架构的搭建完成之后,为了提高项目代码的可读性和可维护性等,应对程序代码分层
    发表于 12-21 06:13

    嵌入式操作系统时如何分层的?各层的功能是什么?

    嵌入式操作系统时如何分层的?各层的功能是什么?
    发表于 12-27 06:44

    探讨一下嵌入式软件分层设计

    嵌入式软件分层设计嵌入式软件就是某一项目的源码文件集合,源码文件的数量,根据项目复杂程度的不同而有规模和层次的差别。就拿简单的一个芯片厂..
    发表于 02-14 07:19

    关于WLAN Bluetooth的嵌入式项目有哪些?

    看到问题的读者们下午好,刚进入嵌入式领域,想咨询了解一下嵌入式关于WLAN、Bluetooth和通信协议相关的嵌入式项目有哪些?请大佬们
    发表于 08-19 16:34

    聊聊嵌入式软件分层

    今天以控制LED闪烁为例,聊聊嵌入式软件分层
    的头像 发表于 12-28 09:22 247次阅读