]> err.no Git - linux-2.6/commitdiff
Modules: fix memory leak of module names
authorGreg Kroah-Hartman <gregkh@suse.de>
Sun, 23 Dec 2007 05:18:25 +0000 (21:18 -0800)
committerGreg Kroah-Hartman <gregkh@suse.de>
Sun, 23 Dec 2007 07:09:05 +0000 (23:09 -0800)
Due to the change in kobject name handling, the module kobject needs to
have a null release function to ensure that the name it previously set
will be properly cleaned up.

All of this wierdness goes away in 2.6.25 with the rework of the kobject
name and cleanup logic, but this is required for 2.6.24.

Thanks to Alexey Dobriyan for finding the problem, and to Kay Sievers
for pointing out the simple way to fix it after I tried many complex
ways.

Cc: Alexey Dobriyan <adobriyan@gmail.com>
Cc: Kay Sievers <kay.sievers@vrfy.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
kernel/params.c

index 2a4c51487e7257e1865ae33d805a22e3dbb7f9ae..7686417ee00eba070b7d9b5c9dd293f9991199f1 100644 (file)
@@ -697,8 +697,18 @@ static struct kset_uevent_ops module_uevent_ops = {
 decl_subsys(module, &module_ktype, &module_uevent_ops);
 int module_sysfs_initialized;
 
+static void module_release(struct kobject *kobj)
+{
+       /*
+        * Stupid empty release function to allow the memory for the kobject to
+        * be properly cleaned up.  This will not need to be present for 2.6.25
+        * with the upcoming kobject core rework.
+        */
+}
+
 static struct kobj_type module_ktype = {
        .sysfs_ops =    &module_sysfs_ops,
+       .release =      module_release,
 };
 
 /*