Blame view
include/asm-generic/bug.h
6.44 KB
b24413180 License cleanup: ... |
1 |
/* SPDX-License-Identifier: GPL-2.0 */ |
1da177e4c Linux-2.6.12-rc2 |
2 3 4 5 |
#ifndef _ASM_GENERIC_BUG_H #define _ASM_GENERIC_BUG_H #include <linux/compiler.h> |
1da177e4c Linux-2.6.12-rc2 |
6 |
|
09682c1dd bug.h: Fix up CON... |
7 8 |
#ifdef CONFIG_GENERIC_BUG #define BUGFLAG_WARNING (1 << 0) |
19d436268 debug: Add _ONCE(... |
9 10 |
#define BUGFLAG_ONCE (1 << 1) #define BUGFLAG_DONE (1 << 2) |
f26dee151 debug: Avoid sett... |
11 |
#define BUGFLAG_TAINT(taint) ((taint) << 8) |
09682c1dd 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 [PATCH] remove al... |
17 |
#ifdef CONFIG_BUG |
7664c5a1d [PATCH] Generic B... |
18 19 |
#ifdef CONFIG_GENERIC_BUG |
7664c5a1d [PATCH] Generic B... |
20 |
struct bug_entry { |
b93a531e3 allow bug table e... |
21 |
#ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS |
7664c5a1d [PATCH] Generic B... |
22 |
unsigned long bug_addr; |
b93a531e3 allow bug table e... |
23 24 25 |
#else signed int bug_addr_disp; #endif |
7664c5a1d [PATCH] Generic B... |
26 |
#ifdef CONFIG_DEBUG_BUGVERBOSE |
b93a531e3 allow bug table e... |
27 |
#ifndef CONFIG_GENERIC_BUG_RELATIVE_POINTERS |
7664c5a1d [PATCH] Generic B... |
28 |
const char *file; |
b93a531e3 allow bug table e... |
29 30 31 |
#else signed int file_disp; #endif |
7664c5a1d [PATCH] Generic B... |
32 33 34 35 |
unsigned short line; #endif unsigned short flags; }; |
7664c5a1d [PATCH] Generic B... |
36 |
#endif /* CONFIG_GENERIC_BUG */ |
af9379c71 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 Linux-2.6.12-rc2 |
48 49 |
#ifndef HAVE_ARCH_BUG #define BUG() do { \ |
d5c003b4d include: replace ... |
50 51 |
printk("BUG: failure at %s:%d/%s()! ", __FILE__, __LINE__, __func__); \ |
305eb32d4 bug.h: work aroun... |
52 |
barrier_before_unreachable(); \ |
1da177e4c Linux-2.6.12-rc2 |
53 54 55 |
panic("BUG!"); \ } while (0) #endif |
1da177e4c Linux-2.6.12-rc2 |
56 |
#ifndef HAVE_ARCH_BUG_ON |
a3f7607d0 include/asm-gener... |
57 |
#define BUG_ON(condition) do { if (unlikely(condition)) BUG(); } while (0) |
1da177e4c Linux-2.6.12-rc2 |
58 |
#endif |
19d436268 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 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 panic: Allow warn... |
76 |
#ifndef __WARN_TAINT |
b9075fa96 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 Eliminate thousan... |
83 |
extern void warn_slowpath_null(const char *file, const int line); |
79b4cc5ee debug: move WARN_... |
84 |
#define WANT_WARN_ON_SLOWPATH |
57adc4d2d Eliminate thousan... |
85 86 |
#define __WARN() warn_slowpath_null(__FILE__, __LINE__) #define __WARN_printf(arg...) warn_slowpath_fmt(__FILE__, __LINE__, arg) |
b2be05273 panic: Allow warn... |
87 88 |
#define __WARN_printf_taint(taint, arg...) \ warn_slowpath_fmt_taint(__FILE__, __LINE__, taint, arg) |
a8f18b909 Add a WARN() macr... |
89 |
#else |
b2be05273 panic: Allow warn... |
90 |
#define __WARN() __WARN_TAINT(TAINT_WARN) |
ec5679e51 debug warnings: e... |
91 |
#define __WARN_printf(arg...) do { printk(arg); __WARN(); } while (0) |
b2be05273 panic: Allow warn... |
92 93 |
#define __WARN_printf_taint(taint, arg...) \ do { printk(arg); __WARN_TAINT(taint); } while (0) |
3a6a62f96 debug: introduce ... |
94 |
#endif |
2553b67a1 lib/bug.c: use co... |
95 96 |
/* used internally by panic.c */ struct warn_args; |
0b396923e asm-generic/bug.h... |
97 |
struct pt_regs; |
2553b67a1 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 debug: introduce ... |
101 |
#ifndef WARN_ON |
684f97834 [PATCH] Let WARN_... |
102 |
#define WARN_ON(condition) ({ \ |
8d4fbcfbe Fix WARN_ON() on ... |
103 |
int __ret_warn_on = !!(condition); \ |
3a6a62f96 debug: introduce ... |
104 105 |
if (unlikely(__ret_warn_on)) \ __WARN(); \ |
684f97834 [PATCH] Let WARN_... |
106 107 |
unlikely(__ret_warn_on); \ }) |
1da177e4c Linux-2.6.12-rc2 |
108 |
#endif |
a8f18b909 Add a WARN() macr... |
109 |
#ifndef WARN |
19d436268 debug: Add _ONCE(... |
110 |
#define WARN(condition, format...) ({ \ |
a8f18b909 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 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 debug: Add _ONCE(... |
123 |
#ifndef WARN_ON_ONCE |
d69a89226 [PATCH] Fix WARN_... |
124 |
#define WARN_ON_ONCE(condition) ({ \ |
7ccaba531 consolidate WARN_... |
125 |
static bool __section(.data.unlikely) __warned; \ |
8d4fbcfbe Fix WARN_ON() on ... |
126 |
int __ret_warn_once = !!(condition); \ |
d69a89226 [PATCH] Fix WARN_... |
127 |
\ |
dfbf2897d bug: set warn var... |
128 129 130 131 |
if (unlikely(__ret_warn_once && !__warned)) { \ __warned = true; \ WARN_ON(1); \ } \ |
d69a89226 [PATCH] Fix WARN_... |
132 |
unlikely(__ret_warn_once); \ |
74bb6a09b [PATCH] introduce... |
133 |
}) |
19d436268 debug: Add _ONCE(... |
134 |
#endif |
74bb6a09b [PATCH] introduce... |
135 |
|
45e9c0de2 warn: Turn the ne... |
136 |
#define WARN_ONCE(condition, format...) ({ \ |
7ccaba531 consolidate WARN_... |
137 |
static bool __section(.data.unlikely) __warned; \ |
45e9c0de2 warn: Turn the ne... |
138 139 |
int __ret_warn_once = !!(condition); \ \ |
dfbf2897d bug: set warn var... |
140 141 142 143 |
if (unlikely(__ret_warn_once && !__warned)) { \ __warned = true; \ WARN(1, format); \ } \ |
45e9c0de2 warn: Turn the ne... |
144 145 |
unlikely(__ret_warn_once); \ }) |
b2be05273 panic: Allow warn... |
146 |
#define WARN_TAINT_ONCE(condition, taint, format...) ({ \ |
7ccaba531 consolidate WARN_... |
147 |
static bool __section(.data.unlikely) __warned; \ |
b2be05273 panic: Allow warn... |
148 149 |
int __ret_warn_once = !!(condition); \ \ |
dfbf2897d bug: set warn var... |
150 151 152 153 |
if (unlikely(__ret_warn_once && !__warned)) { \ __warned = true; \ WARN_TAINT(1, taint, format); \ } \ |
b2be05273 panic: Allow warn... |
154 155 |
unlikely(__ret_warn_once); \ }) |
b607e70ec bug: when !CONFIG... |
156 157 |
#else /* !CONFIG_BUG */ #ifndef HAVE_ARCH_BUG |
a4b5d580e bug: Make BUG() a... |
158 |
#define BUG() do {} while (1) |
b607e70ec bug: when !CONFIG... |
159 160 161 |
#endif #ifndef HAVE_ARCH_BUG_ON |
3c047057d asm-generic: defa... |
162 |
#define BUG_ON(condition) do { if (condition) BUG(); } while (0) |
b607e70ec 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 bug: when !CONFIG... |
175 |
no_printk(format); \ |
b607e70ec 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 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 [PATCH] pi-futex:... |
212 213 214 |
#ifdef CONFIG_SMP # define WARN_ON_SMP(x) WARN_ON(x) #else |
ccd0d44fa 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 WARN_ON_SMP(): Al... |
222 |
# define WARN_ON_SMP(x) ({0;}) |
8eb94f80d [PATCH] pi-futex:... |
223 |
#endif |
2603efa31 bug.h: Fix up pow... |
224 |
#endif /* __ASSEMBLY__ */ |
1da177e4c Linux-2.6.12-rc2 |
225 |
#endif |