From: kfraser@dhcp93.uk.xensource.com Date: Wed, 28 Jun 2006 15:15:36 +0000 (+0100) Subject: [XEN] BUG() places console in sync mode. X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~15912^2~55 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=5de50eb18b7db6292daf2aaa6005d11806e1c996;p=xen.git [XEN] BUG() places console in sync mode. Also move the BUG code out of line. Original patch from Jimi Xenidis. Signed-off-by: Keir Fraser --- diff --git a/xen/drivers/char/console.c b/xen/drivers/char/console.c index 309411b387..2765d4e2e0 100644 --- a/xen/drivers/char/console.c +++ b/xen/drivers/char/console.c @@ -741,6 +741,15 @@ void panic(const char *fmt, ...) machine_restart(0); } +void __bug(char *file, int line) +{ + console_start_sync(); + debugtrace_dump(); + printk("BUG at %s:%d\n", file, line); + FORCE_CRASH(); + for ( ; ; ) ; +} + /* * Local variables: * mode: C diff --git a/xen/include/xen/lib.h b/xen/include/xen/lib.h index 6cfe0dc217..e2c67a1d46 100644 --- a/xen/include/xen/lib.h +++ b/xen/include/xen/lib.h @@ -8,19 +8,23 @@ #include #include -#define BUG() do { \ - debugtrace_dump(); \ - printk("BUG at %s:%d\n", __FILE__, __LINE__); \ - FORCE_CRASH(); \ -} while ( 0 ) - +extern void __bug(char *file, int line) __attribute__((noreturn)); +#define BUG() __bug(__FILE__, __LINE__) #define BUG_ON(_p) do { if (_p) BUG(); } while ( 0 ) /* Force a compilation error if condition is true */ #define BUILD_BUG_ON(condition) ((void)sizeof(char[1 - 2 * !!(condition)])) #ifndef NDEBUG -#define ASSERT(_p) { if ( !(_p) ) { printk("Assertion '%s' failed, line %d, file %s\n", #_p , __LINE__, __FILE__); BUG(); } } +#define ASSERT(_p) \ + do { \ + if ( !(_p) ) \ + { \ + printk("Assertion '%s' failed, line %d, file %s\n", #_p , \ + __LINE__, __FILE__); \ + BUG(); \ + } \ + } while ( 0 ) #else #define ASSERT(_p) ((void)0) #endif