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

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

3天内不再提示

Keil MDK优化选项说明

Dp1040 来源:嵌入式专栏 2023-11-20 10:21 次阅读

最近,看到群里的小伙伴在讨论【我的代码不按照流程执行】相关的话题。这类问题,有经验的工程师肯定能想到是什么原因导致的,那就是编译器把你代码优化了。

本文将围绕Keil MDK优化选项,以及相关拓展知识(微库、实际应用、调试)进行讲述,希望能对你的项目开发有所帮助。

一、概 述

我们所指的优化,主要包括两个方面:

代码大小(Size)

代码性能(运行时间)

在MDK-ARM中,优化相关的配置选项:

868aae92-8745-11ee-939d-92fbcf53809c.png

869512a6-8745-11ee-939d-92fbcf53809c.jpg

当然,如果选择编译器(AC5、AC6)不同,优化选项也有差异(下面讲述)。

举个例子:

某些项目MCU容量有限时,你除了修改代码(优化开支),同时你有必要使用优化选项。

某些项目(比如某算法)需要高效(最短时间)运行,此时有必要使用优化选项。

二、优化选项说明

本节详细讲述了优化相关选项,同时,编译器选择AC5和AC6时有差异,下面也会针对AC5和6分别讲述。

1、Use Cross-Module Optimization:使用跨模块优化

使用跨模块优化可以启用链接器反馈文件(进行两次编译),从而允许进一步的代码优化。

提示:

不针对库目标执行跨模块优化;

跨模块优化将增加构建项目所需的时间,因为会自动执行多个编译和链接步骤。

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时,优化选项有差异(有更多优化选项):

869f0130-8745-11ee-939d-92fbcf53809c.jpg

AC6优化选型中前面5项(default、-O0 ~ 3)和AC5的作用基本一样,但AC6多了三个选项。

-Ofast:启用-O3的所有优化,以及其他可能违反语言标准(严格遵守)的优化。

-Os balanced:平衡代码大小与代码速度。默认情况下,编译器执行优化以提高性能,但可能会增加image文件大小。

-Oz image size:优化代码大小。

三、如何优化?

本节讲述三种编译优化,使其达到最优(代码最小、性能最好):

代码大小

代码性能(速度)

代码平衡(大小和速度)

1、优化代码大小

针对AC5编译器:

Use MicroLIB

Use Cross-module optimization

Optimization:level 2 (-O2)

针对AC6编译器:

Use MicroLIB

Optimization:-Oz image size

说明:

代码量大(ELF代码段通常包含许多函数的代码),可考虑使用The One ELF Section per Function选项减小代码。

AC6编译器改进了优化功能(可以理解为增加的3个选项集成了优化功能)。

代码优化大小(对比):

86a5d80c-8745-11ee-939d-92fbcf53809c.png

2、优化代码性能

针对AC5编译器:

Use Cross-module optimization

Optimization:level 3 (-O3)

Optimize for Time

针对AC6编译器:

Optimization:-Ofast

Link-Time Optimization

代码优化性能(对比):

86b487f8-8745-11ee-939d-92fbcf53809c.png

3、代码平衡

这种情况下,在满足代码大小的同时,我们应尽量满足性能。

这里其实就是一个相关平衡的关系,结合上面两种优化方式根据自己实际情况出发,一般优化考虑如下配置。

针对AC5编译器:

Use Cross-module optimization

Optimization:level 3 (-O3)

Optimize for Time

针对AC6编译器:

Optimization:-Os balanced

Link-Time Optimization

当然,AC6中-Os balanced优化选项更智能

四、拓 展

Keil MDK的优化功能需要结合项目实际情况进行优化。对一些项目能起到很大帮助作用,但优化之后也可能带来一些影响。

比如,使用高度优化(-O1以上),可能会影响Debug调试(因为优化之后,编译输出和实际代码不匹配)。

还有,指定源文件/文件组优化。有些代码不需要优化,我们优化指定的源文件/文件组就行。

86c52766-8745-11ee-939d-92fbcf53809c.jpg

本文转载自嵌入式专栏

审核编辑:汤梓红

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

    关注

    6020

    文章

    44349

    浏览量

    628084
  • 程序
    +关注

    关注

    115

    文章

    3719

    浏览量

    80342
  • keil
    +关注

    关注

    68

    文章

    1207

    浏览量

    166145
  • 代码
    +关注

    关注

    30

    文章

    4665

    浏览量

    67740
  • 编译器
    +关注

    关注

    1

    文章

    1600

    浏览量

    48888

