diff options
author | Rob Landley <rob@landley.net> | 2013-07-18 18:20:03 -0500 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2013-07-18 18:20:03 -0500 |
commit | a817a02c00a06fbf2090259320968addb5f46e58 (patch) | |
tree | 626d9761e1346afc168f64cbfe4dfba9538c20ef /toys/other | |
parent | 39af4ae3e61d352c3faa7d1b87e6ac6fdb69add1 (diff) | |
download | toybox-a817a02c00a06fbf2090259320968addb5f46e58.tar.gz |
Replace users of xexec(toys.optargs) with xexec_optargs(0) to avoid free/reuse bug during argument parsing.
Diffstat (limited to 'toys/other')
-rw-r--r-- | toys/other/chroot.c | 4 | ||||
-rw-r--r-- | toys/other/netcat.c | 2 | ||||
-rw-r--r-- | toys/other/setsid.c | 2 | ||||
-rw-r--r-- | toys/other/taskset.c | 2 | ||||
-rw-r--r-- | toys/other/unshare.c | 2 |
5 files changed, 7 insertions, 5 deletions
diff --git a/toys/other/chroot.c b/toys/other/chroot.c index c9ff10c7..00fb4e7f 100644 --- a/toys/other/chroot.c +++ b/toys/other/chroot.c @@ -18,6 +18,8 @@ config CHROOT void chroot_main(void) { char *binsh[] = {"/bin/sh", "-i", 0}; + if (chdir(*toys.optargs) || chroot(".")) perror_exit("%s", *toys.optargs); - xexec(toys.optargs[1] ? toys.optargs+1 : binsh); + if (toys.optargs[1]) xexec_optargs(1); + else xexec(binsh); } diff --git a/toys/other/netcat.c b/toys/other/netcat.c index a245d119..e41fc4b2 100644 --- a/toys/other/netcat.c +++ b/toys/other/netcat.c @@ -187,7 +187,7 @@ void netcat_main(void) set_alarm(0); if (CFG_NETCAT_LISTEN && (toys.optflags&(FLAG_L|FLAG_l) && toys.optc)) - xexec(toys.optargs); + xexec_optargs(0); // Poll loop copying stdin->socket and socket->stdout. for (;;) { diff --git a/toys/other/setsid.c b/toys/other/setsid.c index 59a1d78f..8f0a0647 100644 --- a/toys/other/setsid.c +++ b/toys/other/setsid.c @@ -24,5 +24,5 @@ void setsid_main(void) setpgid(0,0); tcsetpgrp(0, getpid()); } - xexec(toys.optargs); + xexec_optargs(0); } diff --git a/toys/other/taskset.c b/toys/other/taskset.c index 2b067d4a..bcc03478 100644 --- a/toys/other/taskset.c +++ b/toys/other/taskset.c @@ -90,7 +90,7 @@ void taskset_main(void) if (!(toys.optflags & FLAG_p)) { if (toys.optc < 2) error_exit("Needs 2 args"); do_taskset(getpid(), 1); - xexec(toys.optargs+1); + xexec_optargs(1); } else { char *c; pid_t pid = strtol(toys.optargs[toys.optc-1], &c, 10); diff --git a/toys/other/unshare.c b/toys/other/unshare.c index 9a938186..87db6039 100644 --- a/toys/other/unshare.c +++ b/toys/other/unshare.c @@ -35,5 +35,5 @@ void unshare_main(void) if(unshare(f)) perror_exit("failed"); - xexec(toys.optargs); + xexec_optargs(0); } |