diff options
author | Rich Felker <dalias@aerifal.cx> | 2013-10-03 10:16:01 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2013-10-03 10:16:01 -0400 |
commit | 2b2aff37aced66e4a50a38a14607a9b1dc0ee001 (patch) | |
tree | b8473d323d03458372a1bada847a060ff5a20b0b /src/process | |
parent | 23b8e3bc95620b0bd90a78ce0d926942c12b45da (diff) | |
download | musl-2b2aff37aced66e4a50a38a14607a9b1dc0ee001.zip musl-2b2aff37aced66e4a50a38a14607a9b1dc0ee001.tar.gz musl-2b2aff37aced66e4a50a38a14607a9b1dc0ee001.tar.bz2 |
fix new environment always being null with execle
the va_arg call for the argv[]-terminating null pointer was missing,
so this pointer was being wrongly used as the environment pointer.
issue reported by Timo Teräs. proposed patch slightly modified to
simplify the resulting code.
Diffstat (limited to 'src/process')
-rw-r--r-- | src/process/execle.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/src/process/execle.c b/src/process/execle.c index 6490836..6f2ec05 100644 --- a/src/process/execle.c +++ b/src/process/execle.c @@ -14,9 +14,8 @@ int execle(const char *path, const char *argv0, ...) char **envp; va_start(ap, argv0); argv[0] = (char *)argv0; - for (i=1; i<argc; i++) + for (i=1; i<=argc; i++) argv[i] = va_arg(ap, char *); - argv[i] = NULL; envp = va_arg(ap, char **); return execve(path, argv, envp); } |