aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/xwrap.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/lib/xwrap.c b/lib/xwrap.c
index 817037db..1e39c1bc 100644
--- a/lib/xwrap.c
+++ b/lib/xwrap.c
@@ -197,7 +197,7 @@ pid_t __attribute__((returns_twice)) xvforkwrap(pid_t pid)
if (pid == -1) perror_exit("vfork");
// Signal to xexec() and friends that we vforked so can't recurse
- toys.stacktop = 0;
+ if (!pid) toys.stacktop = 0;
return pid;
}
@@ -237,24 +237,24 @@ pid_t xpopen_both(char **argv, int *pipes)
if (!(pid = CFG_TOYBOX_FORK ? xfork() : XVFORK())) {
// Child process: Dance of the stdin/stdout redirection.
- // cestnepasun[1]->cestnepasun[0] and cestnepasun[2]->cestnepasun[1]
+ // cestnepasun[1]->cestnepasun[0] and cestnepasun[3]->cestnepasun[2]
if (pipes) {
// if we had no stdin/out, pipe handles could overlap, so test for it
// and free up potentially overlapping pipe handles before reuse
- // in child, close read end of output pipe, and return write end as out
+ // in child, close read end of output pipe, use write end as new stdout
if (cestnepasun[2]) {
close(cestnepasun[2]);
pipes[1] = cestnepasun[3];
}
- // in child, close write end of input pipe, and return input end as out.
+ // in child, close write end of input pipe, use read end as new stdin
if (cestnepasun[1]) {
close(cestnepasun[1]);
pipes[0] = cestnepasun[0];
}
- // If swapping stdin/stdout, need to move a filehandle to temp
+ // If swapping stdin/stdout, dup a filehandle that gets closed before use
if (!pipes[1]) pipes[1] = dup(0);
// Are we redirecting stdin?