diff options
Diffstat (limited to 'kernel/panic.c')
| -rw-r--r-- | kernel/panic.c | 25 |
1 files changed, 20 insertions, 5 deletions
diff --git a/kernel/panic.c b/kernel/panic.c index 3fd8c5bf8b39..874ecf1307ae 100644 --- a/kernel/panic.c +++ b/kernel/panic.c | |||
| @@ -213,8 +213,16 @@ unsigned long get_taint(void) | |||
| 213 | 213 | ||
| 214 | void add_taint(unsigned flag) | 214 | void add_taint(unsigned flag) |
| 215 | { | 215 | { |
| 216 | /* can't trust the integrity of the kernel anymore: */ | 216 | /* |
| 217 | debug_locks = 0; | 217 | * Can't trust the integrity of the kernel anymore. |
| 218 | * We don't call directly debug_locks_off() because the issue | ||
| 219 | * is not necessarily serious enough to set oops_in_progress to 1 | ||
| 220 | * Also we want to keep up lockdep for staging development and | ||
| 221 | * post-warning case. | ||
| 222 | */ | ||
| 223 | if (flag != TAINT_CRAP && flag != TAINT_WARN && __debug_locks_off()) | ||
| 224 | printk(KERN_WARNING "Disabling lock debugging due to kernel taint\n"); | ||
| 225 | |||
| 218 | set_bit(flag, &tainted_mask); | 226 | set_bit(flag, &tainted_mask); |
| 219 | } | 227 | } |
| 220 | EXPORT_SYMBOL(add_taint); | 228 | EXPORT_SYMBOL(add_taint); |
| @@ -332,7 +340,7 @@ void oops_exit(void) | |||
| 332 | } | 340 | } |
| 333 | 341 | ||
| 334 | #ifdef WANT_WARN_ON_SLOWPATH | 342 | #ifdef WANT_WARN_ON_SLOWPATH |
| 335 | void warn_slowpath(const char *file, int line, const char *fmt, ...) | 343 | void warn_slowpath_fmt(const char *file, int line, const char *fmt, ...) |
| 336 | { | 344 | { |
| 337 | va_list args; | 345 | va_list args; |
| 338 | char function[KSYM_SYMBOL_LEN]; | 346 | char function[KSYM_SYMBOL_LEN]; |
| @@ -348,7 +356,7 @@ void warn_slowpath(const char *file, int line, const char *fmt, ...) | |||
| 348 | if (board) | 356 | if (board) |
| 349 | printk(KERN_WARNING "Hardware name: %s\n", board); | 357 | printk(KERN_WARNING "Hardware name: %s\n", board); |
| 350 | 358 | ||
| 351 | if (fmt) { | 359 | if (*fmt) { |
| 352 | va_start(args, fmt); | 360 | va_start(args, fmt); |
| 353 | vprintk(fmt, args); | 361 | vprintk(fmt, args); |
| 354 | va_end(args); | 362 | va_end(args); |
| @@ -359,7 +367,14 @@ void warn_slowpath(const char *file, int line, const char *fmt, ...) | |||
| 359 | print_oops_end_marker(); | 367 | print_oops_end_marker(); |
| 360 | add_taint(TAINT_WARN); | 368 | add_taint(TAINT_WARN); |
| 361 | } | 369 | } |
| 362 | EXPORT_SYMBOL(warn_slowpath); | 370 | EXPORT_SYMBOL(warn_slowpath_fmt); |
| 371 | |||
| 372 | void warn_slowpath_null(const char *file, int line) | ||
| 373 | { | ||
| 374 | static const char *empty = ""; | ||
| 375 | warn_slowpath_fmt(file, line, empty); | ||
| 376 | } | ||
| 377 | EXPORT_SYMBOL(warn_slowpath_null); | ||
| 363 | #endif | 378 | #endif |
| 364 | 379 | ||
| 365 | #ifdef CONFIG_CC_STACKPROTECTOR | 380 | #ifdef CONFIG_CC_STACKPROTECTOR |
