使用嵌入式代码生成器检查复杂性

描述

Raspberry Pi 产品线于 2017 年 2 月通过 Raspberry Pi Zero W进行了扩展,这是一款 10 美元的具有无线连接功能的个人计算机。对于业余爱好者、制造商、修补匠、黑客,以及,是的,我们中为数不多的真正努力设计“真正的”电子产品的人来说,这是多么美好的时光啊!

尽管 Raspberry Pi 的“通用计算”区别和微控制器 (MCU) 的“嵌入式”分类存在细微差别,但两者的共同目标是为开发人员“控制复杂性”同时“吸引新手用户”。每种类型的平台都提供免费软件工具,包括集成开发环境 (IDE)、编译器、链接器、模拟器、调试器以及或多或少的开放中间件和操作系统 (OS)。两者都严重依赖于相似的(如果不相同的话)基于 GNU 的工具链。在中间件级别,一旦抽象了较低(直至金属)驱动程序层,开源选项再次非常相似。

尽管他们的使命是通过降低复杂性来支持开发人员,但是文档膨胀的问题在双方都很明显。一个完美的例子是基于 PIC 架构的小型 8 位 MCU,PIC16F1619。PIC16F1619 MCU 用于控制小型电器,为此,它在 20 引脚封装中仅包含 16 kB 闪存、12 个数字外设接口和大约同样多的模拟支持模块,但其数据表跨越 650 页(在添加之前表征数据、图表和图形)。PIC16F1619 上提供的外设(例如信号测量定时器 (SMT))需要多达 50 页,这几乎是描述实际 PIC 内核及其整个指令集所需的页数的两倍。

Raspberry Pi 方面的问题类似,只是按比例放大(高达 10 倍)。这里有几个数据表需要考虑,每个数据表只记录片上系统 (SoC) 的一个组件,例如外围设备、GPU 等。仅内核就占据了 750 多页。

不能指望没有人会阅读或简单地跟上如此大量的信息。特别是嵌入式开发人员总是承受着巨大的压力,要在更短的时间内交付应用程序以实现最快的上市时间。

迷失在嵌入式软件架构的层层中

解决信息泛滥的一种常见解决方案是使用分层架构和抽象硬件细节的标准化外围库对应用程序进行分区。这些层可以表示为一个整齐的堆栈,“应用程序”位于硬件抽象层 (HAL) 的顶部。如果需要,可以进一步细化堆栈以识别 HAL 和其上的中间件层,以实现常见的服务/功能,例如网络、文件系统和图形用户界面 (GUI)(图 1)。

pcb

【图1 | 此处显示的是嵌入式应用程序的软件堆栈的表示,可以通过分离驱动程序和电路板支持层来进一步细化。]

该软件架构模型源自“计算”世界,适用于大多数通用情况。不幸的是,它在嵌入式应用程序中存在两个基本缺点:

只要关注中间件层提供的标准功能,分层架构就可以简化文档膨胀问题。在应用范围的低端,中间件层非常薄,如果存在的话,结果主要是混淆。因此,开发人员必须依靠大型应用程序编程接口 (API) 形式的 HAL 文档,这是一个同样庞大的材料体,可以跨越数千页,而不会真正揭示设备的细节。当出现问题时,开发人员会陷入困境或被迫深入研究大量外来代码。

HAL 层为标准中间件服务提供了巨大的支持,但由于其严格的性质,通常最终会抹去特定设备的独特差异化功能。否则,这些功能可以为特定应用程序提供技术优势,并且可能是首先选择特定设备的原因。

代码生成器:让机器做它最擅长的事情!

由于堆叠的软件架构会导致性能损失和独特功能的扁平化,现代 MCU 开发人员在使用标准化 HAL 时获得的收益会减少。然而,强调快速开发的嵌入式控制市场的新一代代码生成器为解决这个难题提供了一条出路。

代码配置器/生成器做机器最擅长的事情,显着缩短或消除重复和容易出错的搜索数据表以配置硬件外围设备和构建 HAL 的过程。用户还可以从单个代码配置器界面了解特定的硬件外围功能,从而完全减少对数据表的需求。因此,HAL 成为嵌入式开发项目的灵活组成部分,可以在工程师优化应用程序性能时快速且频繁地重新生成。

代码配置器工具的显着特点包括:

与流行的 IDE 完全集成,允许工具(和用户)随时了解项目上下文(涉及的型号/部件号、使用中的中间件库等)

支持独特而复杂的外围设备,例如前面提到的 SMT。例如,SMT 可以在一个页面/对话框中直观地呈现给用户,其中包括一些直观的滚动列表和复选框(图 2)。

一个模板引擎,将用户配置转换为一小组完全定制的函数,减少必须传递给每个函数的参数数量,并保证大多数硬件抽象在编译时静态执行。生成的 API 是最小的,需要学习的功能很少,并利用一致和直观的命名约定。这提高了性能和代码密度(代码示例 1)。

由非常短的(C 语言)源文件组成的输出,可以由用户完全检查,提供学习和手动优化的机会。现代代码配置器以灵活的方式将生成的代码与用户代码混合在一起,从而保持完整性并允许充分利用高级硬件功能。

pcb

【图2 | 此处显示的是 Microchip Technology, Inc. 的 MPLAB 代码配置器 (MCC) 中的信号测量定时器 (SMT) 选项的屏幕截图。]

pcb

[代码示例 1 | SMT 外围源文件 (smt1.c) 的此示例部分显示了 MCC 生成的代码的节俭性。]

一旦外围配置完成,开发人员可以立即专注于应用程序。使用代码生成器,嵌入经典的“Hello, World!” 示例(总是转换为闪烁的 LED)变成了两行代码练习。

pcb

[代码示例 2 | 创建“Hello, World!”只需要两行代码。使用 MCC 的应用程序。]

在《In 10 Lines of Code》[5] 一书中可以找到其他 20 个有效使用快速开发工具的实际示例。

对抗复杂性

当我在 Pi Zero W 上观看 Eben Upton 的视频公告时,我不禁想起了我的早年时光。那时是80年代中期。我买不起 BBC 电脑或豪华的 Amiga,但我确实把所有的钱都花在了 Sinclair ZX Spectrum 上。Eben 让计算“人人都买得起”的努力真的引起了我的共鸣。

毕竟,将一台功能强大的 PC 挤进一个 6 厘米 x 3 厘米的微型印刷电路板 (PCB) 中,所达到的创纪录的低价点仍然让我感到惊讶。我经常想知道,是否正是 Spectrum 的节俭和诸多限制教会我更深入地研究电子产品并让我爱上了那个奇怪的机器世界——今天我们称之为嵌入式的软件和硬件之间的边界。

随着小型 MCU 成长为小型片上系统 (SoC),或者 PC 缩小为 Raspberry Pi,复杂性不一定是技术进步的必然结果。现代代码配置器可以帮助我们增强我们的软件开发过程,并最终恢复我们对快速增长的可用功能的控制。

是呢环保局:郭婷

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

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分