On Wed, 4 Jul 2012 11:31:47 +0800 Cong Wang <amw...@redhat.com> wrote:
> From: WANG Cong <xiyou.wangc...@gmail.com> > > When argv_split() fails, argv is NULL, thus we should avoid calling > agrv_free(argv), and should jump after it. > > Cc: Cyrill Gorcunov <gorcu...@openvz.org> > Cc: Kees Cook <keesc...@chromium.org> > Cc: Serge Hallyn <serge.hal...@canonical.com> > Cc: "Eric W. Biederman" <ebied...@xmission.com> > Cc: Andrew Morton <a...@linux-foundation.org> > Signed-off-by: WANG Cong <xiyou.wangc...@gmail.com> > > --- > diff --git a/kernel/sys.c b/kernel/sys.c > index e0c8ffc..ffa510f 100644 > --- a/kernel/sys.c > +++ b/kernel/sys.c > @@ -2217,13 +2217,13 @@ int orderly_poweroff(bool force) > > ret = call_usermodehelper_fns(argv[0], argv, envp, UMH_NO_WAIT, > NULL, argv_cleanup, NULL); > -out: > if (likely(!ret)) > return 0; > > if (ret == -ENOMEM) > argv_free(argv); > > +out: > if (force) { > printk(KERN_WARNING "Failed to start orderly shutdown: " > "forcing the issue\n"); That code's still pretty stupid-looking, and it's such convoluted code which leads to bugs of this nature. Please, always feel free to step back a bit and think about the overall structure, see if it can be improved. eg... From: Andrew Morton <a...@linux-foundation.org> Subject: kernel/sys.c: avoid argv_free(NULL) If argv_split() failed, the code will end up calling argv_free(NULL). Fix it up and clean things up a bit. Addresses Coverity report 703573. Cc: Cyrill Gorcunov <gorcu...@openvz.org> Cc: Kees Cook <keesc...@chromium.org> Cc: Serge Hallyn <serge.hal...@canonical.com> Cc: "Eric W. Biederman" <ebied...@xmission.com> Cc: WANG Cong <xiyou.wangc...@gmail.com> Cc: Alan Cox <a...@linux.intel.com> Cc: David Rientjes <rient...@google.com> Signed-off-by: Andrew Morton <a...@linux-foundation.org> --- kernel/sys.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff -puN kernel/sys.c~kernel-sysc-avoid-argv_freenull kernel/sys.c --- a/kernel/sys.c~kernel-sysc-avoid-argv_freenull +++ a/kernel/sys.c @@ -2196,25 +2196,25 @@ static void argv_cleanup(struct subproce int orderly_poweroff(bool force) { int argc; - char **argv = argv_split(GFP_ATOMIC, poweroff_cmd, &argc); + char **argv; static char *envp[] = { "HOME=/", "PATH=/sbin:/bin:/usr/sbin:/usr/bin", NULL }; - int ret = -ENOMEM; + int ret; + argv = argv_split(GFP_ATOMIC, poweroff_cmd, &argc); if (argv == NULL) { printk(KERN_WARNING "%s failed to allocate memory for \"%s\"\n", __func__, poweroff_cmd); - goto out; + return -ENOMEM; } ret = call_usermodehelper_fns(argv[0], argv, envp, UMH_NO_WAIT, NULL, argv_cleanup, NULL); -out: if (likely(!ret)) - return 0; + return 0; /* success */ if (ret == -ENOMEM) argv_free(argv); _ -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/