Am Mittwoch 06 Juli 2011, 13:28:18 schrieb Tetsuo Handa: > Richard Weinberger wrote: > > But IMHO adding a new attribute to task_struct is a bit overkill. > > Indeed. I came up with a simpler solution. ;-) > ---------------------------------------- > [PATCH] exec: Do not call request_module() twice from > search_binary_handler(). > > Currently, search_binary_handler() tries to load binary loader module using > request_module() if a loader for the requested program is not yet loaded. > But second attempt of request_module() does not affect the result of > search_binary_handler(). > > If request_module() triggered recursion, calling request_module() twice > causes 2 to the power of MAX_KMOD_CONCURRENT (= 50) repetitions. It is not > an infinite loop but is sufficient for users to consider as a hang up. > > Therefore, this patch changes not to call request_module() twice, making > 1 to the power of MAX_KMOD_CONCURRENT repetitions in case of recursion. > > Signed-off-by: Tetsuo Handa <penguin-kernel@xxxxxxxxxxxxxxxxxxx> > --- > diff --git a/fs/exec.c b/fs/exec.c > index 6075a1e..044c13f 100644 > --- a/fs/exec.c > +++ b/fs/exec.c > @@ -1411,6 +1411,8 @@ int search_binary_handler(struct linux_binprm > *bprm,struct pt_regs *regs) printable(bprm->buf[2]) && > printable(bprm->buf[3])) > break; /* -ENOEXEC */ > + if (try) > + break; /* -ENOEXEC */ > request_module("binfmt-%04x", *(unsigned short *)(&bprm->buf[2])); > #endif > } Nice solution. :-) Tested-by: Richard Weinberger <richard@xxxxxx> Thanks, //richard -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html