如何正确使用MDK-ARM优化功能,以及优化之后带来的影响
本文原创首发在我的另外一个公众号『嵌入式专栏』。
原文:MDK-ARM各种优化选项详细说明、实际应用及拓展内容
许多朋友使用MDK-ARM很长时间,却不知它的优化选项到底该有什么用,或者说到底该如何使用。
本文围绕MDK-ARM优化选项,以及相关拓展知识(微库、实际应用、调试)进行讲述,希望对你今后开发项目有所帮助。
1总述
我们所指的优化,主要两方面:
代码大小(Size)
代码性能(运行时间)
在MDK-ARM中,优化相关的配置选项:
当然,如果选择编译器(AC5、AC6)不同,优化选项也有差异(下面讲述)。
举例:
某些项目MCU容量有限时,你除了修改代码(优化开支),同时你有必要使用优化选项。
某些项目(比如某算法)需要高效(最短时间)运行,此时有必要使用优化选项。
2优化选项说明
本节详细讲述优化相关选项,同时,编译器选择AC5和AC6时有差异,下面也会针对AC5和6分别讲述。
1.Use Cross-Module Optimization:使用跨模块优化
使用跨模块优化可以启用链接器反馈文件(进行两次编译),从而允许进一步的代码优化。
提示:
A.不针对库目标执行跨模块优化。
B.跨模块优化将增加构建项目所需的时间,因为会自动执行多个编译和链接步骤。
2.Use MicroLIB:使用微库
它是ISO标准C运行时库的子集(其中一部分),提供了性能和代码大小之间的权衡。
微库并不完全兼容ANSI,但对于大多数小型嵌入式应用程序来说已经足够了。
3.Use Link-Time Code Generation:使用链接时代码生成(优化)
在V5版本之前有这个优化选项,多文件编译,链接时进行优化:
函数跨模块内联
删除未引用的变量和函数
通过重新排列变量优化内存访问
在可能的情况下重用内存
4.Execute-only Code:生成只执行的代码
不包含未使用(函数、变量等)代码段。
仅限于:
C、Thumb代码
基于Cortex-M3、M4的处理器
编译器5.04以上
5.Optimize for Time:优化时间
以更大的代码大小为代价,减少执行时间。比如:使用内联函数。
编译器为AC6时,此选项为【Link-Time Optimization】,在链接状态下执行模块间优化。
6.Split Load and Store Multiple:分割加载和多存储
指示编译器将LDM和STM指令拆分为两个或多个LDM或STM指令,以减少延迟,此选项可以提高系统的总体性能。
7.The One ELF Section per Function:每个函数一个ELF段
ELF代码段通常包含许多函数的代码,此选项告诉编译器将所有函数放入它们自己的ELF段,这允许链接器删除未使用的ELF段(而不是未使用的函数)。
8.AC5时:Optimization优化选项
<default>:默认值,以优化性能为主。
Level 0 (-O0):关闭大部分优化,除了一些简单的转换,生成的代码具有最佳的调试视图。
Level 1 (-O1):应用受限优化。
比如:删除未使用的内联函数和静态函数,删除冗余代码和重新排序指令等。生成的代码经过合理优化,具有良好的调试视图。
Level 2 (-O2): 高度优化,目标代码到源代码的映射并不一定对应,因此,不利于调试。
Level 3 (-O3):最大级别优化,级别3与时间优化相结合可能生成比级别2更多的代码。
9.AC6时:Optimization优化选项
当编译器选择AC6时,优化选项有差异(有更多优化选项):
AC6优化选型中前面5项(default、-O0 ~ 3)和AC5的作用基本一样,但AC6多了三个选项。
-Ofast:启用-O3的所有优化,以及其他可能违反语言标准(严格遵守)的优化。
-Os balanced:平衡代码大小与代码速度。默认情况下,编译器执行优化以提高性能,但可能会增加image文件大小。
-Oz image size:优化代码大小。
3如何优化?
本节讲述三种编译优化,使其达到最优(代码最小、性能最好)
代码大小
代码性能(速度)
代码平衡(大小和速度)
1.优化代码大小
针对AC5编译器:
Use MicroLIB
Use Cross-module optimization
Optimization:level 2 (-O2)
针对AC6编译器:
Use MicroLIB
Optimization:-Oz image size
说明:
A.代码量大(ELF代码段通常包含许多函数的代码),可考虑使用The One ELF Section per Function选项减小代码。
B.AC6编译器改进了优化功能(可以理解为增加的3个选项集成了优化功能)。
代码优化大小(对比):
2.优化代码性能
针对AC5编译器:
Use Cross-module optimization
Optimization:level 3 (-O3)
Optimize for Time
针对AC6编译器:
Optimization:-Ofast
Link-Time Optimization
代码优化性能(对比):
3.代码平衡
这种情况下,在满足代码大小的同时,我们应尽量满足性能。
这里其实就是一个相关平衡的关系,结合上面两种优化方式根据自己实际情况出发,一般优化考虑如下配置。
针对AC5编译器:
Use Cross-module optimization
Optimization:level 3 (-O3)
Optimize for Time
针对AC6编译器:
Optimization:-Os balanced
Link-Time Optimization
当然,AC6中-Os balanced优化选项更智能。
4拓展说明
MDK-ARM的优化功能需要结合项目实际情况进行优化。对一些项目能起到很大帮助作用,但优化之后也可能带来一些影响。
1.使用高度优化(-O1以上),可能会影响Debug调试(因为优化之后,编译输出和实际代码不匹配)。
2.指定源文件/文件组优化
有些代码不需要优化,我们优化指定的源文件/文件组就行。
推荐阅读:Keil系列教程
5最后
我的知乎:strongerHuang
我的网站:www.strongerhuang.com
若觉得文章对你有帮助,随手点赞、分享,也是对我的支持和鼓励。
关注公众号『strongerHuang』,在底部菜单中查看更多精彩内容!
长按识别图中二维码关注
如何正确使用MDK-ARM优化功能,以及优化之后带来的影响相关推荐
- Keil MDK 编译器 AC5 和 AC6 优化选项重要内容和区别
关注.星标公众号,不错过精彩内容 整理:黄工 参考来源:Arm官网 使用过Keil MDK (Arm Compiler 6)编译器V6版本的读者应该发现了一个问题,V6版本速度比V5版本编译速度快很多 ...
- ARM嵌入式编译器编译优化选项 -O
Arm嵌入式编译器可以执行一些优化来减少代码量并提高应用程序的性能.不同的优化级别有不同的优化目标,不仅如此,针对某个目标进行优化会对其他目标产生影响.比如想减小生成的代码量,势必会影响到该代码的性能 ...
- MySQL的主动优化和被动优化_不要一把梭了,这才是SQL优化的正确姿式!|原创干货...
这是个人第83篇原创文章java 做者 | 王磊mysql 来源 | Java中文社群(ID:javacn666)web 转载请联系受权(微信ID:GG_Stone) 年少不知优化苦,遇坑方知优化难. ...
- 功能更新|DAS推出全局Workload优化功能,实现SQL自动诊断
简介:DAS推出了全局Workload优化功能,可以及时检测到数据库的负载变化,识别到新增SQL.执行变化的SQL以及性能不佳的SQL,并综合考虑SQL的执行频率和相关SQL信息,给出优化建议. 背景 ...
- 如何正确理解SEO优化与搜索引擎优化之间的关系
如果您从事SEO优化工作,或者有一些SEO知识,您就会知道SEO的含义--搜索引擎优化. 是的,大多数人都知道SEO是搜索引擎优化英文的缩写,专业从事搜索引擎优化的工作.但是,大多数人只了解,但不理解 ...
- 电商类产品搜索功能如何优化?
搜索功能对于电商类产品而言尤为重要,当用户带着明确的目的去搜索自己需要的产品时,却没有得到他想要的结果,这在很大程度上直接影响了用户对于产品的体验.本文作者结合自己的经验,来探讨关于电商类产品搜索功能 ...
- 精仿黑鱼资源网 整站源码带完整数据 带SEO优化功能带广告位
精仿黑鱼资源网源码带完整数据 带SEO优化功能带广告位 简介: 这款是黑鱼站长放出来的新版本,带资源和文章发布系统,非常有利于SEO,带大量广告位,对这款有兴趣的站长们 可以搭建体验! 安装教程: 空 ...
- V90 PN 伺服驱动器的一键自动优化功能_方法示例
V90 PN 伺服驱动器的一键自动优化功能_方法示例 首先,了解一下伺服系统的组成,如下图所示,电流环.速度环和位置环 重点: 伺服系统的调节要结合实际的电机机械负载. 对于V90伺服驱动器,支持手动 ...
- Android Studio 4.0 新功能与优化
1.前言 Android Studio又更新了,每次重大更新都给我们的生产力提升了一个台阶,当然也会带来神奇的bug,墙裂提醒各位小伙伴升级请慎重!!! [真香警告]Android Studio下载链 ...
- Android9.0 P 电源管理android各版本电量优化功能策略
针对电量优化android的改动 在最近几个android版本中已存在的电量优化功能基础上,Android 9 引入了一些新功能来持续改进设备电源管理,以确保将系统资源提供给最需要它们的应用. 近几个 ...
最新文章
- python统计特定类型文件数量_分享一些常见的Python编程面试题及答案
- Proguard returned with error code 1. See console
- MySQL 清理slowlog方法
- Jakarta EE中的规范范围
- ajax清请求过程,JS深入基础之Ajax的请求过程
- 中国锦鲤信小呆为兑奖曾刷爆信用卡、陷入焦虑?网友:但我仍想做锦鲤
- 图像处理基础(四)_图像分辨率、图像模式及通道讲解
- flink入门案例之WordCount
- IIS与ASP.NET Http Runtime Pipeline
- 使用 ssh-keygen访问服务器
- 大学计算机python基础课件,大学计算机python基础课件2015lecture03.pdf
- VMware虚拟机启动失败问题解决WMware-tray.exe无法正常启动
- 爬取京东某商品评论并存入csv
- 试图加载格式不正确的程序 0x8007000b
- 天龙八部手游服务器维护公告,天龙维护时间(天龙八部手游11月29日例行维护公告)...
- 重庆大学计算机信息管理基础2013,重庆大学计算机信息管理基础课程考试试卷B.doc...
- 谷歌浏览器如何正确安装第三方已被停用的扩展插件
- 【OSPF的特殊区域和特性】ospf的lsdb优化、特殊区域、路由汇总、静默接口、ospf报文认证、LSA路由汇总、高级特性(PRC、智能计时器、FRR、ospf database overflow)
- GPS涉及到的各种时间转换(年月日,年积日,儒略日,GPS周及周内日或周内秒,星期几)python
- MySQL教程——4 高级篇(性能调优、锁)
热门文章
- LeetCode 2359. 找到离给定两个节点最近的节点 基环树
- iOS学习一些资料的整理
- mysql 日志文件全是0,下面关于MySQL日志文件描述错误的是 (8.0分)
- 管理感悟:放下就是快乐
- 中国古典家具行业市场消费预测及投资风险分析报告2022-2027年
- USB总线-Linux内核USB3.0设备控制器复合设备之legacy方式分析(八)
- java 手机页面pdf显示不出来_PDF首次在Android上加载时显示为空
- Roku被严重低估了
- php使用zts,yum安装方式的php,切换NTS为ZTS版本
- Python使用基础之turtle绘图库使用基础