Blame view

include/asm-generic/bug.h 6.44 KB
b24413180   Greg Kroah-Hartman   License cleanup: ...
1
  /* SPDX-License-Identifier: GPL-2.0 */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2
3
4
5
  #ifndef _ASM_GENERIC_BUG_H
  #define _ASM_GENERIC_BUG_H
  
  #include <linux/compiler.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
6

09682c1dd   Paul Mundt   bug.h: Fix up CON...
7
8
  #ifdef CONFIG_GENERIC_BUG
  #define BUGFLAG_WARNING		(1 << 0)
19d436268   Peter Zijlstra   debug: Add _ONCE(...
9
10
  #define BUGFLAG_ONCE		(1 << 1)
  #define BUGFLAG_DONE		(1 << 2)
f26dee151   Peter Zijlstra   debug: Avoid sett...
11
  #define BUGFLAG_TAINT(taint)	((taint) << 8)
09682c1dd   Paul Mundt   bug.h: Fix up CON...
12
13
14
15
16
  #define BUG_GET_TAINT(bug)	((bug)->flags >> 8)
  #endif
  
  #ifndef __ASSEMBLY__
  #include <linux/kernel.h>
c8538a7aa   Matt Mackall   [PATCH] remove al...
17
  #ifdef CONFIG_BUG
7664c5a1d   Jeremy Fitzhardinge   [PATCH] Generic B...
18
19
  
  #ifdef CONFIG_GENERIC_BUG
7664c5a1d   Jeremy Fitzhardinge   [PATCH] Generic B...
20
  struct bug_entry {
b93a531e3   Jan Beulich   allow bug table e...
21
  #ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS
7664c5a1d   Jeremy Fitzhardinge   [PATCH] Generic B...
22
  	unsigned long	bug_addr;
b93a531e3   Jan Beulich   allow bug table e...
23
24
25
  #else
  	signed int	bug_addr_disp;
  #endif
7664c5a1d   Jeremy Fitzhardinge   [PATCH] Generic B...
26
  #ifdef CONFIG_DEBUG_BUGVERBOSE
b93a531e3   Jan Beulich   allow bug table e...
27
  #ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS
7664c5a1d   Jeremy Fitzhardinge   [PATCH] Generic B...
28
  	const char	*file;
b93a531e3   Jan Beulich   allow bug table e...
29
30
31
  #else
  	signed int	file_disp;
  #endif
7664c5a1d   Jeremy Fitzhardinge   [PATCH] Generic B...
32
33
34
35
  	unsigned short	line;
  #endif
  	unsigned short	flags;
  };
7664c5a1d   Jeremy Fitzhardinge   [PATCH] Generic B...
36
  #endif	/* CONFIG_GENERIC_BUG */
af9379c71   David Brownell   documentation: wh...
37
38
39
40
41
42
43
44
45
46
47
  /*
   * Don't use BUG() or BUG_ON() unless there's really no way out; one
   * example might be detecting data structure corruption in the middle
   * of an operation that can't be backed out of.  If the (sub)system
   * can somehow continue operating, perhaps with reduced functionality,
   * it's probably not BUG-worthy.
   *
   * If you're tempted to BUG(), think again:  is completely giving up
   * really the *only* solution?  There are usually better options, where
   * users don't need to reboot ASAP and can mostly shut down cleanly.
   */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
48
49
  #ifndef HAVE_ARCH_BUG
  #define BUG() do { \
d5c003b4d   Harvey Harrison   include: replace ...
50
51
  	printk("BUG: failure at %s:%d/%s()!
  ", __FILE__, __LINE__, __func__); \
305eb32d4   Arnd Bergmann   bug.h: work aroun...
52
  	barrier_before_unreachable(); \
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
53
54
55
  	panic("BUG!"); \
  } while (0)
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
56
  #ifndef HAVE_ARCH_BUG_ON
a3f7607d0   Josh Triplett   include/asm-gener...
57
  #define BUG_ON(condition) do { if (unlikely(condition)) BUG(); } while (0)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
58
  #endif
19d436268   Peter Zijlstra   debug: Add _ONCE(...
59
60
61
62
63
64
65
66
67
68
69
  #ifdef __WARN_FLAGS
  #define __WARN_TAINT(taint)		__WARN_FLAGS(BUGFLAG_TAINT(taint))
  #define __WARN_ONCE_TAINT(taint)	__WARN_FLAGS(BUGFLAG_ONCE|BUGFLAG_TAINT(taint))
  
  #define WARN_ON_ONCE(condition) ({				\
  	int __ret_warn_on = !!(condition);			\
  	if (unlikely(__ret_warn_on))				\
  		__WARN_ONCE_TAINT(TAINT_WARN);			\
  	unlikely(__ret_warn_on);				\
  })
  #endif
af9379c71   David Brownell   documentation: wh...
70
71
72
73
74
75
  /*
   * WARN(), WARN_ON(), WARN_ON_ONCE, and so on can be used to report
   * significant issues that need prompt attention if they should ever
   * appear at runtime.  Use the versions with printk format strings
   * to provide better diagnostics.
   */
