summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornicm <nicm@openbsd.org>2009-10-21 07:24:23 +0000
committernicm <nicm@openbsd.org>2009-10-21 07:24:23 +0000
commitd9b750bc82d19a610123c82b367950ca4fcd0e68 (patch)
treeaa1bb64e44dfbc89243555afc0095f6d9a0e13dc
parentwhen freeing buffers (i.e. when sio_stop() is called on client side), (diff)
downloadwireguard-openbsd-d9b750bc82d19a610123c82b367950ca4fcd0e68.tar.xz
wireguard-openbsd-d9b750bc82d19a610123c82b367950ca4fcd0e68.zip
Getting the read and write ends of the pipe the right way round is usually
recommended. DOH.
-rw-r--r--usr.bin/tmux/job.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/usr.bin/tmux/job.c b/usr.bin/tmux/job.c
index a264c9ac6f9..9f8e39375fe 100644
--- a/usr.bin/tmux/job.c
+++ b/usr.bin/tmux/job.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: job.c,v 1.6 2009/10/20 22:15:32 nicm Exp $ */
+/* $OpenBSD: job.c,v 1.7 2009/10/21 07:24:23 nicm Exp $ */
/*
* Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -153,13 +153,13 @@ job_run(struct job *job)
sigreset();
/* XXX environ? */
- close(out[1]);
- if (dup2(out[0], STDOUT_FILENO) == -1)
+ if (dup2(out[1], STDOUT_FILENO) == -1)
fatal("dup2 failed");
- if (out[0] != STDOUT_FILENO)
- close(out[0]);
+ if (out[1] != STDOUT_FILENO)
+ close(out[1]);
+ close(out[0]);
- nullfd = open(_PATH_DEVNULL, O_RDONLY, 0);
+ nullfd = open(_PATH_DEVNULL, O_RDWR, 0);
if (nullfd < 0)
fatal("open failed");
if (dup2(nullfd, STDIN_FILENO) == -1)
@@ -172,9 +172,9 @@ job_run(struct job *job)
execl(_PATH_BSHELL, "sh", "-c", job->cmd, (char *) NULL);
fatal("execl failed");
default: /* parent */
- close(out[0]);
+ close(out[1]);
- job->fd = out[1];
+ job->fd = out[0];
if ((mode = fcntl(job->fd, F_GETFL)) == -1)
fatal("fcntl failed");
if (fcntl(job->fd, F_SETFL, mode|O_NONBLOCK) == -1)