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

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

3天内不再提示

如何为嵌入式软件开发选择编译器

jf_pJlTbmA9 来源:jf_pJlTbmA9 作者:jf_pJlTbmA9 2023-07-14 15:26 次阅读

在过去数十年,摩尔定律一直支配着半导体的发展。随着MCU的性能越来越强,嵌入式产品也越来越智能嵌入式软件也变得越来越复杂。编译器作为嵌入式软件开发的基础工具,将程序员编写的源代码转换为底层硬件可以执行的机器指令。一款优秀的编译器既需要对程序进行优化,确保程序可以高效地运行,同时又需要保证转换的一致性。

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

嵌入式软件复杂性vs MCU硬件资源的有限性

嵌入式系统的应用范围日益扩大,从汽车、航空航天到智能家居等领域都有广泛应用。然而,随着嵌入式软件功能越来越复杂,软件复杂性也随之增加,这给嵌入式系统设计带来了很大的挑战。特别是在硬件资源有限的嵌入式系统中,软件复杂性与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)呈现出比其他工具小得多的变化程度,并且在不同芯片上均能产生最小的代码体积。

事实上,在CoreMark总共34个模块的30个中,IAR Embedded Workbench for Arm产生了更紧密的代码,总体体积差异约为20%。同样,我们在调研用户使用IAR Embedded Workbench for RX和IAR Embedded Workbench for RL78开发的真实应用案例时,发现生成的代码体积比GCC和其他工具小27%至 28%。

1685082564694574.png

生成的代码性能

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

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

1685082560353973.png

稳定性也至关重要

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

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

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

技术支持

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

如果免费工具有问题,例如编译器或库中的错误,用户唯一能做的就是试着自己解决,或者在相关的资源库中发布一个问题: https://gcc.gnu.org/faq.html#support

1685082555261518.png

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

1685082549617972.png

总结

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

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

责任编辑:彭菁

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

    关注

    5082

    文章

    19123

    浏览量

    305151
  • 软件开发
    +关注

    关注

    0

    文章

    614

    浏览量

    27358
  • 编译器
    +关注

    关注

    1

    文章

    1634

    浏览量

    49129
收藏 人收藏

    评论

    相关推荐

    招聘嵌入式软件开发编译器相关工程师

    本公司是大型国企,位于美丽的海滨城市珠海,为满足公司战略发展需求,特招聘嵌入式软件开发类岗位技术工程师,欢迎相关人士应聘。待遇优厚,具体可电话沟通或后续面谈。以下是岗位职责和要求。如有意向者可发
    发表于 03-23 00:01

    嵌入式软件开发与非嵌入式软件开发的区别?

    嵌入式软件开发与非嵌入式软件开发区别?设备驱动开发与裸机驱动开发区别?
    发表于 04-02 06:29

    嵌入式软件开发语言的相关资料推荐

    的,CPU和电脑不一样,所以编译器也是不一样的,生成的可执行程序也是不一样的。不同于一般形式的软件编程,基于特定的硬件平台嵌入式系统编程的,势必要求其编程语言具备较强的硬件直接操作能力。毫无疑问
    发表于 10-27 06:30

    什么是嵌入式软件开发

    嵌入式软件开发又是指什么?   随着嵌入式软件系统结构越来越复杂,嵌入式软件
    发表于 04-20 08:43 8782次阅读

    嵌入式软件开发与Embedded-GIS

    1.嵌入式软件开发 市场现状 嵌入式操作系统 嵌入式软件开发特点 嵌入式
    发表于 02-28 10:39 36次下载

    ARM嵌入式软件开发

    ARM嵌入式软件开发ARM嵌入式软件开发ARM嵌入式软件开发
    发表于 01-15 17:29 65次下载

    嵌入式交叉编译环境的搭建解析

    是不同版本的内核,都会用到不同的交叉编译器,而且,有些交叉编译器经常会有部分的bug,这都会导致最后的代码无法正常地运行。因此,选择合适的交叉编译器对于
    发表于 10-18 16:44 1次下载

    嵌入式软件开发的优势分析

    为什么当今嵌入式行业会如此受欢迎呢?我们从事嵌入式软件开发有什么好处吗?小编就来说说我的看法吧,嵌入式软件开发的优势我们可以从几点来看。
    的头像 发表于 12-21 15:23 5233次阅读

    关于做嵌入式软件开发和普通桌面软件开发的区别问题

    前几天别人问我做嵌入式开发和普通桌面开发有什么区别,当时回答的不全面,今天来总结一下:嵌入式开发在宿主机上编辑、编译程序,在目标机运行测试程序,称为交叉
    发表于 10-21 10:06 4次下载
    关于做<b class='flag-5'>嵌入式</b><b class='flag-5'>软件开发</b>和普通桌面<b class='flag-5'>软件开发</b>的区别问题

    嵌入式软件开发是什么? 

    嵌入式软件开发就是指在嵌入式操作系统下进行开发,包括在系统化设计指导下的硬件、软件以及综合研发。硬件研发通常指在EDA
    发表于 11-03 09:36 8次下载
    <b class='flag-5'>嵌入式</b><b class='flag-5'>软件开发</b>是什么? 

    嵌入式软件开发做什么?嵌入式开发培训学哪些

    嵌入式行业可以说从幕后走到前台,大家对他都很熟悉了,我国嵌入式人才缺口每年在50万左右,相关调查报告称嵌入式软件开发是未来几年最热门和最受欢迎的职业之一。但是还有很多人不知道
    发表于 11-03 10:36 19次下载
    <b class='flag-5'>嵌入式</b><b class='flag-5'>软件开发</b>做什么?<b class='flag-5'>嵌入式开发</b>培训学哪些

    嵌入式软件开发的特点、设计流程、嵌入式软件的结构

           嵌入式软件开发的特点、设计流程、嵌入式软件的结构 一:嵌入式软件开发的特点1.
    发表于 11-03 15:21 38次下载
    <b class='flag-5'>嵌入式</b><b class='flag-5'>软件开发</b>的特点、设计流程、<b class='flag-5'>嵌入式</b><b class='flag-5'>软件</b>的结构

    何为嵌入式软件开发选择编译器

    在过去数十年,摩尔定律一直支配着半导体的发展。随着MCU的性能越来越强,嵌入式产品也越来越智能,嵌入式软件也变得越来越复杂。编译器作为嵌入式
    的头像 发表于 04-06 14:59 874次阅读

    深入浅出编译优化选项(上)

    在前文 《 如何为嵌入式软件开发选择编译器》 中讲到编译器对于
    的头像 发表于 04-14 09:11 2271次阅读
    深入浅出<b class='flag-5'>编译</b>优化选项(上)

    嵌入式软件开发软件开发的区别

    嵌入式软件开发软件开发是两个不同的概念,它们在一些关键方面有着明显的区别。嵌入式软件开发是指开发
    的头像 发表于 01-22 15:27 2285次阅读