b2be05273   Ben Hutchings   panic: Allow warn...
76
  #ifndef __WARN_TAINT
b9075fa96   Joe Perches   treewide: use __p...
77
78
79
80
81
82
  extern __printf(3, 4)
  void warn_slowpath_fmt(const char *file, const int line,
  		       const char *fmt, ...);
  extern __printf(4, 5)
  void warn_slowpath_fmt_taint(const char *file, const int line, unsigned taint,
  			     const char *fmt, ...);
57adc4d2d   Andi Kleen   Eliminate thousan...
83
  extern void warn_slowpath_null(const char *file, const int line);
79b4cc5ee   Arjan van de Ven   debug: move WARN_...
84
  #define WANT_WARN_ON_SLOWPATH
57adc4d2d   Andi Kleen   Eliminate thousan...
85
86
  #define __WARN()		warn_slowpath_null(__FILE__, __LINE__)
  #define __WARN_printf(arg...)	warn_slowpath_fmt(__FILE__, __LINE__, arg)
b2be05273   Ben Hutchings   panic: Allow warn...
87
88
  #define __WARN_printf_taint(taint, arg...)				\
  	warn_slowpath_fmt_taint(__FILE__, __LINE__, taint, arg)
a8f18b909   Arjan van de Ven   Add a WARN() macr...
89
  #else
b2be05273   Ben Hutchings   panic: Allow warn...
90
  #define __WARN()		__WARN_TAINT(TAINT_WARN)
ec5679e51   Ingo Molnar   debug warnings: e...
91
  #define __WARN_printf(arg...)	do { printk(arg); __WARN(); } while (0)
b2be05273   Ben Hutchings   panic: Allow warn...
92
93
  #define __WARN_printf_taint(taint, arg...)				\
  	do { printk(arg); __WARN_TAINT(taint); } while (0)
3a6a62f96   Olof Johansson   debug: introduce ...
94
  #endif
2553b67a1   Josh Poimboeuf   lib/bug.c: use co...
95
96
  /* used internally by panic.c */
  struct warn_args;
0b396923e   Ian Abbott   asm-generic/bug.h...
97
  struct pt_regs;
2553b67a1   Josh Poimboeuf   lib/bug.c: use co...
98
99
100
  
  void __warn(const char *file, int line, void *caller, unsigned taint,
  	    struct pt_regs *regs, struct warn_args *args);
3a6a62f96   Olof Johansson   debug: introduce ...
101
  #ifndef WARN_ON
684f97834   Herbert Xu   [PATCH] Let WARN_...
102
  #define WARN_ON(condition) ({						\
8d4fbcfbe   Linus Torvalds   Fix WARN_ON() on ...
103
  	int __ret_warn_on = !!(condition);				\
3a6a62f96   Olof Johansson   debug: introduce ...
104
105
  	if (unlikely(__ret_warn_on))					\
  		__WARN();						\
684f97834   Herbert Xu   [PATCH] Let WARN_...
106
107
  	unlikely(__ret_warn_on);					\
  })
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
108
  #endif
a8f18b909   Arjan van de Ven   Add a WARN() macr...
109
  #ifndef WARN
19d436268   Peter Zijlstra   debug: Add _ONCE(...
110
  #define WARN(condition, format...) ({					\
a8f18b909   Arjan van de Ven   Add a WARN() macr...
111
112
113
114
115
116
  	int __ret_warn_on = !!(condition);				\
  	if (unlikely(__ret_warn_on))					\
  		__WARN_printf(format);					\
  	unlikely(__ret_warn_on);					\
  })
  #endif
b2be05273   Ben Hutchings   panic: Allow warn...
117
118
119
120
121
122
  #define WARN_TAINT(condition, taint, format...) ({			\
  	int __ret_warn_on = !!(condition);				\
  	if (unlikely(__ret_warn_on))					\
  		__WARN_printf_taint(taint, format);			\
  	unlikely(__ret_warn_on);					\
  })
19d436268   Peter Zijlstra   debug: Add _ONCE(...
123
  #ifndef WARN_ON_ONCE
d69a89226   Andrew Morton   [PATCH] Fix WARN_...
124
  #define WARN_ON_ONCE(condition)	({				\
7ccaba531   Jan Beulich   consolidate WARN_...
125
  	static bool __section(.data.unlikely) __warned;		\
8d4fbcfbe   Linus Torvalds   Fix WARN_ON() on ...
126
  	int __ret_warn_once = !!(condition);			\
d69a89226   Andrew Morton   [PATCH] Fix WARN_...
127
  								\
dfbf2897d   Steven Rostedt   bug: set warn var...
128
129
130
131
  	if (unlikely(__ret_warn_once && !__warned)) {		\
  		__warned = true;				\
  		WARN_ON(1);					\
  	}							\
d69a89226   Andrew Morton   [PATCH] Fix WARN_...
132
  	unlikely(__ret_warn_once);				\
74bb6a09b   Ingo Molnar   [PATCH] introduce...
133
  })
