Commit e3f94b85 authored by Michael Ellerman's avatar Michael Ellerman Committed by Paul Mackerras

[PATCH] powerpc: Make BUG_ON & WARN_ON play nice with compile-time optimisations

Change BUG_ON and WARN_ON to give the compiler a chance to perform
compile-time optimsations. Depending on the complexity of the condition,
the compiler may not do this very well, so if it's important check the
object code.

Current GCC's (4.x) produce good code as long as the condition does not
include a function call, including a static inline.
Signed-off-by: default avatarMichael Ellerman <michael@ellerman.id.au>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent af308377
...@@ -30,6 +30,12 @@ struct bug_entry *find_bug(unsigned long bugaddr); ...@@ -30,6 +30,12 @@ struct bug_entry *find_bug(unsigned long bugaddr);
#ifdef CONFIG_BUG #ifdef CONFIG_BUG
/*
* BUG_ON() and WARN_ON() do their best to cooperate with compile-time
* optimisations. However depending on the complexity of the condition
* some compiler versions may not produce optimal results.
*/
#define BUG() do { \ #define BUG() do { \
__asm__ __volatile__( \ __asm__ __volatile__( \
"1: twi 31,0,0\n" \ "1: twi 31,0,0\n" \
...@@ -40,6 +46,10 @@ struct bug_entry *find_bug(unsigned long bugaddr); ...@@ -40,6 +46,10 @@ struct bug_entry *find_bug(unsigned long bugaddr);
} while (0) } while (0)
#define BUG_ON(x) do { \ #define BUG_ON(x) do { \
if (__builtin_constant_p(x)) { \
if (x) \
BUG(); \
} else { \
__asm__ __volatile__( \ __asm__ __volatile__( \
"1: "PPC_TLNEI" %0,0\n" \ "1: "PPC_TLNEI" %0,0\n" \
".section __bug_table,\"a\"\n" \ ".section __bug_table,\"a\"\n" \
...@@ -47,9 +57,24 @@ struct bug_entry *find_bug(unsigned long bugaddr); ...@@ -47,9 +57,24 @@ struct bug_entry *find_bug(unsigned long bugaddr);
".previous" \ ".previous" \
: : "r" ((long)(x)), "i" (__LINE__), \ : : "r" ((long)(x)), "i" (__LINE__), \
"i" (__FILE__), "i" (__FUNCTION__)); \ "i" (__FILE__), "i" (__FUNCTION__)); \
} \
} while (0)
#define WARN() do { \
__asm__ __volatile__( \
"1: twi 31,0,0\n" \
".section __bug_table,\"a\"\n" \
"\t"PPC_LONG" 1b,%0,%1,%2\n" \
".previous" \
: : "i" (__LINE__ + BUG_WARNING_TRAP), \
"i" (__FILE__), "i" (__FUNCTION__)); \
} while (0) } while (0)
#define WARN_ON(x) do { \ #define WARN_ON(x) do { \
if (__builtin_constant_p(x)) { \
if (x) \
WARN(); \
} else { \
__asm__ __volatile__( \ __asm__ __volatile__( \
"1: "PPC_TLNEI" %0,0\n" \ "1: "PPC_TLNEI" %0,0\n" \
".section __bug_table,\"a\"\n" \ ".section __bug_table,\"a\"\n" \
...@@ -58,6 +83,7 @@ struct bug_entry *find_bug(unsigned long bugaddr); ...@@ -58,6 +83,7 @@ struct bug_entry *find_bug(unsigned long bugaddr);
: : "r" ((long)(x)), \ : : "r" ((long)(x)), \
"i" (__LINE__ + BUG_WARNING_TRAP), \ "i" (__LINE__ + BUG_WARNING_TRAP), \
"i" (__FILE__), "i" (__FUNCTION__)); \ "i" (__FILE__), "i" (__FUNCTION__)); \
} \
} while (0) } while (0)
#define HAVE_ARCH_BUG #define HAVE_ARCH_BUG
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment