diff options
author | Oleg Nesterov <oleg@redhat.com> | 2013-05-16 17:43:55 +0200 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2013-05-19 10:04:50 -0700 |
commit | 49432a001824f973ccf8214c7ef9e8e72c974987 (patch) | |
tree | db701c0b38b0c9a63ed38ed7eea404f89f0baa11 /kernel | |
parent | ac087d8e21d7722266d913d766b5c8b87772cbb4 (diff) | |
download | kernel_samsung_espresso10-49432a001824f973ccf8214c7ef9e8e72c974987.zip kernel_samsung_espresso10-49432a001824f973ccf8214c7ef9e8e72c974987.tar.gz kernel_samsung_espresso10-49432a001824f973ccf8214c7ef9e8e72c974987.tar.bz2 |
usermodehelper: check subprocess_info->path != NULL
commit 264b83c07a84223f0efd0d1db9ccc66d6f88288f upstream.
argv_split(empty_or_all_spaces) happily succeeds, it simply returns
argc == 0 and argv[0] == NULL. Change call_usermodehelper_exec() to
check sub_info->path != NULL to avoid the crash.
This is the minimal fix, todo:
- perhaps we should change argv_split() to return NULL or change the
callers.
- kill or justify ->path[0] check
- narrow the scope of helper_lock()
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-By: Lucas De Marchi <lucas.demarchi@intel.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/kmod.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/kernel/kmod.c b/kernel/kmod.c index fabfe54..f625b4f 100644 --- a/kernel/kmod.c +++ b/kernel/kmod.c @@ -421,6 +421,11 @@ int call_usermodehelper_exec(struct subprocess_info *sub_info, int retval = 0; helper_lock(); + if (!sub_info->path) { + retval = -EINVAL; + goto out; + } + if (sub_info->path[0] == '\0') goto out; |