On Sat, 2008-01-05 at 19:12 -0800, Arjan van de Ven wrote:
> From: Olof Johansson <[EMAIL PROTECTED]>
> 
> Not using the ppc-specific WARN_ON/BUG_ON constructs actually saves about
> 4K text on a ppc64_defconfig.  The main reason seems to be that prepping
> the arguments to the conditional trap instructions is more work than just
> doing a compare and branch.

I'm a bit annoyed by that one ... for obvious reasons... I wish gcc
could be better here. Also, we can't completely remove the support for
the trap since we use that in asm in various places...

Ben.

> Signed-off-by: Olof Johansson <[EMAIL PROTECTED]>
> Cc: <[EMAIL PROTECTED]>
> Cc: Scott Wood <[EMAIL PROTECTED]>
> Cc: Benjamin Herrenschmidt <[EMAIL PROTECTED]>
> Cc: Paul Mackerras <[EMAIL PROTECTED]>, 
> Signed-off-by: Andrew Morton <[EMAIL PROTECTED]>
> ---
> 
>  include/asm-powerpc/bug.h |   37 -------------------------------------
>  1 file changed, 37 deletions(-)
> 
> Index: linux-2.6.24-rc6/include/asm-powerpc/bug.h
> ===================================================================
> --- linux-2.6.24-rc6.orig/include/asm-powerpc/bug.h
> +++ linux-2.6.24-rc6/include/asm-powerpc/bug.h
> @@ -54,12 +54,6 @@
>       ".previous\n"
>  #endif
>  
> -/*
> - * 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 {                                           \
>       __asm__ __volatile__(                                   \
>               "1:     twi 31,0,0\n"                           \
> @@ -69,20 +63,6 @@
>       for(;;) ;                                               \
>  } while (0)
>  
> -#define BUG_ON(x) do {                                               \
> -     if (__builtin_constant_p(x)) {                          \
> -             if (x)                                          \
> -                     BUG();                                  \
> -     } else {                                                \
> -             __asm__ __volatile__(                           \
> -             "1:     "PPC_TLNEI"     %4,0\n"                 \
> -             _EMIT_BUG_ENTRY                                 \
> -             : : "i" (__FILE__), "i" (__LINE__), "i" (0),    \
> -               "i" (sizeof(struct bug_entry)),               \
> -               "r" ((__force long)(x)));                     \
> -     }                                                       \
> -} while (0)
> -
>  #define __WARN() do {                                                \
>       __asm__ __volatile__(                                   \
>               "1:     twi 31,0,0\n"                           \
> @@ -92,23 +72,6 @@
>                 "i" (sizeof(struct bug_entry)));              \
>  } while (0)
>  
> -#define WARN_ON(x) ({                                                \
> -     int __ret_warn_on = !!(x);                              \
> -     if (__builtin_constant_p(__ret_warn_on)) {              \
> -             if (__ret_warn_on)                              \
> -                     __WARN();                               \
> -     } else {                                                \
> -             __asm__ __volatile__(                           \
> -             "1:     "PPC_TLNEI"     %4,0\n"                 \
> -             _EMIT_BUG_ENTRY                                 \
> -             : : "i" (__FILE__), "i" (__LINE__),             \
> -               "i" (BUGFLAG_WARNING),                        \
> -               "i" (sizeof(struct bug_entry)),               \
> -               "r" (__ret_warn_on));                         \
> -     }                                                       \
> -     unlikely(__ret_warn_on);                                \
> -})
> -
>  #endif /* __ASSEMBLY __ */
>  #endif /* CONFIG_BUG */
>  
> 
> 

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

Reply via email to