广告

MCU软件基准测试实用技巧:编译器优化能力评测指引

2021-12-14 14:54:54 IAR Systems 阅读:
本文以在MCU领域内广泛使用的IAR Embedded Workbench开发工具套件为例,来分享MCU软件基准测试应该注意的项目和以下技巧,从而帮助读者能够去生成业内最高效和最完备的代码。

在MCU开发和应用中,工程师都需要进行MCU的能力测试,通用的做法是用Benchmark(基准)程序来测试。然而,在做基准测试时,编译器的优化能力也在测试结果中有较为明显的影响,同一套硬件平台,选用不同的编译器和不同的优化选项,可能得出的结果相差较大。Ldeednc

为了最大程度释放MCU的性能,在基准测试中取得最理想的结果,往往需要工程师不仅对自身的硬件比较了解,更需要深入了解编译器的优化原理,并灵活应用,才能在基准测试中发挥出MCU的全部性能。IAR Systems作为全球知名的嵌入式工具厂商,其编译器在优化能力上有独特的优势,MCU配合IAR的编译器往往能够得出较好的基准测试结果。Ldeednc

本文以已在MCU领域内广泛使用的IAR Embedded Workbench开发工具套件为例,来分享MCU软件基准测试应该注意的项目和以下技巧,从而帮助读者能够去生成业内最高效和最完备的代码。利用以下项目和设置,工程师可以精准调整优化等级,最大限度地进行测试和提升所开发和应用代码的性能。Ldeednc

Ldeednc

选择代码尺寸还是执行速度

利用IAR Embedded Workbench等开发工具套件,工程师可以对整个工程范围或对单个文件设定优化级别和类型。在源代码中,甚至可以对单个函数使用 #pragma optimize 指令来完成此操作。Ldeednc

优化的目的是减少代码尺寸和提高执行速度。如果只能满足其中一个目标,编译器会根据用户指定的设置进行优先处理。因此,在实际的软件基准测试中,工程师可以尝试各种设置来获得最佳效果。举个例子,由于函数内联更侧重于执行速度的优化,相较于采用通用代码尺寸优化设置,采用函数内联与通用代码执行速度优化设置将获得更小的程序代码。Ldeednc

Ldeednc

选择小型内存模型

为了能够充分地发挥MCU器件的性能和减少应用中的问题,软件开发必须充分考虑MCU器件的内存等资源限制,因此需要为目标器件和项目选择尽可能小的内存模型。小型内存模型的优点包括:Ldeednc

  • 更小尺寸的地址
  • 更小尺寸的指令
  • 更小尺寸的指针
  • 效率更高
  • 代码更少

诸如IAR Embedded Workbench这样的成熟的开发工具套件也集成了相关评估功能,可以对内存模型进行多方面评估,从而帮助工程师去测试软件的规模和优化设计。Ldeednc

选择合适的运行时

默认情况下,运行时库是以最高代码尺寸优化级别进行编译的。如果您想要对速度进行优化,请考虑重新编译生成这些库。可以通过配置选项来设置某些标准库功能(如语言环境、文件描述符和多字节)最适合的级别。Ldeednc

根据具体需求,在库选项中选择 scanf 输入和 printf 的格式。默认选项并非最小格式。Ldeednc

Ldeednc

Ldeednc

使用正确的数据类型

数据类型与代码尺寸或者执行速度息息相关,因此需要利用开发工具来对数据类型进行观察和分析,以便找到适合硬件资源的类型。在IAR Embedded Workbench开发工具套件中,开发人员可以从以下几个方面着手进行测试和优化:Ldeednc

  • 选择最适合您应用程序的的数据类型尺寸
  • 尽量使用无符号字符型,这样就能执行位操作而不是算术操作

Ldeednc

检查目标特定选项

检查能提高性能的目标特定选项,这在日常的MCU设计和应用开发中往往需要工程师具有相当的经验,但是通过使用诸如IAR Embedded Workbench这类成熟的开发工具套件则可以快速而完善地完成必要的性能检查:Ldeednc

  • 高效的寻址模式——可实现高效的内存访问
  • 使用特定的寄存器来处理常量/变量——代码在寄存器上的操作效率比在内存上更高
  • 偶对齐函数入口——偶对齐指令可以提高速度
  • 字节对齐对象——更小的存储空间需求,但可能生成更大的代码尺寸

使用基准测试相关代码

