Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /* |
| 3 | * lib/bust_spinlocks.c |
| 4 | * |
| 5 | * Provides a minimal bust_spinlocks for architectures which don't have one of their own. |
| 6 | * |
| 7 | * bust_spinlocks() clears any spinlocks which would prevent oops, die(), BUG() |
| 8 | * and panic() information from reaching the user. |
| 9 | */ |
| 10 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 | #include <linux/kernel.h> |
Frederic Weisbecker | dc72c32 | 2013-03-22 15:04:39 -0700 | [diff] [blame] | 12 | #include <linux/printk.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 13 | #include <linux/spinlock.h> |
| 14 | #include <linux/tty.h> |
| 15 | #include <linux/wait.h> |
| 16 | #include <linux/vt_kern.h> |
Viktor Rosendahl | b61312d | 2009-01-06 14:40:42 -0800 | [diff] [blame] | 17 | #include <linux/console.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 18 | |
| 19 | |
Kirill Korotaev | cefc8be | 2007-02-10 01:46:18 -0800 | [diff] [blame] | 20 | void __attribute__((weak)) bust_spinlocks(int yes) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 21 | { |
| 22 | if (yes) { |
Jan Beulich | 0044299 | 2007-10-16 23:29:33 -0700 | [diff] [blame] | 23 | ++oops_in_progress; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | } else { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | #ifdef CONFIG_VT |
| 26 | unblank_screen(); |
| 27 | #endif |
Viktor Rosendahl | b61312d | 2009-01-06 14:40:42 -0800 | [diff] [blame] | 28 | console_unblank(); |
Jan Beulich | 0044299 | 2007-10-16 23:29:33 -0700 | [diff] [blame] | 29 | if (--oops_in_progress == 0) |
| 30 | wake_up_klogd(); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | } |
| 32 | } |