19d436268   Peter Zijlstra   debug: Add _ONCE(...
134
  #endif
74bb6a09b   Ingo Molnar   [PATCH] introduce...
135

45e9c0de2   Arjan van de Ven   warn: Turn the ne...
136
  #define WARN_ONCE(condition, format...)	({			\
7ccaba531   Jan Beulich   consolidate WARN_...
137
  	static bool __section(.data.unlikely) __warned;		\
45e9c0de2   Arjan van de Ven   warn: Turn the ne...
138
139
  	int __ret_warn_once = !!(condition);			\
  								\
dfbf2897d   Steven Rostedt   bug: set warn var...
140
141
142
143
  	if (unlikely(__ret_warn_once && !__warned)) {		\
  		__warned = true;				\
  		WARN(1, format);				\
  	}							\
45e9c0de2   Arjan van de Ven   warn: Turn the ne...
144
145
  	unlikely(__ret_warn_once);				\
  })
b2be05273   Ben Hutchings   panic: Allow warn...
146
  #define WARN_TAINT_ONCE(condition, taint, format...)	({	\
7ccaba531   Jan Beulich   consolidate WARN_...
147
  	static bool __section(.data.unlikely) __warned;		\
b2be05273   Ben Hutchings   panic: Allow warn...
148
149
  	int __ret_warn_once = !!(condition);			\
  								\
dfbf2897d   Steven Rostedt   bug: set warn var...
150
151
152
153
  	if (unlikely(__ret_warn_once && !__warned)) {		\
  		__warned = true;				\
  		WARN_TAINT(1, taint, format);			\
  	}							\
b2be05273   Ben Hutchings   panic: Allow warn...
154
155
  	unlikely(__ret_warn_once);				\
  })
b607e70ec   Josh Triplett   bug: when !CONFIG...
156
157
  #else /* !CONFIG_BUG */
  #ifndef HAVE_ARCH_BUG
a4b5d580e   Josh Triplett   bug: Make BUG() a...
158
  #define BUG() do {} while (1)
b607e70ec   Josh Triplett   bug: when !CONFIG...
159
160
161
  #endif
  
  #ifndef HAVE_ARCH_BUG_ON
3c047057d   Arnd Bergmann   asm-generic: defa...
162
  #define BUG_ON(condition) do { if (condition) BUG(); } while (0)
b607e70ec   Josh Triplett   bug: when !CONFIG...
163
164
165
166
167
168
169
170
171
172
173
174
  #endif
  
  #ifndef HAVE_ARCH_WARN_ON
  #define WARN_ON(condition) ({						\
  	int __ret_warn_on = !!(condition);				\
  	unlikely(__ret_warn_on);					\
  })
  #endif
  
  #ifndef WARN
  #define WARN(condition, format...) ({					\
  	int __ret_warn_on = !!(condition);				\
4e50ebde3   Josh Triplett   bug: when !CONFIG...
175
  	no_printk(format);						\
b607e70ec   Josh Triplett   bug: when !CONFIG...
176
177
178
179
180
181
182
183
184
185
  	unlikely(__ret_warn_on);					\
  })
  #endif
  
  #define WARN_ON_ONCE(condition) WARN_ON(condition)
  #define WARN_ONCE(condition, format...) WARN(condition, format)
  #define WARN_TAINT(condition, taint, format...) WARN(condition, format)
  #define WARN_TAINT_ONCE(condition, taint, format...) WARN(condition, format)
  
  #endif
2092e6be8   Steven Rostedt   WARN_ON_SMP(): Al...
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
  /*
   * WARN_ON_SMP() is for cases that the warning is either
   * meaningless for !SMP or may even cause failures.
   * This is usually used for cases that we have
   * WARN_ON(!spin_is_locked(&lock)) checks, as spin_is_locked()
   * returns 0 for uniprocessor settings.
   * It can also be used with values that are only defined
   * on SMP:
   *
   * struct foo {
   *  [...]
   * #ifdef CONFIG_SMP
   *	int bar;
   * #endif
   * };
   *
   * void func(struct foo *zoot)
   * {
   *	WARN_ON_SMP(!zoot->bar);
   *
   * For CONFIG_SMP, WARN_ON_SMP() should act the same as WARN_ON(),
   * and should be a nop and return false for uniprocessor.
   *
   * if (WARN_ON_SMP(x)) returns true only when CONFIG_SMP is set
   * and x is true.
   */
8eb94f80d   Ingo Molnar   [PATCH] pi-futex:...
212
213
214
  #ifdef CONFIG_SMP
  # define WARN_ON_SMP(x)			WARN_ON(x)
  #else
ccd0d44fa   Steven Rostedt   WARN_ON_SMP(): Ad...
215
216
217
218
219
220
221
  /*
   * Use of ({0;}) because WARN_ON_SMP(x) may be used either as
   * a stand alone line statement or as a condition in an if ()
   * statement.
   * A simple "0" would cause gcc to give a "statement has no effect"
   * warning.
   */
2092e6be8   Steven Rostedt   WARN_ON_SMP(): Al...
222
  # define WARN_ON_SMP(x)			({0;})
8eb94f80d   Ingo Molnar   [PATCH] pi-futex:...
223
  #endif
2603efa31   Paul Mundt   bug.h: Fix up pow...
224
  #endif /* __ASSEMBLY__ */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
225
  #endif