所有的MCU开发工具都应该提供基准测试相关代码,但是成熟的通用开发工具的代码库都是这些提供商在相关领域经验的浓缩,因此更为全面和高效。其中的重要经验包括:Ldeednc

  • 嵌入式系统的基准测试应该针对嵌入式程序的特点来设计。
  • 实际的应用程序通常也适用于基准测试,但需要确保代码的可执行性。链接器会删除未引用的代码和变量,但并非所有的链接器都具备这种功能。
  • 确保测试代码不受测试工具(测试相关函数)的影响。以下示例其实是对 printf() (测试相关函数)进行了基准测试。

Ldeednc

  • 比较链接后生成的代码。一款编译器可能会采用内联代码,而另一款编译器可能会调用库。
  • 充分了解用于执行基准测试的应用代码!

总结

通过使用诸如IAR Embedded Workbench这类成熟的开发工具套件,发挥其在几十年全球性应用中行汇聚和迭代出的知识,MCU设计和应用开发工程师可以快速完成上述这些必要的性能测试,同时也可以进一步有针对性地发挥MCU的性能,从而实现目标器件最优化的、软硬件合一的功能。Ldeednc

  • 微信扫一扫
    一键转发
  • 最前沿的电子设计资讯
    请关注“电子技术设计微信公众号”
  • 立足优势 持续领先:KIOXIA铠侠新一代UFS嵌入式闪存器 KIOXIA铠侠中国近日宣布,今年其最新发布的业界首款*1支持MIPI M-PHY*2 v5.0的通用闪存*3Universal Flash Storage嵌入式闪存器件,目前已率先批量交货,助力本土手机产商实现存储速度飞跃。
  • 低功耗“刚需”加速物联网应用落地,用独特MCU设计的省 低功耗MCU涉及的关键技术和设计挑战非常多,从如何定义系统架构、构建平台和MCU生态系统到数字电路设计,从工艺的选择到模拟电路设计,从可靠性设计到低功耗设计,从应用创新到满足客户各种需求等,每方面都对设计公司提出很高要求……
  • 车载充电器设计对专用MCU提出需求 电动汽车系统提出了必须通过量身定制的解决方案来解决的独特挑战。这在MCU的选择上很清楚。传统的汽车MCU,例如为ICE车辆的动力系统所设计的那些MCU,并不是为支持电动化设计要求所需的基本数字、模拟和系统级功能而设计的。例如,大多数传统的汽车MCU无法支持高开关频率来获得宽禁带技术的优势。
  • 大联大世平集团推出基于灵动微电子MindMotion产品的低 大联大控股宣布,其旗下世平推出基于灵动微电子(MindMotion)MM32SPIN560C的低压无刷电机驱动方案。
  • 意法半导体生物识别支付平台获EMVCo 认证,有助于机构 意法半导体完整的技术平台获得行业认证,整合嵌入式安全单元和超低功耗通用微控制器,具有经济、强大的安全保护功能
  • 如何设计电池管理系统 我们可以用电池管理系统(BMS)监控电池和可能的故障情况,防止电池出现性能下降、容量衰减甚至可能损害用户或周围环境的情况。BMS还负责提供准确的充电状态(SoC)和健康状态(SoH)估计,以确保在电池的整个生命周期内提供信息丰富且安全的用户体验。设计合适的BMS不仅从安全的角度来看至关重要,而且对于客户满意度也很重要。
  • MCU三大新型存储器技术梳理 目前越来越多的MCU厂商选择将新型的存储器集成在MCU中,从而突破传统闪存技术的限制,使MCU性能水平达到一个新的高度。
  • 为AI SoC打造芯片级安全性 使用内置于RISC-V架构的固有特性以及附加扩展,有助于从芯片级另外增加一个分层,从而确保AI SoC的安全性…
  • 可穿戴设备设计关键在于数据准确性和算法有效性 本文分享了ADI在可穿戴领域的一些理解和思考,分为三个部分:一是可穿戴广义设备的市场趋势,包括“卷中卷的卷王”TWS耳机、AR/VR和智能手表;二是可穿戴产品解析;三是想做到差异化,数据和算法到底扮演着什么样的角色。
  • 电动汽车中的电力电子技术概述 高效率和高可靠性是促进电力电子系统分析和设计的两个关键特性。
  • AI 超级计算机,人工智能进入企业的拐点 正如英伟达加速计算业务副总裁Ian Buck所说:“我们正处于一个 AI 进入企业的转折点。”
  • 裸机系统上的模拟调试 我承认“模拟调试”这个标题有点神秘。阅读本文后,嵌入式固件开发人员可能会遭受认知失调的困扰,但相信我,这以后会说得通的。本标题暗示的是处理MCU中被处理信号的任务。
广告
热门推荐
广告
广告
EE直播间
在线研讨会
广告
广告
面包芯语
广告
向右滑动:上一篇 向左滑动:下一篇 我知道了