diff options
author | Josh Poimboeuf <jpoimboe@redhat.com> | 2017-07-15 01:10:58 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2017-07-20 06:31:04 -0400 |
commit | 325cdacd03c12629aa5f9ee2ace49b1f3dc184a8 (patch) | |
tree | f9bafe49be8aa9e98a0afb4a4a4009e5d4a7561f /arch/blackfin | |
parent | 095f6d76221dd4b99d004e4c826ac4382c6ce5e3 (diff) |
debug: Fix WARN_ON_ONCE() for modules
Mike Galbraith reported a situation where a WARN_ON_ONCE() call in DRM
code turned into an oops. As it turns out, WARN_ON_ONCE() seems to be
completely broken when called from a module.
The bug was introduced with the following commit:
19d436268dde ("debug: Add _ONCE() logic to report_bug()")
That commit changed WARN_ON_ONCE() to move its 'once' logic into the bug
trap handler. It requires a writable bug table so that the BUGFLAG_DONE
bit can be written to the flags to indicate the first warning has
occurred.
The bug table was made writable for vmlinux, which relies on
vmlinux.lds.S and vmlinux.lds.h for laying out the sections. However,
it wasn't made writable for modules, which rely on the ELF section
header flags.
Reported-by: Mike Galbraith <efault@gmx.de>
Tested-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com>
Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Fixes: 19d436268dde ("debug: Add _ONCE() logic to report_bug()")
Link: http://lkml.kernel.org/r/a53b04235a65478dd9afc51f5b329fdc65c84364.1500095401.git.jpoimboe@redhat.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'arch/blackfin')
-rw-r--r-- | arch/blackfin/include/asm/bug.h | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/blackfin/include/asm/bug.h b/arch/blackfin/include/asm/bug.h index 8d9b1eba89c4..76b2e82ee730 100644 --- a/arch/blackfin/include/asm/bug.h +++ b/arch/blackfin/include/asm/bug.h | |||
@@ -21,7 +21,7 @@ | |||
21 | #define _BUG_OR_WARN(flags) \ | 21 | #define _BUG_OR_WARN(flags) \ |
22 | asm volatile( \ | 22 | asm volatile( \ |
23 | "1: .hword %0\n" \ | 23 | "1: .hword %0\n" \ |
24 | " .section __bug_table,\"a\",@progbits\n" \ | 24 | " .section __bug_table,\"aw\",@progbits\n" \ |
25 | "2: .long 1b\n" \ | 25 | "2: .long 1b\n" \ |
26 | " .long %1\n" \ | 26 | " .long %1\n" \ |
27 | " .short %2\n" \ | 27 | " .short %2\n" \ |
@@ -38,7 +38,7 @@ | |||
38 | #define _BUG_OR_WARN(flags) \ | 38 | #define _BUG_OR_WARN(flags) \ |
39 | asm volatile( \ | 39 | asm volatile( \ |
40 | "1: .hword %0\n" \ | 40 | "1: .hword %0\n" \ |
41 | " .section __bug_table,\"a\",@progbits\n" \ | 41 | " .section __bug_table,\"aw\",@progbits\n" \ |
42 | "2: .long 1b\n" \ | 42 | "2: .long 1b\n" \ |
43 | " .short %1\n" \ | 43 | " .short %1\n" \ |
44 | " .org 2b + %2\n" \ | 44 | " .org 2b + %2\n" \ |