[<prev] [next>] [day] [month] [year] [list]
Message-ID: <20080123203650.17b31d55@laptopd505.fenrus.org>
Date: Wed, 23 Jan 2008 20:36:50 -0800
From: Arjan van de Ven <arjan@...radead.org>
To: mingo@...e.hu, a.p.zijlstra@...llo.nl,
torvalds@...ux-foundation.org
Cc: flamingice@...rmilk.net, akpm@...ux-foundation.org,
linux-kernel@...r.kernel.org, reinette.chatre@...el.com
Subject: [patch] lockdep: fix kernel crash on module unload
Hi Linus, Peter, Ingo,
we're seeing a VERY repeatable oops on module unload on the Intel
wireless drivers with lockdep enabled; turns out Michael Wu had already
rootcaused this type of crash (see URL below), however the fix he has
would increase the structure size of the lockdep metadata a lot; a much
simpler fix for the oops is in the patch below; the lockdep module
unload code just was not agressive enough in detecting which metadata
structures to nuke. With this patch a very repeatable oops on unload
went away (Reinette tested it and it survived > 100 unload cycles now).
The oops happens even in 2.6.24-rc8 and the fix is rather obvious, so
it might even be 2.6.24 material (or for 24-stable just after that)
--------
Subject: lockdep: fix kernel crash on module unload
From: Arjan van de Ven <arjan@...ux.intel.com>
Michael Wu noticed in his lkml post at
http://marc.info/?l=linux-kernel&m=119396182726091&w=2
that certain wireless drivers ended up having their name
in module memory, which would then crash the kernel on module
unload.
The patch he proposed was a bit clumsy in that it increased the
size of a lockdep entry significantly; the patch below tries another
approach, it checks, on module teardown, if the name of a class is
in module space and then zaps the class. This is very similar to what
we already do with keys that are in module space.
Signed-off-by: Arjan van de Ven <arjan@...ux.intel.com>
---
kernel/lockdep.c | 7 +++++--
1 file changed, 5 insertions(+), 2 deletions(-)
Index: linux-2.6.24-rc8/kernel/lockdep.c
===================================================================
--- linux-2.6.24-rc8.orig/kernel/lockdep.c
+++ linux-2.6.24-rc8/kernel/lockdep.c
@@ -2932,7 +2932,7 @@ static void zap_class(struct lock_class
}
-static inline int within(void *addr, void *start, unsigned long size)
+static inline int within(const void *addr, void *start, unsigned long size)
{
return addr >= start && addr < start + size;
}
@@ -2954,9 +2954,12 @@ void lockdep_free_key_range(void *start,
head = classhash_table + i;
if (list_empty(head))
continue;
- list_for_each_entry_safe(class, next, head, hash_entry)
+ list_for_each_entry_safe(class, next, head, hash_entry) {
if (within(class->key, start, size))
zap_class(class);
+ else if (within(class->name, start, size))
+ zap_class(class);
+ }
}
graph_unlock();
--
If you want to reach me at my work email, use arjan@...ux.intel.com
For development, discussion and tips for power savings,
visit http://www.lesswatts.org
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists