MDK中One ELF Section per Function选项功能探究
2015-06-17 09:46
211 查看
使用了ST的库,感觉体积有点大,点亮个 LED 使用了 2.5K flash 了。
一个简单的瘦身办法,也就是,将不使用的函数剔除,不连接进去最终的烧写文件,有用的函数连接进去,没用的函数不要。
只需要2步
设置项目属性
1,在 Linker 页的 Misc contrrols 那里添加 --remove
作用是将不使用的输入段(input sections)移除。
--remove 这个参数是Keil 默认已经开启的,所以加不加都一样 , Etual 2012-6-29 修改
2,单加上面那个是没有效果的,因为一个文件作为一个输入段的话就没效果了。
所以下面的操作是将每个函数作为一个输入段,这就可以优化了。方法是
在 C/C++ 页勾选 “One ELF Section per Function” 就可以了
优化我一般选 -02
重新编译,原来 2.5K 的程序,现在变成 1.2K 了 ......
========================
================================
本文主要探讨的是MDK开发工具中One ELF Section per Function选项对于代码优化的作用及其实现的机制。
这里以EK-STM32F开发板的LCDDemo实验例程为例进行说明:
1)在MDK的Project -> Options for Target -> Target选项卡下,在Code Generation 中选中Use MicroLIB,选择使用微库。在User选项卡Run User Programs After Build/Rebuild中,勾选Run #1,同时在文本框中输入命令C:/Keil/ARM/BIN31/fromelf.exe --bin -o ./output/LCDDemo.bin ./output/
LCDDemo_MDK.axf用于生成.bin文件。
2)在选项卡C/C++中选择优化等级2,同时不选中任何的优化选项。保存,编译链接,下载运行程序,查看output中LCDDemo.bin文件的大小为4728Byte。
3)在图3所示的界面中,将One ELF Section per Function选项选中,保存,编译链接,下载运行程序,查看output中LCDDemo.bin文件的大小为3700Byte。
可以从以上的操作看出, 在其他条件相同的情况下,选项One ELF Section per Function可以将LCDDemo最后生成的.bin文件的大小减少1028Byte,这对于存储资源有限的嵌入式设备来说,还是具有很大的吸引力的。
那么,选项One ELF Section per Function是如何对C程序代码进行优化呢?为此,笔者特别设计了一个方案用于验证选项One ELF Section per Function的优化功能。
首先在LCDDemo工程的main.c文件中加入如下的代码:
void unuse()
{
int i,j = 0;
for (i=0; i<0xfffff; i++) j++;
for (j=0; j<0xfffff; j++) i++;
}
unuse()函数仅是为了测试用而加入的一个函数,该函数为被其他任何的函数所调用。下面分别查看使用选项One ELF Section per Function和不使用选项One ELF Section per Function的区别。
A, 如之前的步骤2)所示操作,生成的LCDDemo.bin的大小为7396Byte。同时,笔者采用反汇编过程进一步验证,找到了unuse()的反汇编代码。可以看出,确实因为添加了unuse()这个函数,而使得最后生成的LCDDemo.bin文件的变大。.
B, 如之前的步骤3)所示操作,生成的LCDDemo.bin的大小为3700Byte。同时,笔者采用反汇编过程进一步验证,未找到unuse()的反汇编代码。可以看出,使用选项. One ELF Section per Function后,即使添加了未使用的函数unuse(),也对于最后生成的LCDDemo.bin文件没有任何的影响。
因此,可以得出,选项One ELF Section per Function的主要功能是对冗余函数的优化。通过这个选项,可以在最后生成的二进制文件中将冗余函数排除掉(虽然其所在的文件已经参与了编译链接),以便最大程度地优化最后生成的二进制代码。
而该选项实现的机制是将每一个函数作为一个优化的单元,而并非整个文件作为参与优化的单元。
选项One ELF Section per Function所具有的这种优化功能特别重要,尤其是在对于生成的二进制文件大小有严格要求的场合。人们习惯将一系列接口函数放在一个文件里,然后将其整个包含在工程中,即使这个文件将只有一个函数被用到。这样,最后生成的二进制文件中就有可能包含众多的冗余函数,造成了宝贵存储空间的浪费。
选项One ELF Section per Function对于一个大工程的优化效果尤其突出,有时候甚至可以达到减半的效果。当然,对于小工程或是少有冗余函数的工程来说,其优化效果就没有那么明显了。
http://blogimg.chinaunix.net/blog/upfile2/090807160642.rar
一个简单的瘦身办法,也就是,将不使用的函数剔除,不连接进去最终的烧写文件,有用的函数连接进去,没用的函数不要。
只需要2步
设置项目属性
1,在 Linker 页的 Misc contrrols 那里添加 --remove
作用是将不使用的输入段(input sections)移除。
--remove 这个参数是Keil 默认已经开启的,所以加不加都一样 , Etual 2012-6-29 修改
2,单加上面那个是没有效果的,因为一个文件作为一个输入段的话就没效果了。
所以下面的操作是将每个函数作为一个输入段,这就可以优化了。方法是
在 C/C++ 页勾选 “One ELF Section per Function” 就可以了
优化我一般选 -02
重新编译,原来 2.5K 的程序,现在变成 1.2K 了 ......
========================
主要目的是剔除不用的函数,对于自己写的代码,基本没啥优化效果 ..... 因为ST的库需要考虑很多芯片,所以有多余的代码,主要目的是搞掉这部分代码而已。 |
本文主要探讨的是MDK开发工具中One ELF Section per Function选项对于代码优化的作用及其实现的机制。
这里以EK-STM32F开发板的LCDDemo实验例程为例进行说明:
1)在MDK的Project -> Options for Target -> Target选项卡下,在Code Generation 中选中Use MicroLIB,选择使用微库。在User选项卡Run User Programs After Build/Rebuild中,勾选Run #1,同时在文本框中输入命令C:/Keil/ARM/BIN31/fromelf.exe --bin -o ./output/LCDDemo.bin ./output/
LCDDemo_MDK.axf用于生成.bin文件。
2)在选项卡C/C++中选择优化等级2,同时不选中任何的优化选项。保存,编译链接,下载运行程序,查看output中LCDDemo.bin文件的大小为4728Byte。
3)在图3所示的界面中,将One ELF Section per Function选项选中,保存,编译链接,下载运行程序,查看output中LCDDemo.bin文件的大小为3700Byte。
可以从以上的操作看出, 在其他条件相同的情况下,选项One ELF Section per Function可以将LCDDemo最后生成的.bin文件的大小减少1028Byte,这对于存储资源有限的嵌入式设备来说,还是具有很大的吸引力的。
那么,选项One ELF Section per Function是如何对C程序代码进行优化呢?为此,笔者特别设计了一个方案用于验证选项One ELF Section per Function的优化功能。
首先在LCDDemo工程的main.c文件中加入如下的代码:
void unuse()
{
int i,j = 0;
for (i=0; i<0xfffff; i++) j++;
for (j=0; j<0xfffff; j++) i++;
}
unuse()函数仅是为了测试用而加入的一个函数,该函数为被其他任何的函数所调用。下面分别查看使用选项One ELF Section per Function和不使用选项One ELF Section per Function的区别。
A, 如之前的步骤2)所示操作,生成的LCDDemo.bin的大小为7396Byte。同时,笔者采用反汇编过程进一步验证,找到了unuse()的反汇编代码。可以看出,确实因为添加了unuse()这个函数,而使得最后生成的LCDDemo.bin文件的变大。.
B, 如之前的步骤3)所示操作,生成的LCDDemo.bin的大小为3700Byte。同时,笔者采用反汇编过程进一步验证,未找到unuse()的反汇编代码。可以看出,使用选项. One ELF Section per Function后,即使添加了未使用的函数unuse(),也对于最后生成的LCDDemo.bin文件没有任何的影响。
因此,可以得出,选项One ELF Section per Function的主要功能是对冗余函数的优化。通过这个选项,可以在最后生成的二进制文件中将冗余函数排除掉(虽然其所在的文件已经参与了编译链接),以便最大程度地优化最后生成的二进制代码。
而该选项实现的机制是将每一个函数作为一个优化的单元,而并非整个文件作为参与优化的单元。
选项One ELF Section per Function所具有的这种优化功能特别重要,尤其是在对于生成的二进制文件大小有严格要求的场合。人们习惯将一系列接口函数放在一个文件里,然后将其整个包含在工程中,即使这个文件将只有一个函数被用到。这样,最后生成的二进制文件中就有可能包含众多的冗余函数,造成了宝贵存储空间的浪费。
选项One ELF Section per Function对于一个大工程的优化效果尤其突出,有时候甚至可以达到减半的效果。当然,对于小工程或是少有冗余函数的工程来说,其优化效果就没有那么明显了。
http://blogimg.chinaunix.net/blog/upfile2/090807160642.rar
相关文章推荐
- MySQL双机热备份方法
- left join,inner join区别
- 使用MyEclipse+TomCat搭建服务端开发环境
- JQuery autocomplete ajax 实现自动完成
- 转载 解决Android与服务器交互大容量数据问题
- PAT Basic 1033. 旧键盘打字(20)
- 【Android】下拉列表、拖动条、星级评分条与标签文本的触摸事件
- android自定义Switch样式
- leetCode(5):Sort List
- 常用的算法函数
- opencv中ptr的使用
- leetCode(5):Sort List 分类: leetCode 2015-06-17 09:45 170人阅读 评论(0) 收藏
- 遇到The connection to adb is down, and a severe error has occured
- HTTP Status 500 - java.lang.ClassNotFoundException: org.apache.jsp.WEB_002dINF.pages.index.index_jsp
- VB实现禁用任务管理器的方法
- j2se学习笔记-Enum枚举类型
- C#实现ListView选中项向上或向下移动的方法
- input框只能输入大于0的数字,当值为0或者“”时会变成1
- JS学习笔记(一):关于{}和[]的使用
- android代码混淆之自定View问题