diff options
| author | Oleg Nesterov <oleg@redhat.com> | 2012-03-23 18:02:48 -0400 |
|---|---|---|
| committer | Luis Henriques <luis.henriques@canonical.com> | 2012-04-05 11:17:14 -0400 |
| commit | 322f5cfdfdcf001f8e9f53a6342ead60e9a6d077 (patch) | |
| tree | 7da07e8d7244d4f72f9d7f896477ace06b121eb7 /include/linux | |
| parent | de7db9c247875ac10d4d27da70c668109e0108cf (diff) | |
usermodehelper: kill umh_wait, renumber UMH_* constants
BugLink: http://bugs.launchpad.net/bugs/963685
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: Oleg 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: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
(cherry picked from commit 9d944ef32e83405a07376f112e9f02161d3e9731)
Signed-off-by: Tim Gardner <tim.gardner@canonical.com>
Acked-by: Stefan Bader <stefan.bader@canonical.com>
Acked-by: Andy Whitcroft <andy.whitcroft@canonical.com>
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/kmod.h | 18 |
1 files changed, 7 insertions, 11 deletions
diff --git a/include/linux/kmod.h b/include/linux/kmod.h index 846f5695230..0f2c5a6b054 100644 --- a/include/linux/kmod.h +++ b/include/linux/kmod.h | |||
| @@ -48,12 +48,9 @@ static inline int request_module_nowait(const char *name, ...) { return -ENOSYS; | |||
| 48 | struct cred; | 48 | struct cred; |
| 49 | struct file; | 49 | struct file; |
| 50 | 50 | ||
| 51 | enum umh_wait { | 51 | #define UMH_NO_WAIT 0 /* don't wait at all */ |
| 52 | UMH_NO_WAIT = -1, /* don't wait at all */ | 52 | #define UMH_WAIT_EXEC 1 /* wait for the exec, but not the process */ |
| 53 | UMH_WAIT_EXEC = 0, /* wait for the exec, but not the process */ | 53 | #define UMH_WAIT_PROC 2 /* wait for the process to complete */ |
| 54 | UMH_WAIT_PROC = 1, /* wait for the process to complete */ | ||
| 55 | }; | ||
| 56 | |||
| 57 | #define UMH_KILLABLE 4 /* wait for EXEC/PROC killable */ | 54 | #define UMH_KILLABLE 4 /* wait for EXEC/PROC killable */ |
| 58 | 55 | ||
| 59 | struct subprocess_info { | 56 | struct subprocess_info { |
| @@ -62,7 +59,7 @@ struct subprocess_info { | |||
| 62 | char *path; | 59 | char *path; |
| 63 | char **argv; | 60 | char **argv; |
| 64 | char **envp; | 61 | char **envp; |
| 65 | enum umh_wait wait; | 62 | int wait; |
| 66 | int retval; | 63 | int retval; |
| 67 | int (*init)(struct subprocess_info *info, struct cred *new); | 64 | int (*init)(struct subprocess_info *info, struct cred *new); |
| 68 | void (*cleanup)(struct subprocess_info *info); | 65 | void (*cleanup)(struct subprocess_info *info); |
| @@ -80,7 +77,7 @@ void call_usermodehelper_setfns(struct subprocess_info *info, | |||
| 80 | void *data); | 77 | void *data); |
| 81 | 78 | ||
| 82 | /* Actually execute the sub-process */ | 79 | /* Actually execute the sub-process */ |
| 83 | int call_usermodehelper_exec(struct subprocess_info *info, enum umh_wait wait); | 80 | int call_usermodehelper_exec(struct subprocess_info *info, int wait); |
| 84 | 81 | ||
| 85 | /* Free the subprocess_info. This is only needed if you're not going | 82 | /* Free the subprocess_info. This is only needed if you're not going |
| 86 | to call call_usermodehelper_exec */ | 83 | to call call_usermodehelper_exec */ |
| @@ -89,8 +86,7 @@ void call_usermodehelper_freeinfo(struct subprocess_info *info); | |||
| 89 | extern void populate_rootfs_wait(void); | 86 | extern void populate_rootfs_wait(void); |
| 90 | 87 | ||
| 91 | static inline int | 88 | static inline int |
| 92 | call_usermodehelper_fns(char *path, char **argv, char **envp, | 89 | call_usermodehelper_fns(char *path, char **argv, char **envp, int wait, |
| 93 | enum umh_wait wait, | ||
| 94 | int (*init)(struct subprocess_info *info, struct cred *new), | 90 | int (*init)(struct subprocess_info *info, struct cred *new), |
| 95 | void (*cleanup)(struct subprocess_info *), void *data) | 91 | void (*cleanup)(struct subprocess_info *), void *data) |
| 96 | { | 92 | { |
| @@ -110,7 +106,7 @@ call_usermodehelper_fns(char *path, char **argv, char **envp, | |||
| 110 | } | 106 | } |
| 111 | 107 | ||
| 112 | static inline int | 108 | static inline int |
| 113 | call_usermodehelper(char *path, char **argv, char **envp, enum umh_wait wait) | 109 | call_usermodehelper(char *path, char **argv, char **envp, int wait) |
| 114 | { | 110 | { |
| 115 | return call_usermodehelper_fns(path, argv, envp, wait, | 111 | return call_usermodehelper_fns(path, argv, envp, wait, |
| 116 | NULL, NULL, NULL); | 112 | NULL, NULL, NULL); |
