mirror of https://github.com/hak5/openwrt.git
parent
4625c9b5a4
commit
8e662f28fe
|
@ -0,0 +1,47 @@
|
||||||
|
From df754e6af2f237a6c020c0daff55a1a609338e31 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Zijlstra <a.p.zijlstra@chello.nl>
|
||||||
|
Date: Mon, 14 Nov 2011 13:13:49 +0100
|
||||||
|
Subject: [PATCH 1/2] lockdep, bug: Exclude TAINT_FIRMWARE_WORKAROUND from disabling lockdep
|
||||||
|
|
||||||
|
It's unlikely that TAINT_FIRMWARE_WORKAROUND causes false
|
||||||
|
lockdep messages, so do not disable lockdep in that case.
|
||||||
|
We still want to keep lockdep disabled in the
|
||||||
|
TAINT_OOT_MODULE case:
|
||||||
|
|
||||||
|
- bin-only modules can cause various instabilities in
|
||||||
|
their and in unrelated kernel code
|
||||||
|
|
||||||
|
- they are impossible to debug for kernel developers
|
||||||
|
|
||||||
|
- they also typically do not have the copyright license
|
||||||
|
permission to link to the GPL-ed lockdep code.
|
||||||
|
|
||||||
|
Suggested-by: Ben Hutchings <ben@decadent.org.uk>
|
||||||
|
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
|
||||||
|
Link: http://lkml.kernel.org/n/tip-xopopjjens57r0i13qnyh2yo@git.kernel.org
|
||||||
|
Signed-off-by: Ingo Molnar <mingo@elte.hu>
|
||||||
|
---
|
||||||
|
kernel/panic.c | 12 ++++++++++--
|
||||||
|
1 files changed, 10 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
--- a/kernel/panic.c
|
||||||
|
+++ b/kernel/panic.c
|
||||||
|
@@ -240,8 +240,16 @@ void add_taint(unsigned flag)
|
||||||
|
* Also we want to keep up lockdep for staging development and
|
||||||
|
* post-warning case.
|
||||||
|
*/
|
||||||
|
- if (flag != TAINT_CRAP && flag != TAINT_WARN && __debug_locks_off())
|
||||||
|
- printk(KERN_WARNING "Disabling lock debugging due to kernel taint\n");
|
||||||
|
+ switch (flag) {
|
||||||
|
+ case TAINT_CRAP:
|
||||||
|
+ case TAINT_WARN:
|
||||||
|
+ case TAINT_FIRMWARE_WORKAROUND:
|
||||||
|
+ break;
|
||||||
|
+
|
||||||
|
+ default:
|
||||||
|
+ if (__debug_locks_off())
|
||||||
|
+ printk(KERN_WARNING "Disabling lock debugging due to kernel taint\n");
|
||||||
|
+ }
|
||||||
|
|
||||||
|
set_bit(flag, &tainted_mask);
|
||||||
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
From 9ec84acee1e221d99dc33237bff5e82839d10cc0 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Ben Hutchings <ben@decadent.org.uk>
|
||||||
|
Date: Wed, 7 Dec 2011 14:30:58 +0000
|
||||||
|
Subject: [PATCH 2/2] lockdep, bug: Exclude TAINT_OOT_MODULE from disabling lock debugging
|
||||||
|
|
||||||
|
We do want to allow lock debugging for GPL-compatible modules
|
||||||
|
that are not (yet) built in-tree. This was disabled as a
|
||||||
|
side-effect of commit 2449b8ba0745327c5fa49a8d9acffe03b2eded69
|
||||||
|
('module,bug: Add TAINT_OOT_MODULE flag for modules not built
|
||||||
|
in-tree'). Lock debug warnings now include taint flags, so
|
||||||
|
kernel developers should still be able to deflect warnings
|
||||||
|
caused by out-of-tree modules.
|
||||||
|
|
||||||
|
The TAINT_PROPRIETARY_MODULE flag for non-GPL-compatible modules
|
||||||
|
will still disable lock debugging.
|
||||||
|
|
||||||
|
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
|
||||||
|
Cc: Nick Bowler <nbowler@elliptictech.com>
|
||||||
|
Cc: Greg KH <greg@kroah.com>
|
||||||
|
Cc: Dave Jones <davej@redhat.com>
|
||||||
|
Cc: Rusty Russell <rusty@rustcorp.com.au>
|
||||||
|
Cc: Randy Dunlap <rdunlap@xenotime.net>
|
||||||
|
Cc: Debian kernel maintainers <debian-kernel@lists.debian.org>
|
||||||
|
Cc: Peter Zijlstra <peterz@infradead.org>
|
||||||
|
Cc: Alan Cox <alan@linux.intel.com>
|
||||||
|
Link: http://lkml.kernel.org/r/1323268258.18450.11.camel@deadeye
|
||||||
|
Signed-off-by: Ingo Molnar <mingo@elte.hu>
|
||||||
|
---
|
||||||
|
kernel/panic.c | 5 +++--
|
||||||
|
1 files changed, 3 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
--- a/kernel/panic.c
|
||||||
|
+++ b/kernel/panic.c
|
||||||
|
@@ -237,11 +237,12 @@ void add_taint(unsigned flag)
|
||||||
|
* Can't trust the integrity of the kernel anymore.
|
||||||
|
* We don't call directly debug_locks_off() because the issue
|
||||||
|
* is not necessarily serious enough to set oops_in_progress to 1
|
||||||
|
- * Also we want to keep up lockdep for staging development and
|
||||||
|
- * post-warning case.
|
||||||
|
+ * Also we want to keep up lockdep for staging/out-of-tree
|
||||||
|
+ * development and post-warning case.
|
||||||
|
*/
|
||||||
|
switch (flag) {
|
||||||
|
case TAINT_CRAP:
|
||||||
|
+ case TAINT_OOT_MODULE:
|
||||||
|
case TAINT_WARN:
|
||||||
|
case TAINT_FIRMWARE_WORKAROUND:
|
||||||
|
break;
|
Loading…
Reference in New Issue