文章目录
- 优化选项
- 博文链接
- 单独设置某段代码优化等级
- 博文链接
优化选项
- -O/-O0:无优化(默认)
- -O1:使用能减少目标文件大小以及执行时间并且不会使编译时间明显增加的优化。该模式在编译大型程序的时候会花费更多的时间和内存。在-O1 下,编译会尝试减少代码体积和代码运行时间,但是并不执行会花费大量时间的优化操作。
- -O2: 包含-O1 的优化并增加了不需要在目标文件大小和执行速度上进行折衷的优化。GCC 执行几乎所有支持的操作但不包括空间和速度之间权衡的优化,编译器不执行循环展开以及函数内联。这是推荐的优化等级,除非你有特殊的需求。-O2 会比-O1 启用多一些标记。与-O1 比较该优化-O2 将会花费更多的编译时间当然也会生成性能更好的代码。
- -Os:专门优化目标文件大小,执行所有的不增加目标文件大小的-O2 优化选项。同时-Os 还会执行更加优化程序空间的选项。这对于磁盘空间极其紧张或者 CPU 缓存较小的机器非常有用。但也可能产生些许问题,因此软件树中的大部分 ebuild 都过滤掉这个等级的优化。使用-Os 是不推荐的。
- -O3: 打开所有 -O2 的优化选项并且增加 -finline-functions, -funswitch-loops,-fpredictive-commoning, -fgcse-after-reload and -ftree-vectorize 优化选项。这是最高最危险的优化等级。用这个选项会延长编译代码的时间,并且在使用 gcc4.x 的系统里不应全局启用。自从 3.x 版本以来 gcc 的行为已经有了极大地改变。在 3.x,-O3 生成的代码也只
是比-O2 快一点点而已,而 gcc4.x 中还未必更快。用-O3 来编译所有的软件包将产生更大体积更耗内存的二进制文件,大大增加编译失败的机会或不可预知的程序行为(包括错误)。这样做将得不偿失,记住过犹不及。在 gcc 4.x.中使用-O3 是不推荐的。
博文链接
gcc各等级优化的性质
gcc手册-优化选项(英文原文)
单独设置某段代码优化等级
一个简单示例如下,
#pragma GCC push_options
#pragma GCC optimize ("O1")
void spi_write_only(u32 data)
{
u32 uiTemp;
Xil_Out32(IOMODULE_IO_BASEADDR + SPI_SEND_DATA_ADDR*4,data);
Xil_Out32(IOMODULE_IO_BASEADDR + SPI_SEND_VLD_ADDR*4,0);
Xil_Out32(IOMODULE_IO_BASEADDR + SPI_SEND_VLD_ADDR*4,1);
Xil_Out32(IOMODULE_IO_BASEADDR + SPI_SEND_VLD_ADDR*4,0);
while(1)
{
uiTemp = Xil_In32(IOMODULE_IO_BASEADDR + SPI_RECV_ADDR*4);
if(0x1 == (uiTemp>>31))
{
break;
}
}
}
#pragma GCC pop_options
博文链接
C/C++编译器局部优化技术:局部优化是针对单个函数或基本块进行的优化
【C++】如何强制指定函数的优化等级
如何指定某个c代码段在使用gcc编译时的优化级别
GCC设置部分代码的编译选项