How to change optimization level of one function?
It's described in https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#Common-Function-Attributes
You can change the level by declaring the function like this:
void some_func() __attribute__ ((optimize(1))) {
....
}
To force optimization level 1 for it.
I know this question is tagged as GCC, but I was just looking into doing this portably and thought the results may come in handy for someone, so:
- GCC has an
optimize(X)
function attribute - Clang has
optnone
andminsize
function attributes (use__has_attribute
to test for support). Since I believe 3.5 it also has#pragma clang optimize on|off
. - Intel C/C++ compiler has
#pragma intel optimization_level 0
which applies to the next function after the pragma - MSVC has
#pragma optimize
, which applies to the first function after the pragma - IBM XL has
#pragma option_override(funcname, "opt(level,X)")
. Note that 13.1.6 (at least) returns true for__has_attribute(optnone)
but doesn't actually support it. - ARM has
#pragma Onum
, which can be coupled with#pragma push/pop
- ODS has
#pragma opt X (funcname)
- Cray has
#pragma _CRI [no]opt
- TI has
#pragma FUNCTION_OPTIONS(func,"…")
(C) and#pragma FUNCTION_OPTIONS("…")
(C++) - IAR has
#pragma optimize=...
- Pelles C has
#pragma optimize time/size/none
So, for GCC/ICC/MSVC/clang/IAR/Pelles and TI C++, you could define a macro that you just put before the function. If you want to support XL, ODS, and TI C you could add the function name as an argument. ARM would require another macro after the function to pop the setting. For Cray AFAIK you can't restore the previous value, only turn optimization off and on.
I think the main reason for this is to disable optimizations for a buggy compiler (or a compiler which exposes bugs in your code), so a unified portable experience probably isn't critical, but hopefully this list helps someone find the right solution for their compiler.
Edit: It's also worth noting that it's relatively common to disable optimizations because code which was working before no longer does. While it's possible that there is a bug in the compiler, it's much more likely that your code was relying on undefined behavior and newer, smarter compilers can and will elide the undefined case. The right answer in situations like this is not to disable optimizations, but instead to fix your code. UBsan on clang and gcc can help a lot here; compile with -fsanitize=undefined
and lots of undefined behavior will start emitting warnings at runtime. Also, try compiling with all the warning options you can enabled; for GCC that means -Wall -Wextra
, for clang throw in -Weverything
.