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

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

3天内不再提示

如何正确使用MDK-ARM优化功能, 以及优化之后带来的影响

黄工的嵌入式技术圈 ? 来源:黄工的嵌入式技术圈 ? 作者:黄工的嵌入式技术 ? 2020-02-28 15:17 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

许多朋友使用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优化选项:默认值,以优化性能为主。 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系列教程

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

    关注

    134

    文章

    9374

    浏览量

    378777
  • 代码
    +关注

    关注

    30

    文章

    4906

    浏览量

    71030
  • MDK
    MDK
    +关注

    关注

    4

    文章

    211

    浏览量

    32803
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    MySQL 8.0性能优化实战指南

    作为一名运维工程师,MySQL数据库优化是我们日常工作中最具挑战性的任务之一。MySQL 8.0作为当前主流版本,在性能、安全性和功能上都有了显著提升,但如何充分发挥其潜力,仍需要我们掌握正确
    的头像 发表于 07-24 11:48 ?188次阅读

    VirtualLab:光栅的优化与分析

    光栅是光学工程师使用的最基本的工具。为了设计和分析这类组件,快速物理光学建模和设计软件VirtualLab Fusion为用户提供了许多有用的工具。其中包括参数优化,以轻松优化系统,以及参数运行,它
    发表于 05-23 08:49

    OCAD应用:凸轮曲线的优化设计

    的组分数,比如含有一个前固定组、一个变焦组、一个补偿组以及一个固定组的变焦系统被称为三组分变焦系统。为保证各活动组分在变焦过程中按设计要求移动活动组分,保证其表面间隔尺寸,一般都使用凸轮结构驱动各组
    发表于 05-16 08:50

    OCAD应用:凸轮曲线的优化设计

    的组分数,比如含有一个前固定组、一个变焦组、一个补偿组以及一个固定组的变焦系统被称为三组分变焦系统。为保证各活动组分在变焦过程中按设计要求移动活动组分,保证其表面间隔尺寸,一般都使用凸轮结构驱动各组
    发表于 03-04 10:08

    VirtualLab Fusion应用:参数优化文档介绍

    局部优化算法和一种全局优化算法。 参数优化文档 可以为光学装置生成参数优化文档,该光学装置通过探测器或分析仪输出要优化的数字。 参数
    发表于 02-28 08:44

    嵌入式系统中的代码优化与压缩技术

    ,可能会在数据采集、处理以及无线传输过程中消耗过多电量,导致电池寿命大幅缩短,频繁更换电池不仅给用户带来不便,也增加了使用成本。通过代码优化,减少不必要的计算和内存访问,可显著提升该节点的运行效率
    发表于 02-26 15:00

    MPLS网络性能优化技巧

    )均支持MPLS功能,并且配置正确。不兼容的设备可能会导致性能瓶颈或网络故障。 硬件升级 :如果网络设备性能成为瓶颈,考虑升级到性能更高的设备,以支持更大的网络流量和更复杂的网络拓扑。 二、优化路由协议 选择合适的路由协议 :如
    的头像 发表于 02-14 17:09 ?996次阅读

    FRED应用:LED发光颜色优化

    。第四个无光线追迹面用于优化后的颜色对比。 优化变量 优化的第一步涉及到变量的定义,本例中,优化3个LED光源的光功率。因为没有对应的光源功率优化
    发表于 01-17 09:39

    FRED应用:LED发光颜色优化

    。第四个无光线追迹面用于优化后的颜色对比。 优化变量 优化的第一步涉及到变量的定义,本例中,优化3个LED光源的光功率。因为没有对应的光源功率优化
    发表于 01-07 08:51

    HVAC网关设计优化以及通用逻辑和电压转换用例

    电子发烧友网站提供《HVAC网关设计优化以及通用逻辑和电压转换用例.pdf》资料免费下载
    发表于 09-24 11:24 ?0次下载
    HVAC网关设计<b class='flag-5'>优化</b><b class='flag-5'>以及</b>通用逻辑和电压转换用例

    TI Arm内核三角函数的优化

    电子发烧友网站提供《TI Arm内核三角函数的优化.pdf》资料免费下载
    发表于 09-11 09:19 ?1次下载
    TI <b class='flag-5'>Arm</b>内核三角函数的<b class='flag-5'>优化</b>

    keil软件实现编程仿真需要哪些步骤

    Keil MDK-ARM 是一款广泛使用的集成开发环境(IDE),专为 ARM Cortex-M 微控制器编程而设计。它提供了代码编辑、编译、链接、调试和仿真等功能。 1. 安装 Keil
    的头像 发表于 09-02 10:28 ?2589次阅读

    keil5怎么利用sys进行配置ti环境

    以下是一些关键步骤和建议: 安装Keil MDK-ARM: 首先,您需要从Keil官方网站下载并安装Keil MDK-ARM。这是一个集成开发环境(IDE),专为ARM Cortex-M微控制器
    的头像 发表于 09-02 10:19 ?1398次阅读

    keil5怎么给ti烧录程序

    安装Keil MDK-ARM软件: 访问Keil官方网站(https://www.keil.com/)并下载Keil MDK-ARM软件。 安装软件并激活您的许可证。 创建新项目: 打开Keil
    的头像 发表于 09-02 10:18 ?2664次阅读

    优化 FPGA HLS 设计

    ,可以通过使用 FPGA 工具设置优化设计本身来最大限度地减少性能损失。 高效找到正确的FPGA工具设置 尽管设计人员知道 FPGA 工具设置的存在,但这些设置往往没有
    发表于 08-16 19:56