Commit 9d944ef3 authored by Oleg Nesterov's avatar Oleg Nesterov Committed by Linus Torvalds

usermodehelper: kill umh_wait, renumber UMH_* constants

No functional changes.  It is not sane to use UMH_KILLABLE with enum
umh_wait, but obviously we do not want another argument in
call_usermodehelper_* helpers.  Kill this enum, use the plain int.
Signed-off-by: default avatarOleg Nesterov <oleg@redhat.com>
Cc: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Tejun Heo <tj@kernel.org>
Cc: David Rientjes <rientjes@google.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent d0bd587a
...@@ -48,12 +48,9 @@ static inline int request_module_nowait(const char *name, ...) { return -ENOSYS; ...@@ -48,12 +48,9 @@ static inline int request_module_nowait(const char *name, ...) { return -ENOSYS;
struct cred; struct cred;
struct file; struct file;
enum umh_wait { #define UMH_NO_WAIT 0 /* don't wait at all */
UMH_NO_WAIT = -1, /* don't wait at all */ #define UMH_WAIT_EXEC 1 /* wait for the exec, but not the process */
UMH_WAIT_EXEC = 0, /* wait for the exec, but not the process */ #define UMH_WAIT_PROC 2 /* wait for the process to complete */
UMH_WAIT_PROC = 1, /* wait for the process to complete */
};
#define UMH_KILLABLE 4 /* wait for EXEC/PROC killable */ #define UMH_KILLABLE 4 /* wait for EXEC/PROC killable */
struct subprocess_info { struct subprocess_info {
...@@ -62,7 +59,7 @@ struct subprocess_info { ...@@ -62,7 +59,7 @@ struct subprocess_info {
char *path; char *path;
char **argv; char **argv;
char **envp; char **envp;
enum umh_wait wait; int wait;
int retval; int retval;
int (*init)(struct subprocess_info *info, struct cred *new); int (*init)(struct subprocess_info *info, struct cred *new);
void (*cleanup)(struct subprocess_info *info); void (*cleanup)(struct subprocess_info *info);
...@@ -80,15 +77,14 @@ void call_usermodehelper_setfns(struct subprocess_info *info, ...@@ -80,15 +77,14 @@ void call_usermodehelper_setfns(struct subprocess_info *info,
void *data); void *data);
/* Actually execute the sub-process */ /* Actually execute the sub-process */
int call_usermodehelper_exec(struct subprocess_info *info, enum umh_wait wait); int call_usermodehelper_exec(struct subprocess_info *info, int wait);
/* Free the subprocess_info. This is only needed if you're not going /* Free the subprocess_info. This is only needed if you're not going
to call call_usermodehelper_exec */ to call call_usermodehelper_exec */
void call_usermodehelper_freeinfo(struct subprocess_info *info); void call_usermodehelper_freeinfo(struct subprocess_info *info);
static inline int static inline int
call_usermodehelper_fns(char *path, char **argv, char **envp, call_usermodehelper_fns(char *path, char **argv, char **envp, int wait,
enum umh_wait wait,
int (*init)(struct subprocess_info *info, struct cred *new), int (*init)(struct subprocess_info *info, struct cred *new),
void (*cleanup)(struct subprocess_info *), void *data) void (*cleanup)(struct subprocess_info *), void *data)
{ {
...@@ -106,7 +102,7 @@ call_usermodehelper_fns(char *path, char **argv, char **envp, ...@@ -106,7 +102,7 @@ call_usermodehelper_fns(char *path, char **argv, char **envp,
} }
static inline int static inline int
call_usermodehelper(char *path, char **argv, char **envp, enum umh_wait wait) call_usermodehelper(char *path, char **argv, char **envp, int wait)
{ {
return call_usermodehelper_fns(path, argv, envp, wait, return call_usermodehelper_fns(path, argv, envp, wait,
NULL, NULL, NULL); NULL, NULL, NULL);
......
...@@ -257,12 +257,9 @@ static void __call_usermodehelper(struct work_struct *work) ...@@ -257,12 +257,9 @@ static void __call_usermodehelper(struct work_struct *work)
{ {
struct subprocess_info *sub_info = struct subprocess_info *sub_info =
container_of(work, struct subprocess_info, work); container_of(work, struct subprocess_info, work);
enum umh_wait wait = sub_info->wait; int wait = sub_info->wait & ~UMH_KILLABLE;
pid_t pid; pid_t pid;
if (wait != UMH_NO_WAIT)
wait &= ~UMH_KILLABLE;
/* CLONE_VFORK: wait until the usermode helper has execve'd /* CLONE_VFORK: wait until the usermode helper has execve'd
* successfully We need the data structures to stay around * successfully We need the data structures to stay around
* until that is done. */ * until that is done. */
...@@ -451,8 +448,7 @@ EXPORT_SYMBOL(call_usermodehelper_setfns); ...@@ -451,8 +448,7 @@ EXPORT_SYMBOL(call_usermodehelper_setfns);
* asynchronously if wait is not set, and runs as a child of keventd. * asynchronously if wait is not set, and runs as a child of keventd.
* (ie. it runs with full root capabilities). * (ie. it runs with full root capabilities).
*/ */
int call_usermodehelper_exec(struct subprocess_info *sub_info, int call_usermodehelper_exec(struct subprocess_info *sub_info, int wait)
enum umh_wait wait)
{ {
DECLARE_COMPLETION_ONSTACK(done); DECLARE_COMPLETION_ONSTACK(done);
int retval = 0; int retval = 0;
......
...@@ -91,7 +91,7 @@ static void umh_keys_cleanup(struct subprocess_info *info) ...@@ -91,7 +91,7 @@ static void umh_keys_cleanup(struct subprocess_info *info)
* Call a usermode helper with a specific session keyring. * Call a usermode helper with a specific session keyring.
*/ */
static int call_usermodehelper_keys(char *path, char **argv, char **envp, static int call_usermodehelper_keys(char *path, char **argv, char **envp,
struct key *session_keyring, enum umh_wait wait) struct key *session_keyring, int wait)
{ {
gfp_t gfp_mask = (wait == UMH_NO_WAIT) ? GFP_ATOMIC : GFP_KERNEL; gfp_t gfp_mask = (wait == UMH_NO_WAIT) ? GFP_ATOMIC : GFP_KERNEL;
struct subprocess_info *info = struct subprocess_info *info =
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment