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

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

3天内不再提示

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

星星科技指导员 来源:嵌入式计算设计 作者:Lucio Di 2022-06-09 11:05 次阅读

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)。

poYBAGKhZBuAB5dAAABOG8pCf5s001.png

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

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

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

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

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

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

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

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

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

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

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

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

pYYBAGKhZBWATcC5AADtmaIGywg199.png

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

poYBAGKhZA6AWVUsAAMHJ88JxWU091.png

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

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

pYYBAGKhZAiAA3USAAAe4I6dglE111.png

[代码示例 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,复杂性不一定是技术进步的必然结果。现代代码配置器可以帮助我们增强我们的软件开发过程,并最终恢复我们对快速增长的可用功能的控制。

是呢环保局:郭婷

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

    关注

    4193

    文章

    22376

    浏览量

    383966
  • soc
    soc
    +关注

    关注

    38

    文章

    3709

    浏览量

    215375
  • 定时器
    +关注

    关注

    23

    文章

    3124

    浏览量

    111898
收藏 人收藏

    评论

    相关推荐

    RL78的代码生成器发布说明

    电子发烧友网站提供《RL78的代码生成器发布说明.pdf》资料免费下载
    发表于 01-30 09:48 0次下载
    RL78的<b class='flag-5'>代码</b><b class='flag-5'>生成器</b>发布说明

    单片机代码自动生成器程序

    和输入/输出设备的芯片。它通常用于嵌入式系统中,能够完成一系列特定的任务。开发人员编写的单片机代码负责指导单片机执行相应的任务。然而,编写单片机代码是一项繁琐而容易出错的工作,代码
    的头像 发表于 01-08 14:12 531次阅读

    TSMaster报文发送的信号生成器操作说明

    信号生成器功能是TSMaster分析中的报文发送模块。信号生成器用于发送和配置每个CAN/LIN信号的值变化行为,简而言之,这是一个可以控制和调整CAN/LIN信号值的功能。我们可选择的信号生成器
    的头像 发表于 12-23 08:21 267次阅读
    TSMaster报文发送的信号<b class='flag-5'>生成器</b>操作说明

    Python生成器的使用方法

    举一个例子,编写一个函数计算一串数字里所有偶数的个数,其实是很简单的问题,但是有些人是用生成器这么写的: In [ 66 ]: def f1 ( x ): ....: return sum
    的头像 发表于 11-03 15:41 219次阅读

    STM32MP1系列密钥生成器软件说明

    电子发烧友网站提供《STM32MP1系列密钥生成器软件说明.pdf》资料免费下载
    发表于 09-20 10:36 0次下载
    STM32MP1系列密钥<b class='flag-5'>生成器</b>软件说明

    Versal GTY/GTYP:使用PRBS生成器检查

    本文涵盖了在 Versal GTY 和 GTYP 中使用模式生成器检查器时对以下操作的限制
    的头像 发表于 07-10 17:18 679次阅读

    e² studio 代码生成器用户手册:RZ API 参考 Rev.1.02

    e² studio 代码生成器用户手册:RZ API 参考 Rev.1.02
    发表于 07-05 18:52 0次下载
    e² studio <b class='flag-5'>代码</b><b class='flag-5'>生成器</b>用户手册:RZ API 参考 Rev.1.02

    IzoT 资源报告生成器用户指南

    IzoT 资源报告生成器用户指南
    发表于 07-04 20:46 0次下载
    IzoT 资源报告<b class='flag-5'>生成器</b>用户指南

    代码生成器用户手册:RL78 API 参考

    代码生成器用户手册:RL78 API 参考
    发表于 07-03 20:08 0次下载
    <b class='flag-5'>代码</b><b class='flag-5'>生成器</b>用户手册:RL78 API 参考

    将使用代码生成器生成的项目移植到与智能配置器一起使用的项目

    将使用代码生成器生成的项目移植到与智能配置器一起使用的项目
    发表于 06-30 20:54 0次下载
    将使用<b class='flag-5'>代码</b><b class='flag-5'>生成器</b><b class='flag-5'>生成</b>的项目移植到与智能配置器一起使用的项目

    个性化地定制自己的uvm代码生成器模板和脚本

    使用uvm代码生成器创建基本的uvm验证环境框架,然后丢弃代码生成器模板并扩展和维护生成出来的代码
    的头像 发表于 05-14 16:51 1181次阅读
    个性化地定制自己的uvm<b class='flag-5'>代码</b><b class='flag-5'>生成器</b>模板和脚本

    代码生成器配置和软件UART的实现

    (RL78)上的具体的实现方法,这里略去工程的建立过程,相应的驱动程序细节可以参考代码生成器生成代码,这里只重点讲述代码
    的头像 发表于 05-09 09:25 857次阅读
    <b class='flag-5'>代码</b><b class='flag-5'>生成器</b>配置和软件UART的实现

    外设驱动生成器V.1.02指导手册

    外设驱动生成器V.1.02 指导手册
    发表于 04-28 18:44 0次下载
    外设驱动<b class='flag-5'>生成器</b>V.1.02指导手册

    外设驱动生成器V.1.03 用户手册

    外设驱动生成器V.1.03 用户手册
    发表于 04-26 20:05 0次下载
    外设驱动<b class='flag-5'>生成器</b>V.1.03 用户手册

    外设驱动生成器V.1.03 指导书

    外设驱动生成器V.1.03 指导书
    发表于 04-26 20:05 0次下载
    外设驱动<b class='flag-5'>生成器</b>V.1.03 指导书