原文标题:写个单片机程序,居然被优化了!

文章出处:【微信号:玩点嵌入式,微信公众号:玩点嵌入式】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    keil MDK应用技巧资料的分享

    keil mdk的信号函数 6、keil mdk下如何设置非零初始化变量 7、keil mdk
    发表于 06-21 12:15

    Arm Keil MDK教程下载

    Arm Keil MDK教程下载
    发表于 06-14 07:21 366次下载

    KEIL MDK-Arm免费下载

    KEIL MDK-Arm免费下载
    发表于 09-17 15:29 441次下载

    编译器_keil优化选项问题

    keil编译器的优化选项针对ARM,对STM32编译的一些优化的问题
    发表于 02-25 14:18 3次下载

    Keil MDK V5.11版使用方法

    Keil MDK V5.11版使用的方法等等
    发表于 07-13 15:40 0次下载

    keil MDK-ARM下载入口

    keil MDK-ARM下载入口
    发表于 11-20 17:41 21次下载

    KEIL MDK简介,如何安装KEIL MDK下载程序

    选择安装路径。这里选择的是F盘,若读者硬盘资源充裕,则建议安装在C盘,跑起来快些。这里有一点需要说明的是:如果你之前安装了keil c51环境,安装keil mdk的时候可以安装到同一
    的头像 发表于 04-30 16:53 2.7w次阅读
    <b class='flag-5'>KEIL</b> <b class='flag-5'>MDK</b>简介,如何安装<b class='flag-5'>KEIL</b> <b class='flag-5'>MDK</b>下载程序

    KeilMDK-ARM)系列教程(五) _Configuration(Ⅰ)

    KeilMDK-ARM)系列教程(五)_Configuration(Ⅰ)
    的头像 发表于 03-20 14:58 3967次阅读
    <b class='flag-5'>Keil</b>(<b class='flag-5'>MDK</b>-ARM)系列教程(五) _Configuration(Ⅰ)

    KeilMDK-ARM)系列教程(二)_ 工具栏详细说明

    KeilMDK-ARM)系列教程(二)_工具栏详细说明
    的头像 发表于 03-24 10:23 3933次阅读
    <b class='flag-5'>Keil</b>(<b class='flag-5'>MDK</b>-ARM)系列教程(二)_ 工具栏详细<b class='flag-5'>说明</b>

    KeilMDK-ARM) 使用教程(三)_在线调试

    KeilMDK-ARM)使用教程(三)_在线调试
    的头像 发表于 04-07 14:30 5322次阅读
    <b class='flag-5'>Keil</b>(<b class='flag-5'>MDK</b>-ARM) 使用教程(三)_在线调试

    KeilMDK-ARM)使用教程 (二)_菜单

    KeilMDK-ARM)使用教程(二)_菜单
    的头像 发表于 04-07 14:42 4091次阅读
    <b class='flag-5'>Keil</b>(<b class='flag-5'>MDK</b>-ARM)使用教程 (二)_菜单

    Keil MDK的一个bug

    素材来源:Keil 编辑整理:strongerHuang 不知道还有多少人在继续在使用Keil MDK做开发,或学习,猜的没错的话,应该还是有不少人任然在使用MDK。 前面有个读者给我
    的头像 发表于 10-19 15:26 2298次阅读
    <b class='flag-5'>Keil</b> <b class='flag-5'>MDK</b>的一个bug

    Keil MDK和IAR EARM的发展历程及历史版本下载

    Keil 和 IAR算是一代经典的IDE工具,之所以这么多人使用,除了工具比较好之外,他们的发展历史比较长也是一个原因。 下面来描述一下Keil MDK 和 IAR EARM发展历程及历史版本下载
    的头像 发表于 12-31 10:01 4985次阅读

    Keil C51和Keil MDK下载

    Keil C51和Keil MDK下载
    发表于 12-03 20:21 96次下载
    <b class='flag-5'>Keil</b> C51和<b class='flag-5'>Keil</b> <b class='flag-5'>MDK</b>下载

    为MindSDK搭建Keil MDK开发环境

    本文介绍基于Windows操作系统构建嵌入式系统开发环境过程中需要使用的主要软件Keil MDK,并对一些需要特别关注的要点重点说明Keil MD
    的头像 发表于 05-04 10:42 1395次阅读
    为MindSDK搭建<b class='flag-5'>Keil</b> <b class='flag-5'>MDK</b>开发环境