
本帖最后由 QianFan 于 2015-10-25 20:42 编辑 在上一篇帖子(https://www.stmcu.org.cn/module/forum/thread-603787-1-1.html),我们使用gcc和Makefile成功的点亮了一盏led灯。却发现程序有点大,占用了6K多的代码空间。相比keil mdk下的代码量,这个确实大的多。这并不是我们使用的gcc的原因,也不是gcc链接newlibc库的原因。而是我们没有选择任何优化的参数。(下图是未经任何优化的代码大小) ![]() / d( s& W2 E" ~4 l0 ~- v* a -Os优化:1 ?: W$ f$ Y" `( \ 说到代码的优化,在单片机中,由于flash空间过小,我们并不会过多的考虑优化代码运行的速度,而是要考虑代码占用的空间。这样,首先想到的是-Os优化。可以参考网址:http://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html#index-Os-919 。对-Os的解释如下:9 q0 i' H2 ~$ F >Optimize for size. -Os enables all -O2 optimizations that do not typically ( [4 x( O, I3 U+ u3 q >increase code size. It also performs further optimizations designed 5 |9 b+ A6 r3 y6 ]' _ >to reduce code size. ! A' b2 i/ C$ w. {, m4 Z 在Makefile中,对CFLAGS编译命令添加-Os,如下图所示:(在Makefile中,#是注释一行的意思) ![]() 接着执行make clean,将上次的*.o文件删除,在重新执行make all。 ![]() 可以看到,加了-Os优化之后,代码减小到了3K多点。' r5 J' ^6 ?6 U- M0 y -ffunction-sections -fdata-sections 优化:) r: ?' N0 R. U; l. U 对3K的流水等代码并不满意。毕竟keil mdk产生的才不足2K。我们还要对其再次优化。在gnu option index参考手册中,看到这个优化命令:% J7 P8 {! p1 b3 g0 r9 N ![]() ![]() ffunction-section,fdata-section这两个命令可以是函数或者数据存放在自己独立的sections中。这两个命令是编译命令。而gc-sections是回收无用的sections。gc-sections是链接命令。不过ffucntion-section,fdata-sections和g参数连用,用于调试的时候,可能会产生什么问题。修改Makefile,增加这几个命令。去掉之前添加的-Os命令。2 d( v# y% W# \4 b) l* S" x1 r& T! [ ![]() 同样,make clean,make all之后:(代码竟然降到1680字节了!)3 U5 ]+ U, B+ V- D ![]() ffunction-sections,fdata-sections,Os连用:% A8 t5 L/ I, l% h# q( c# Z% x 下面我们将这几个命令都用上在试一下:9 A* {; M9 D, ^2 H/ p8 h7 e; ? ![]() 同样,make clean,make all之后:这个似乎是我们的终极目标了。5 L% X/ q. D+ S+ ?! c2 ? ![]() |
blink_op.zip
下载390.53 KB, 下载次数: 167
赞一个!