首页
论坛
博客
大讲堂
人才网
直播
资讯
技术文章
频道
登录
注册
MCU软件基准测试实用技巧:编译器优化能力评测指引
2021-12-14 19:01:53
IAR Systems
在MCU开发和应用中,工程师都需要进行MCU的能力
测试
,通用的做法是用Benchmark(基准)程序来
测试
。然而,在做基准
测试
时,编译器的优化能力也在
测试
结果中有较为明显的影响,同一套硬件平台,选用不同的编译器和不同的优化选项,可能得出的结果相差较大。
为了最大程度释放MCU的性能,在基准
测试
中取得最理想的结果,往往需要工程师不仅对自身的硬件比较了解,更需要深入了解编译器的优化原理,并灵活应用,才能在基准
测试
中发挥出MCU的全部性能。IAR Systems作为全球知名的嵌入式工具厂商,其编译器在优化能力上有独特的优势,MCU配合IAR的编译器往往能够得出较好的基准
测试
结果。
本文以已在MCU领域内广泛使用的IAR Embedded Workbench开发工具套件为例,来分享MCU软件基准
测试
应该注意的项目和以下技巧,从而帮助读者能够去生成业内最高效和最完备的代码。利用以下项目和设置,工程师可以精准调整优化等级,最大限度地进行
测试
和提升所开发和应用代码的性能。
选择
代码尺寸还是执行
速度
利用IAR Embedded Workbench等开发工具套件,工程师可以对整个工程范围或对单个文件设定优化级别和类型。在源代码中,甚至可以对单个函数使用 #pragma optimize 指令来完成此操作。
优化的目的是减少代码尺寸和提高执行速度。如果只能满足其中一个目标,编译器会根据用户指定的设置进行优先处理。因此,在实际的软件基准
测试
中,工程师可以尝试各种设置来获得最佳效果。举个例子,由于函数内联更侧重于执行速度的优化,相较于采用通用代码尺寸优化设置,采用函数内联与通用代码执行速度优化设置将获得更小的程序代码。
选择
小型
内存模型
为了能够充分地发挥MCU器件的性能和减少应用中的问题,软件开发必须充分考虑MCU器件的内存等资源限制,因此需要为目标器件和项目选择尽可能小的内存模型。
小型内存模型的优点包括:
更小尺寸的地址
更小尺寸的指令
更小尺寸的指针
效率更高
代码更少
诸如IAR Embedded Workbench这样的成熟的开发工具套件也集成了相关评估功能,可以对内存模型进行多方面评估,从而帮助工程师去
测试
软件的规模和优化设计。
选择合适的
运行时
库
默认情况下,运行时库是以最高代码尺寸优化级别进行编译的。如果您想要对速度进行优化,请考虑重新编译生成这些库。可以通过配置选项来设置某些标准库功能(如语言环境、文件描述符和多字节)最适合的级别。
根据具体需求,在库选项中选择 scanf 输入和 printf 的格式。默认选项并非最小格式。
使用正确的数据类型
数据类型与代码尺寸或者执行速度息息相关,因此需要利用开发工具来对数据类型进行观察和分析,以便找到适合硬件资源的类型。在IAR Embedded Workbench开发工具套件中,开发人员可以从以下几个方面着手进行
测试
和优化:
选择最适合您应用程序的的数据类型尺寸
尽量使用无符号字符型,这样就能执行位操作而不是算术操作
检查目标特定选项
检查能提高性能的目标特定选项,这在日常的MCU设计和应用开发中往往需要工程师具有相当的经验,但是通过使用诸如IAR Embedded Workbench这类成熟的开发工具套件则可以快速而完善地完成必要的性能检查:
高效的寻址模式——可实现高效的内存访问
使用特定的寄存器来处理常量/变量——代码在寄存器上的操作效率比在内存上更高
偶对齐函数入口——偶对齐指令可以提高速度
字节对齐对象——更小的存储空间需求,但可能生成更大的代码尺寸
使用基准
测试
相关
代码
所有的MCU开发工具都应该提供基准
测试
相关代码,但是成熟的通用开发工具的代码库都是这些提供商在相关领域经验的浓缩,因此更为全面和高效。其中的重要经验包括:
嵌入式系统的基准
测试
应该针对嵌入式程序的特点来设计。
实际的应用程序通常也适用于基准
测试
,但需要确保代码的可执行性。链接器会删除未引用的代码和变量,但并非所有的链接器都具备这种功能。
确保
测试
代码不受
测试
工具(
测试
相关函数)的影响。以下示例其实是对 printf() (
测试
相关函数)进行了基准
测试
。
比较链接后生成的代码。一款编译器可能会采用内联代码,而另一款编译器可能会调用库。
充分了解用于执行基准
测试
的应用代码!
总结
通过使用诸如IAR Embedded Workbench这类成熟的开发工具套件,发挥其在几十年全球性应用中行汇聚和迭代出的知识,MCU设计和应用开发工程师可以快速完成上述这些必要的性能
测试
,同时也可以进一步有针对性地发挥MCU的性能,从而实现目标器件最优化的、软硬件合一的功能。
关键词:
EETOP 官方微信
创芯大讲堂 在线教育
创芯老字号 半导体快讯
相关文章
上一篇:
大联大世平集团推出基于NXP产品的PEPS
下一篇:
Imagination Series3NX神经网络加速器
全部评论
最新资讯
消息称:三星7nm也将停供中国大陆!
拒绝认罪!华为要求美国法官驳回指控
大神出手!为日本打造芯片设计精英军团!
瑞萨与尼得科携手开发创新“8合1”概念验证
思特威4K超星光级图像传感器SC850SL荣获“
全球最畅销手机TOP10:中国仅一款上榜!
芯片成本飙升 国产手机现涨价潮!
台官员:禁止台积电在海外生产2nm芯片
艾迈斯欧司朗推出全新UV-C LED,提升UV-C
Melexis发布突破性Arcminaxis™位置感应技
最热资讯
将意图转化为行动:走进嵌入式语音控制的新
深圳:鼓励高端微控制器(MCU)、计算芯片
基础设施数字化正当时,兆易创新与信驰科技
德州仪器低功耗汽车微控制器为汽车应用提供
IAR嵌入式解决方案发布全新版本,增强云调
瑞萨推出全新RA8入门级MCU产品群, 提供极
从富士通到RAMXEED,以全新一代FeRAM迎接边
MIKROE推出世界上最大的嵌入式项目平台Embe
嵌入式FPGA IP正在发现更广阔的用武之地
大联大世平集团推出基于onsemi、NXP、安世