应对实际工程挑战如何为嵌入式软件开发选择编译器

来源:nba小九直播下载
发布时间:2024-08-01 23:54:02

...

  的基础工具,将程序员编写的源代码转换为底层硬件可以执行的机器指令。一款优秀的既需要对程序来优化,确保程序能高效地运行,同时又需要保证转换的一致性。

  因此,对于嵌入式系统研发人员来讲,在选择以编译器为核心的开发工具时,就必须要考虑一款编译器与其工程环境和项目需求的关系,从而通过“利其器”而“善其事”。本文将介绍一款优秀编译器应具备的一些特征,帮助嵌入式软件研发人员根据其工程需求来选择比较适合的编译器,最快和最好地完成其工程项目。

  嵌入式系统的应用场景范围日益扩大,从汽车、航空航天到智能家居等领域都有广泛应用。然而,随着嵌入式软件功能越来越复杂,软件复杂性也随之增加,这给嵌入式系统模块设计带来了很大的挑战。尤其是在硬件资源有限的嵌入式系统中,软件复杂性与MCU硬件资源之间的平衡变得很重要。

  一方面,随着软件功能的增加,软件复杂性持续不断的增加,这可能会引起代码变得庞大、难以维护。嵌入式软件需要对外部设备和传感器来控制和响应,同时还要实现复杂的算法和数据结构,这一些都会增加软件的复杂性。

  另一方面,嵌入式系统通常只具有有限的硬件资源,包括处理器速度、存储器容量和外设接口等。这些硬件资源的限制可能会限制系统的功能和性能。当软件复杂度增加时,可能会占用更多的硬件资源,因此导致系统性能直线下降或功能受限。此时,需要采用编译优化算法、数据结构和代码模块化等技术,以便在MCU硬件资源有限的情况下实现复杂的嵌入式软件功能。

  因此,在嵌入式系统模块设计中,软件复杂性和MCU硬件资源之间的平衡最重要。需要优化嵌入式软件的设计和实现,以确保系统的性能、稳定和成本的完整考量。采用有效的软件工程方法和工具,可以在硬件资源有限的情况下实现更复杂的嵌入式系统功能。编译器作为嵌入式软件开发中不可或缺的生产工具,承担从C/C++源码到目标二进制代码的高效转换职责,对其的选择对于嵌入式软件的开发极为重要。

  首先,优秀的编译器可以将C/C++源代码转换成体积更小的二进制代码,从而在给定的MCU中加入更多的功能。在嵌入式系统中,MCU的存储器资源通常是有限的,因此,如果代码越小,系统就能轻松实现更多的功能。此外,更小的代码体积也代表着更少的存储器占用,这能够更好的降低系统的成本。

  下面,我们通过CoreMark基准对市面上流行的MCU编译器输出的代码尺寸做多元化的分析。CoreMark基准是一个很好的参考,因为它试图纳入研发人员做的一些更常见的事情,如矩阵操作、CRC计算、列表处理(包括查找和排序)等等。因此,它为你提供了一个关于编译器能做什么的“真实世界”的比较,而且它还有防篡改机制,以确保编译器供应商不会通过“手工优化”CoreMark代码来作弊。可以访问EEMBC网站查找包含各种MCU和编译器组合的CoreMark基准。

  虽然CoreMark是一个速度基准,但得益于其广泛的方法,它也是一个很好的代码体积基准。在各种芯片上观察该基准测试的一个文件(coremark.c),不难发现,根据下图中显示的所使用的芯片,其体积有小幅的变化。IAR Embedded Workbench(图中为:ICCARM V7.70.1)呈现出比其他工具小得多的变化程度,并且在不同芯片上均能产生最小的代码体积。

  其次,性能卓越的编译器能够最终靠代码优化技术来提升代码执行速度。例如,编译器能够直接进行代码重排、内联函数和循环展开等优化操作,以提高代码的执行效率和性能。在嵌入式系统中,处理器的性能通常也是有限的,因此代码的执行速度很重要。通过提升代码执行速度,系统能更充分地利用处理器的性能,这可以让研发人员在不需要更高性能的处理器的情况下实现更高效的系统模块设计,同时节省系统成本。另外,高效的二进制代码一样能降低MCU的功耗,有助于提升产品的续航能力,从而使得产品在低功耗应用中更具竞争力。

  同样,我们通过CoreMark基准对市面上流行的MCU编译器输出的代码性能做多元化的分析。这里我们举例来自Nordic Semiconductor芯片的CoreMark基准测试数据。选用“极致性能”编译优化选项参数进行编译时,IAR Embedded Workbench for Arm确实远超其他工具。如下表所示,从这些基准测试中,能够正常的看到IAR Embedded Workbench比Keil工具链高出19.1%,比GCC工具链高出惊人的29.8%。建议在CoreMark网页上查看当前最新的分数。也能自己运行基准测试以获得精确的数字。

  另外,编译器编译输出的稳定性也至关重要。如果编译器的输出不稳定,那么在相同的源代码上编译可能会得到不同的结果,从而使得嵌入式系统在不同的环境中表现出不一致的行为。这将对系统的可靠性和稳定能力产生负面影响,并且可能会导致系统的错误行为,从而增加项目时间和成本。因此,编译器必须确保其输出的结果是可靠和可重复的,以确保系统的稳定性和可靠性。

  相对于开源编译器工具,IAR Embedded Workbench作为商用编译器工具的领导者,拥有资深的专业方面技术团队和严格的品控流程,在发布版本之前会经过严格的测试和审核过程,确保其在各种情况下都能稳定运行。

  除此之外,对于有功能安全产品需求的用户,IAR Embedded Workbench高质量编译器通过了由TÜV SÜD认证的功能安全认证,涵盖了工业(IEC 61508),汽车(ISO 26262)等10种不一样的种类的功能安全标准,能够在一定程度上帮助用户加快功能安全认证,加速产品上市。

  最后,也是很重要的一点是用户是否能快速有效的获得技术上的支持。尽管编译器的性能和稳定能力都很优秀,但若用户在使用时遇上问题并且不能获得及时的技术上的支持,这将使用户的使用体验下降,项目开发延期,甚至使用户产品无法按时交付。因此,能否提供及时的技术上的支持也是用户选择编译器的一个很重要的考量因素。

  如果免费工具有问题,例如编译器或库中的错误,用户唯一能做的就是试着自己解决,或者在相关的资源库中发布一个问题。

  为避免整个开发团队因为开发工具的问题而停止工作,是使用IAR等商用专业开发工具的最大原因之一。除此之外,IAR在世界各地都有当地的支持团队,IAR中国技术上的支持团队直接为国内客户提供高效的本地技术上的支持服务。(见下图)

  一款优秀的编译器可以将源代码转换成高效、稳定、优化的二进制代码,使得嵌入式系统能够在有限的硬件资源下实现复杂的功能和卓越的性能。选择一款适合特定平台、性能卓越、稳定可靠、并提供优质技术支持的编译器对于嵌入式软件开发来说是至关重要的。

  IAR拥有资深的编译器技术团队,深耕编译器产品开发40余年,为用户更好的提供业界领先、性能卓越的编译工具链。IAR中国的技术上的支持团队时刻准备着为国内用户更好的提供高效、专业的技术上的支持,为嵌入式应用开发者保驾护航。

  Microchip推出具有灵活许可选项的MPLAB XC-DSC编译器,进一步扩展开发生态系统

  IAR嵌入式解决方案发布全新版本,增强云调试和仿真功能,推动下一代嵌入式软件开发

  Microchip推出具有灵活许可选项的MPLAB® XC-DSC编译器, 进一步扩展开发生态系统

  《Keil Software –Cx51 编译器用户手册 中文完整版》(403页)

  下一篇:消息称三星半导体将减少 10% 晶圆投片量,EUV 产线成重灾区