exec: simplify the copy_strings_kernel calling convention
authorChristoph Hellwig <hch@lst.de>
Thu, 4 Jun 2020 23:51:14 +0000 (16:51 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Fri, 5 Jun 2020 02:06:26 +0000 (19:06 -0700)
copy_strings_kernel is always used with a single argument,
adjust the calling convention to that.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Link: http://lkml.kernel.org/r/20200501104105.2621149-2-hch@lst.de
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
fs/binfmt_em86.c
fs/binfmt_misc.c
fs/binfmt_script.c
fs/exec.c
include/linux/binfmts.h

index 4664978..f33fa66 100644 (file)
@@ -68,15 +68,15 @@ static int load_em86(struct linux_binprm *bprm)
         * user environment and arguments are stored.
         */
        remove_arg_zero(bprm);
-       retval = copy_strings_kernel(1, &bprm->filename, bprm);
+       retval = copy_string_kernel(bprm->filename, bprm);
        if (retval < 0) return retval; 
        bprm->argc++;
        if (i_arg) {
-               retval = copy_strings_kernel(1, &i_arg, bprm);
+               retval = copy_string_kernel(i_arg, bprm);
                if (retval < 0) return retval; 
                bprm->argc++;
        }
-       retval = copy_strings_kernel(1, &i_name, bprm);
+       retval = copy_string_kernel(i_name, bprm);
        if (retval < 0) return retval;
        bprm->argc++;
 
index cdb4582..b15257d 100644 (file)
@@ -190,13 +190,13 @@ static int load_misc_binary(struct linux_binprm *bprm)
                bprm->file = NULL;
        }
        /* make argv[1] be the path to the binary */
-       retval = copy_strings_kernel(1, &bprm->interp, bprm);
+       retval = copy_string_kernel(bprm->interp, bprm);
        if (retval < 0)
                goto error;
        bprm->argc++;
 
        /* add the interp as argv[0] */
-       retval = copy_strings_kernel(1, &fmt->interpreter, bprm);
+       retval = copy_string_kernel(fmt->interpreter, bprm);
        if (retval < 0)
                goto error;
        bprm->argc++;
index e9e6a6f..c4fb7f5 100644 (file)
@@ -117,17 +117,17 @@ static int load_script(struct linux_binprm *bprm)
        retval = remove_arg_zero(bprm);
        if (retval)
                return retval;
-       retval = copy_strings_kernel(1, &bprm->interp, bprm);
+       retval = copy_string_kernel(bprm->interp, bprm);
        if (retval < 0)
                return retval;
        bprm->argc++;
        if (i_arg) {
-               retval = copy_strings_kernel(1, &i_arg, bprm);
+               retval = copy_string_kernel(i_arg, bprm);
                if (retval < 0)
                        return retval;
                bprm->argc++;
        }
-       retval = copy_strings_kernel(1, &i_name, bprm);
+       retval = copy_string_kernel(i_name, bprm);
        if (retval)
                return retval;
        bprm->argc++;
index 2c46511..4814b26 100644 (file)
--- a/fs/exec.c
+++ b/fs/exec.c
@@ -588,24 +588,23 @@ out:
 }
 
 /*
- * Like copy_strings, but get argv and its values from kernel memory.
+ * Copy and argument/environment string from the kernel to the processes stack.
  */
-int copy_strings_kernel(int argc, const char *const *__argv,
-                       struct linux_binprm *bprm)
+int copy_string_kernel(const char *arg, struct linux_binprm *bprm)
 {
        int r;
        mm_segment_t oldfs = get_fs();
        struct user_arg_ptr argv = {
-               .ptr.native = (const char __user *const  __user *)__argv,
+               .ptr.native = (const char __user *const  __user *)&arg,
        };
 
        set_fs(KERNEL_DS);
-       r = copy_strings(argc, argv, bprm);
+       r = copy_strings(1, argv, bprm);
        set_fs(oldfs);
 
        return r;
 }
-EXPORT_SYMBOL(copy_strings_kernel);
+EXPORT_SYMBOL(copy_string_kernel);
 
 #ifdef CONFIG_MMU
 
@@ -1865,7 +1864,7 @@ static int __do_execve_file(int fd, struct filename *filename,
        if (retval < 0)
                goto out;
 
-       retval = copy_strings_kernel(1, &bprm->filename, bprm);
+       retval = copy_string_kernel(bprm->filename, bprm);
        if (retval < 0)
                goto out;
 
index a345d9f..3d3afe0 100644 (file)
@@ -144,8 +144,7 @@ extern int setup_arg_pages(struct linux_binprm * bprm,
 extern int transfer_args_to_stack(struct linux_binprm *bprm,
                                  unsigned long *sp_location);
 extern int bprm_change_interp(const char *interp, struct linux_binprm *bprm);
-extern int copy_strings_kernel(int argc, const char *const *argv,
-                              struct linux_binprm *bprm);
+int copy_string_kernel(const char *arg, struct linux_binprm *bprm);
 extern void install_exec_creds(struct linux_binprm *bprm);
 extern void set_binfmt(struct linux_binfmt *new);
 extern ssize_t read_code(struct file *, unsigned long, loff_t, size_t);