Login | Register For Free | Help
Search for: (Advanced)

Mailing List Archive: Linux: Kernel
[PATCH] kernel/module.c - fix warning and reduce stack usage - reintroduction of mistakenly dropped patch
 

Index | Next | Previous | View Flat


juhl-lkml at dif

Apr 2, 2005, 3:57 PM


Views: 330
Permalink
[PATCH] kernel/module.c - fix warning and reduce stack usage - reintroduction of mistakenly dropped patch

Hi Andrew,

Reading your 2.6.12-rc1-mm4 announce text I see

...
-figure-out-who-is-inserting-bogus-modules-warning-fix.patch

Folded into figure-out-who-is-inserting-bogus-modules.patch
...
figure-out-who-is-inserting-bogus-modules.patch
Figure out who is inserting bogus modules
...

However, it seems you did *not* roll
figure-out-who-is-inserting-bogus-modules-warning-fix.patch into
figure-out-who-is-inserting-bogus-modules.patch but instead just dropped
the patch.

It also turns out I had a small boundary error (off-by-one) in my original
patch which Yum Rayan spotted and fixed in a patch he wrote that also
reduces the stack usage of the function (by dynamically allocating the
needed mem for 'args' instead of using a static 512 byte array - see the
LKML thread with subject "[PATCH] Reduce stack usage in module.c"), so
below you'll find an updated patch that reintroduce
figure-out-who-is-inserting-bogus-modules-warning-fix.patch on top of
2.6.12-rc1-mm4 and includes Yum Rayan's fix for the off-by-one and also
adopts his use of kmalloc() instead of large static array.

Yum Rayan's patch does more than what I've included below, I've only
included his changes to the who_is_doing_it() function, if you want the
rest of his changes then please see the original thread for his full
patch.

Here's the updated figure-out-who-is-inserting-bogus-modules-warning-fix.patch

Signed-off-by: Jesper Juhl <juhl-lkml[at]dif.dk>

--- linux-2.6.12-rc1-mm4-orig/kernel/module.c 2005-03-31 21:20:07.000000000 +0200
+++ linux-2.6.12-rc1-mm4/kernel/module.c 2005-04-03 01:54:30.000000000 +0200
@@ -1399,10 +1399,19 @@ static inline void add_kallsyms(struct m
static void who_is_doing_it(void)
{
/* Print out all the args. */
- char args[512];
- unsigned int i, len = current->mm->arg_end - current->mm->arg_start;
+ char *args;
+ unsigned long i, len = current->mm->arg_end - current->mm->arg_start;

- copy_from_user(args, (void *)current->mm->arg_start, len);
+ if (len > 512)
+ len = 512;
+
+ args = kmalloc(len + 1, GFP_KERNEL);
+ if (!args) {
+ printk(KERN_WARNING "Unable to allocate memory, can't print who's inserting bogus modules\n");
+ return;
+ }
+
+ len -= copy_from_user(args, (void *)current->mm->arg_start, len);

for (i = 0; i < len; i++) {
if (args[i] == '\0')
@@ -1410,6 +1419,7 @@ static void who_is_doing_it(void)
}
args[i] = 0;
printk("ARGS: %s\n", args);
+ kfree(args);
}

/* Allocate and load the module: note that size of section 0 is always


-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo[at]vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/

Subject User Time
[PATCH] kernel/module.c - fix warning and reduce stack usage - reintroduction of mistakenly dropped patch juhl-lkml at dif Apr 2, 2005, 3:57 PM
    Re: [PATCH] kernel/module.c - fix warning and reduce stack usage - reintroduction of mistakenly dropped patch juhl-lkml at dif Apr 2, 2005, 3:05 PM
    Re: [PATCH] kernel/module.c - fix warning and reduce stack usage - reintroduction of mistakenly dropped patch akpm at osdl Apr 2, 2005, 3:57 PM
        Re: [PATCH] kernel/module.c - fix warning and reduce stack usage - reintroduction of mistakenly dropped patch juhl-lkml at dif Apr 2, 2005, 3:06 PM

  Index | Next | Previous | View Flat
 
 


Interested in having your list archived? Contact lists@gossamer-threads.com
 
  Web Applications & Managed Hosting Powered by Gossamer Threads Inc.