optimizing out inline functions

From: Steve French
Date: Wed May 28 2008 - 15:51:42 EST


In trying to remove some macros, I ran across another kernel style
question. I see two ways that people try to let the compiler optimize
out unused code and would like to know which is preferred. The first
example uses an empty inline function and trusts the compiler will
optimize it out.

#ifdef CONFIG_DEBUG_SOMETHING
static inline void some_debug_function(var1)
{
something = var1;
printk(some debug text);
}
#else
static inline void some_debug_function(var1)
{
/* empty function */
}
#endif


alternatively I have seen places where people put a #define of do while 0, e.g.



#ifdef CONFIG_DEBUG_SOMETHING
static inline void some_debug_function(var1)
{
something = var1;
printk(some debug text);
}
#else
#define some_debug_function(var) do {} while (0)
#endif


Is one or the other style (with or without #define of empty function)
preferred? Does the compiler optimize both #else clauses out
properly? sparse and checkpatch seem to take either

--
Thanks,

Steve
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/