Keil MDK 编译器 AC5 和 AC6 优化选项重要内容和区别
关注、星标公众号,不错过精彩内容
整理:黄工
参考来源:Arm官网
使用过Keil MDK (Arm Compiler 6)编译器V6版本的读者应该发现了一个问题,V6版本速度比V5版本编译速度快很多。
(说明:是V6版本编译器,不是V6版本MDK)
那你发现了Arm Compiler V6和V5有什么区别吗? 集成在MDK中的优化选项又有哪些区别?
一、关于Arm Compiler 6
Arm Compiler 6(简称AC6)是用于Arm处理器的编译工具链,目前最新版本:Arm Compiler V6.14。
用于编译Coterx-M处理器的编译器很多,Arm Compiler就是其中一个,常用于Keil MDK、 Arm Development Studio(DS-5)中,还可用作独立工具链安装。
当然,除了Arm Compiler,针对Coterx-M的编译器还有很多,比如:GNU Compiler、 IAR Compiler、 CCS Compiler等。
Arm Compiler 6工具链包括:
armclang:基于LLVM和Clang技术的编译器和集成汇编器。
armasm:armasm语法汇编代码的旧版汇编程序。将armclang集成汇编程序用于所有新的汇编文件。
armar:使ELF目标文件集可以一起收集。
armlink:将对象和库组合在一起以生成可执行文件的链接器。
fromelf:镜像转换程序和反汇编程序。
Arm C libraries:嵌入式系统的运行时支持库。
Arm C ++libraries:基于LLVM libc++项目的库。
ARM Compiler 5(和更早版本)使用armcc编译器,而ARM Compiler 6将armcc替换为armclang,armclang基于LLVM,它具有不同的命令行参数、指令等,因此算是一个新的编译器。
更多参考内容和地址:
编译器Clang会代替GCC吗?
http://www2.keil.com/mdk5/compiler/6/
https://developer.arm.com/tools-and-software/embedded/arm-compiler/downloads/version-6
二、AC5和AC6
Arm Compiler 5(AC5)算是用的比较多的一代编译器,在Keil MDK V4版本及V5早期的版本都是使用AC5。
在2015年的时候,AC6发布了,并在随后新版本的MDK中集成了AC6,直到现在最新版本的MDK集成了AC6.13(可以修改版本):
AC6相比AC5优势
AC6相比之前版本的编译器做了很多改动,大家最为直观的感受就是编译速度提高了很多,还有代码大小。
当然除了速度和大小,还有其他很多优势,比如:支持C ++ 14标准、使用TrustZone for Armv8-M为设备创建安全和非安全代码、兼容基于GCC创建的源代码,也就是GCC可以编译的源码它也能编译。
这是官方提供的代码大小对比:
AC5升级到AC6
AC5和AC6是不同的编译器,兼容性方面还是有差异,需要迁移。这个迁移过程官方提供有文档:
https://developer.arm.com/docs/100068/0614/migrating-from-arm-compiler-5-to-arm-compiler-6
当然,也可以参看我之前分享的文章:
MDK-ARM编译器从V5升级到V6需要做哪些工作?
相关视频:
三、Keil MDK 优化选项
在Keil MDK中,相比AC5,使用AC6会增加几个优化选项:代码大小、速度、平衡等。
优化选项包含:
优化级别-O0
-O0
禁用所有优化。此优化级别是默认设置。使用-O0
结果可以加快编译和构建时间,但比其他优化级别生成的代码要慢。与-O0
其他优化级别相比,代码大小和堆栈使用率明显更高 。生成的代码与源代码紧密相关,但是生成的代码量更大,包括无用的代码。
优化级别-O1
-O1
在编译器中启用核心优化。此优化级别提供了良好的调试体验,并具有比-O0
更好的代码质量,堆栈使用率也提高了。Arm建议使用此选项以获得良好的调试体验。
-O1
与-O0
相比,使用时的区别是:
启用优化,这可能会降低调试信息的完整度。
启用了内联和尾调用,这意味着回溯可能无法提供打开功能激活的堆栈。
不会调用没有使用,或没有预期调用的函数,代码量更小。
变量的值在不使用后可能在其范围内不可用。例如,它们的堆栈位置可能已被重用。。
优化级别-O2
-O2
与-O1
相比,有更高的性能优化。增加了一些新的优化,并更改了优化的启发式方法。这是编译器可能生成矢量指令的第一个优化级别。它还会降低调试体验。
-O2
与-O1相比使用时的差异是:
编译器认为内联调用站点可获利的阈值可能会增加。
执行的循环展开数量可能会增加。
可以为简单循环和独立标量运算的相关序列生成矢量指令。
可以使用armclang命令行选项禁止创建矢量指令-fno-vectorize
。
优化级别-O3
-O3
与-O2相比,有更高的性能优化。此优化级别允许进行需要大量编译时分析和资源的优化,并且与-O2相比更改了优化的启发式方法。-O3
指示编译器针对生成的代码的性能进行优化,而忽略生成的代码的大小,这可能会导致代码大小增加。
-O3
与-O2相比使用时的差异是:
编译器认为内联调用站点是有利可图的阈值增加。
执行的循环展开量增加。
在编译器管道中启用更积极的指令优化。
优化级别-Os
-Os
目的是在不显着增加代码大小的情况下提供高性能。根据你的应用程序,提供的性能可能类似于 -O2
或-O3
。
-Os
与-O3相比,可减少代码大小。但会降低调试体验。
-Os
与-O3相比使用时的差异是:
降低编译器认为内联调用站点可获利的阈值。
显着降低了执行的循环展开量。
优化级别-Oz
-Oz
目的是提供尽可能小的代码量。Arm 建议使用此选项以获得最佳代码大小。此优化级别会降低调试体验。
-Oz
与-Os相比使用时的差异是:
编译器仅针对代码大小进行优化,而忽略性能优化,这可能会导致代码变慢。
未禁用功能内联。在某些情况下,内联可能会整体上减少代码大小,例如,如果一个函数仅被调用一次。仅当预期代码大小会减小时,才将内联启发式方法调整为内联式。
禁用可能会增加代码大小的优化,例如循环展开和循环矢量化。
循环是作为while循环而不是do-while循环生成的。
优化级别-Ofast
-Ofast
从级别执行优化,包括使用 -ffast-math
armclang选项执行的优化。
该级别还执行其他进一步的优化,可能会违反严格遵守语言标准的要求。
与-O3相比,该级别会降低调试体验,并可能导致代码大小增加。
优化级别-Omax
-Omax
是最大程度的优化,并专门针对性能优化。它支持从级别进行的所有优化,以及链接时间优化(LTO)。
在此优化级别上,Arm Compiler可能会违反严格遵守语言标准的规定。使用此优化级别可获得最快的性能。
与-Ofast相比,该级别会降低调试体验,并可能导致代码大小增加。
如果你使用-Omax进行编译,并具有单独的编译和链接步骤,你还必须在armlink命令行中包括-Omax。
以上是关于编译器的相关内容和比较,希望对大家有帮助。更多关于Keil的内容,可以在后台回复“Keil系列教程”。
‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧ END ‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧
推荐阅读:
精选汇总 | 目录 | 搜索
单片机系统EMC测试和故障排除
【Linux系统编程】IO标准缓冲区
关注微信公众号『strongerHuang』,后台回复“1024”查看更多内容,回复“微信”可添加我微信。
长按前往图中包含的公众号关注
Keil MDK 编译器 AC5 和 AC6 优化选项重要内容和区别相关推荐
- IMXRT10xx MDK 编译器AC5 升级AC6
1.更换编译器为AC6 2.产生链接信息,可以gotodef 3.更改编译配置 4.修改分散加载文件(重点) 修改分散加载文件第一行 #!armclang --target=arm-arm-none- ...
- Keil MDK使用编译器AC5与AC6生成浏览信息的差异
关注+星标公众号,不错过精彩内容 作者 | strongerHuang 微信公众号 | 嵌入式专栏 很多使用过Keil MDK的工程师都发现了一个问题,Keil MDK编译代码的时候,速度很慢. 编译 ...
- 【软件入门】Keil:从AC5到AC6
Keil:从AC5到AC6 前一阵安装了新版本的Keil,搭配CubeMX使用没有出现什么问题.但是今天查看以前代码的时候发现了一个很尴尬的问题,编译莫名其妙会出现很多问题.先把问题复现一下,在后面会 ...
- 网站SEO优化 站内优化和站外优化的具体内容和区别
随着互联网的发展,越来越多的企业开始意识到网络营销的重要性.对于想要在互联网上获得更多曝光和流量的企业来说,搜索引擎优化(SEO)已经成为一种非常有效的方式.在SEO中,站内优化和站外优化是两个非常重 ...
- keil MDK编译器警告和错误详解(不定期更新)
工作后从单片机转成ARM,刚开始用ADS1.2编译器,用了一段时间,因为我接手的项目的老程序正是用ADS编译的,部门也大都在用.在学单片机的时候用的是keil c51编译器,ads和这个编译器在易用性 ...
- Keil MDK编译器(V4.03)与J-LINK使用
前几天进手了一个J-LINK,因为H-JTAG毕竟对MDK支持的不是太完美,比如用keil mdk上面的下载按钮烧录程序,不是直接就能烧录进去,而是弹出H-Flash软件,再手工选择文件烧录:而且用H ...
- LLVM代码空间优化(一) 编译器自带的优化选项
最近项目组遇到编译安全固件,超出了r52安全核SRAM自带空间问题.急需要找寻方法优化代码体积(代码段大小+数据段大小+stack+bss段)方法,目前初步分析只有代码段&数据段有优化的可能, ...
- keil MDK编译器警告和错误详解
1.warning: #550-D: variable 'd' was set but never used 描述:变量'd'定义但从未使用,或者是,虽然这个变量你使用了,但编译器认为变量d所在的语 ...
- Keil MDK 5.30来了,编译性能优化,快速入门Cortex-M55
关注.星标公众号,不错过精彩内容 素材来源:Arm Keil 编辑整理:strongerHuang 早在ARM推出Cortex-M55内核的时候,就放出来一些关于Keil MDK V5.30的消息:C ...
最新文章
- 力扣(LeetCode)刷题,简单题(第13期)
- 扩增子分析解读3格式转换,去冗余,聚类
- MobileNet_v2
- 2011年9月计算机C语言真题,2011年9月全国计算机二级C语言考试真题及答案.doc
- labview如何加载库_迈德威视工业相机LabView 开发指导
- XCTF-MISC-新手区:stegano
- django 怎么加权限 静态资源目录_Django1.7如何配置静态资源访问
- C++,string类的指针,string类数组的指针 string *s
- 2017-2018-1 20155227 《信息安全系统设计基础》第四周学习总结
- 数据结构知识点大汇总(三)
- 佳能MP259打印重影的问题始终无法得到彻底解决,今天终于找到方法了
- Cache之直接映射
- logisim基础(非常基础)----寄存器元件的使用
- NRF52840 BLE OTA
- 2022-2027年中国智能硬件行业市场深度分析及发展战略规划报告
- 关于Java的点点滴滴(1)——Static关键字
- python编程心得体会800字_学习python的心得体会
- 年金系数用计算机怎么算,年金系数是什么?怎么计算?
- CC00009.python——|HadoopPython.v09|——|Arithmetic.v09|语法:核心语法运算符.V1|
- 区块链塔防游戏NFT游戏开发