1#ifndef _ASM_X86_BUG_H
2#define _ASM_X86_BUG_H
3
4#define HAVE_ARCH_BUG
5
6#ifdef CONFIG_DEBUG_BUGVERBOSE
7
8#ifdef CONFIG_X86_32
9# define __BUG_C0 "2:\t.long 1b, %c0\n"
10#else
11# define __BUG_C0 "2:\t.long 1b - 2b, %c0 - 2b\n"
12#endif
13
14#define BUG() \
15do { \
16 asm volatile("1:\tud2\n" \
17 ".pushsection __bug_table,\"a\"\n" \
18 __BUG_C0 \
19 "\t.word %c1, 0\n" \
20 "\t.org 2b+%c2\n" \
21 ".popsection" \
22 : : "i" (__FILE__), "i" (__LINE__), \
23 "i" (sizeof(struct bug_entry))); \
24 unreachable(); \
25} while (0)
26
27#else
28#define BUG() \
29do { \
30 asm volatile("ud2"); \
31 unreachable(); \
32} while (0)
33#endif
34
35#include <asm-generic/bug.h>
36
37#endif
38