hrtimer: fix rq->lock inversion (again)
[linux-2.6/mini2440.git] / include / asm-generic / bug.h
blob37b82cb96c891ffe8dc9356a7f11736aca8975ff
1 #ifndef _ASM_GENERIC_BUG_H
2 #define _ASM_GENERIC_BUG_H
4 #include <linux/compiler.h>
6 #ifdef CONFIG_BUG
8 #ifdef CONFIG_GENERIC_BUG
9 #ifndef __ASSEMBLY__
10 struct bug_entry {
11 #ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS
12 unsigned long bug_addr;
13 #else
14 signed int bug_addr_disp;
15 #endif
16 #ifdef CONFIG_DEBUG_BUGVERBOSE
17 #ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS
18 const char *file;
19 #else
20 signed int file_disp;
21 #endif
22 unsigned short line;
23 #endif
24 unsigned short flags;
26 #endif /* __ASSEMBLY__ */
28 #define BUGFLAG_WARNING (1<<0)
29 #endif /* CONFIG_GENERIC_BUG */
32 * Don't use BUG() or BUG_ON() unless there's really no way out; one
33 * example might be detecting data structure corruption in the middle
34 * of an operation that can't be backed out of. If the (sub)system
35 * can somehow continue operating, perhaps with reduced functionality,
36 * it's probably not BUG-worthy.
38 * If you're tempted to BUG(), think again: is completely giving up
39 * really the *only* solution? There are usually better options, where
40 * users don't need to reboot ASAP and can mostly shut down cleanly.
42 #ifndef HAVE_ARCH_BUG
43 #define BUG() do { \
44 printk("BUG: failure at %s:%d/%s()!\n", __FILE__, __LINE__, __func__); \
45 panic("BUG!"); \
46 } while (0)
47 #endif
49 #ifndef HAVE_ARCH_BUG_ON
50 #define BUG_ON(condition) do { if (unlikely(condition)) BUG(); } while(0)
51 #endif
54 * WARN(), WARN_ON(), WARN_ON_ONCE, and so on can be used to report
55 * significant issues that need prompt attention if they should ever
56 * appear at runtime. Use the versions with printk format strings
57 * to provide better diagnostics.
59 #ifndef __WARN
60 #ifndef __ASSEMBLY__
61 extern void warn_slowpath(const char *file, const int line,
62 const char *fmt, ...) __attribute__((format(printf, 3, 4)));
63 #define WANT_WARN_ON_SLOWPATH
64 #endif
65 #define __WARN() warn_slowpath(__FILE__, __LINE__, NULL)
66 #define __WARN_printf(arg...) warn_slowpath(__FILE__, __LINE__, arg)
67 #else
68 #define __WARN_printf(arg...) do { printk(arg); __WARN(); } while (0)
69 #endif
71 #ifndef WARN_ON
72 #define WARN_ON(condition) ({ \
73 int __ret_warn_on = !!(condition); \
74 if (unlikely(__ret_warn_on)) \
75 __WARN(); \
76 unlikely(__ret_warn_on); \
78 #endif
80 #ifndef WARN
81 #define WARN(condition, format...) ({ \
82 int __ret_warn_on = !!(condition); \
83 if (unlikely(__ret_warn_on)) \
84 __WARN_printf(format); \
85 unlikely(__ret_warn_on); \
87 #endif
89 #else /* !CONFIG_BUG */
90 #ifndef HAVE_ARCH_BUG
91 #define BUG()
92 #endif
94 #ifndef HAVE_ARCH_BUG_ON
95 #define BUG_ON(condition) do { if (condition) ; } while(0)
96 #endif
98 #ifndef HAVE_ARCH_WARN_ON
99 #define WARN_ON(condition) ({ \
100 int __ret_warn_on = !!(condition); \
101 unlikely(__ret_warn_on); \
103 #endif
105 #ifndef WARN
106 #define WARN(condition, format...) ({ \
107 int __ret_warn_on = !!(condition); \
108 unlikely(__ret_warn_on); \
110 #endif
112 #endif
114 #define WARN_ON_ONCE(condition) ({ \
115 static int __warned; \
116 int __ret_warn_once = !!(condition); \
118 if (unlikely(__ret_warn_once)) \
119 if (WARN_ON(!__warned)) \
120 __warned = 1; \
121 unlikely(__ret_warn_once); \
124 #define WARN_ONCE(condition, format...) ({ \
125 static int __warned; \
126 int __ret_warn_once = !!(condition); \
128 if (unlikely(__ret_warn_once)) \
129 if (WARN(!__warned, format)) \
130 __warned = 1; \
131 unlikely(__ret_warn_once); \
134 #define WARN_ON_RATELIMIT(condition, state) \
135 WARN_ON((condition) && __ratelimit(state))
137 #ifdef CONFIG_SMP
138 # define WARN_ON_SMP(x) WARN_ON(x)
139 #else
140 # define WARN_ON_SMP(x) do { } while (0)
141 #endif
143 #endif