Merge branch 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzi...
[linux-2.6-block.git] / include / asm-generic / bug.h
CommitLineData
1da177e4
LT
1#ifndef _ASM_GENERIC_BUG_H
2#define _ASM_GENERIC_BUG_H
3
4#include <linux/compiler.h>
1da177e4 5
c8538a7a 6#ifdef CONFIG_BUG
7664c5a1
JF
7
8#ifdef CONFIG_GENERIC_BUG
9#ifndef __ASSEMBLY__
10struct bug_entry {
b93a531e 11#ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS
7664c5a1 12 unsigned long bug_addr;
b93a531e
JB
13#else
14 signed int bug_addr_disp;
15#endif
7664c5a1 16#ifdef CONFIG_DEBUG_BUGVERBOSE
b93a531e 17#ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS
7664c5a1 18 const char *file;
b93a531e
JB
19#else
20 signed int file_disp;
21#endif
7664c5a1
JF
22 unsigned short line;
23#endif
24 unsigned short flags;
25};
26#endif /* __ASSEMBLY__ */
27
28#define BUGFLAG_WARNING (1<<0)
29#endif /* CONFIG_GENERIC_BUG */
30
af9379c7
DB
31/*
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.
37 *
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.
41 */
1da177e4
LT
42#ifndef HAVE_ARCH_BUG
43#define BUG() do { \
d5c003b4 44 printk("BUG: failure at %s:%d/%s()!\n", __FILE__, __LINE__, __func__); \
1da177e4
LT
45 panic("BUG!"); \
46} while (0)
47#endif
48
1da177e4 49#ifndef HAVE_ARCH_BUG_ON
2a41de48 50#define BUG_ON(condition) do { if (unlikely(condition)) BUG(); } while(0)
1da177e4
LT
51#endif
52
af9379c7
DB
53/*
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.
58 */
3a6a62f9 59#ifndef __WARN
79b4cc5e 60#ifndef __ASSEMBLY__
a8f18b90
AV
61extern void warn_slowpath(const char *file, const int line,
62 const char *fmt, ...) __attribute__((format(printf, 3, 4)));
79b4cc5e
AV
63#define WANT_WARN_ON_SLOWPATH
64#endif
ec5679e5
IM
65#define __WARN() warn_slowpath(__FILE__, __LINE__, NULL)
66#define __WARN_printf(arg...) warn_slowpath(__FILE__, __LINE__, arg)
a8f18b90 67#else
ec5679e5 68#define __WARN_printf(arg...) do { printk(arg); __WARN(); } while (0)
3a6a62f9
OJ
69#endif
70
71#ifndef WARN_ON
684f9783 72#define WARN_ON(condition) ({ \
8d4fbcfb 73 int __ret_warn_on = !!(condition); \
3a6a62f9
OJ
74 if (unlikely(__ret_warn_on)) \
75 __WARN(); \
684f9783
HX
76 unlikely(__ret_warn_on); \
77})
1da177e4
LT
78#endif
79
a8f18b90
AV
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); \
86})
87#endif
88
c8538a7a
MM
89#else /* !CONFIG_BUG */
90#ifndef HAVE_ARCH_BUG
91#define BUG()
92#endif
93
c8538a7a
MM
94#ifndef HAVE_ARCH_BUG_ON
95#define BUG_ON(condition) do { if (condition) ; } while(0)
96#endif
97
98#ifndef HAVE_ARCH_WARN_ON
8c7c7c9b 99#define WARN_ON(condition) ({ \
8d4fbcfb 100 int __ret_warn_on = !!(condition); \
8c7c7c9b
RB
101 unlikely(__ret_warn_on); \
102})
c8538a7a 103#endif
a8f18b90
AV
104
105#ifndef WARN
106#define WARN(condition, format...) ({ \
107 int __ret_warn_on = !!(condition); \
108 unlikely(__ret_warn_on); \
109})
110#endif
111
c8538a7a
MM
112#endif
113
d69a8922
AM
114#define WARN_ON_ONCE(condition) ({ \
115 static int __warned; \
8d4fbcfb 116 int __ret_warn_once = !!(condition); \
d69a8922
AM
117 \
118 if (unlikely(__ret_warn_once)) \
119 if (WARN_ON(!__warned)) \
120 __warned = 1; \
121 unlikely(__ret_warn_once); \
74bb6a09
IM
122})
123
45e9c0de
AV
124#define WARN_ONCE(condition, format...) ({ \
125 static int __warned; \
126 int __ret_warn_once = !!(condition); \
127 \
128 if (unlikely(__ret_warn_once)) \
129 if (WARN(!__warned, format)) \
130 __warned = 1; \
131 unlikely(__ret_warn_once); \
132})
133
717115e1
DY
134#define WARN_ON_RATELIMIT(condition, state) \
135 WARN_ON((condition) && __ratelimit(state))
136
8eb94f80
IM
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
142
1da177e4 143#endif