summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
authorFlorian Obser <florian@cvs.openbsd.org>2013-10-18 14:42:19 +0000
committerFlorian Obser <florian@cvs.openbsd.org>2013-10-18 14:42:19 +0000
commit91e9f359887862e9303466bf94bac8e367f40ad5 (patch)
tree7a4feefd1252c2c2b672283a1a01ba5d7a92f5b0 /usr.sbin
parent33c4b41a8393394ada80807e90d16aa355ec9286 (diff)
set FD_CLOEXEC
OK blambert
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/slowcgi/slowcgi.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/usr.sbin/slowcgi/slowcgi.c b/usr.sbin/slowcgi/slowcgi.c
index b10a0697ada..fa36cf31195 100644
--- a/usr.sbin/slowcgi/slowcgi.c
+++ b/usr.sbin/slowcgi/slowcgi.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: slowcgi.c,v 1.11 2013/09/19 09:21:29 blambert Exp $ */
+/* $OpenBSD: slowcgi.c,v 1.12 2013/10/18 14:42:18 florian Exp $ */
/*
* Copyright (c) 2013 David Gwynne <dlg@openbsd.org>
* Copyright (c) 2013 Florian Obser <florian@openbsd.org>
@@ -25,6 +25,7 @@
#include <sys/un.h>
#include <sys/wait.h>
#include <err.h>
+#include <fcntl.h>
#include <ctype.h>
#include <errno.h>
#include <event.h>
@@ -307,6 +308,7 @@ slowcgi_listen(char *path, gid_t gid)
if ((fd = socket(AF_UNIX, SOCK_STREAM, 0)) == -1)
lerr(1, "slowcgi_listen: socket");
+ fcntl(fd, F_SETFD, FD_CLOEXEC);
bzero(&sun, sizeof(sun));
sun.sun_family = AF_UNIX;
@@ -388,6 +390,7 @@ slowcgi_accept(int fd, short events, void *arg)
}
}
+ fcntl(s, F_SETFD, FD_CLOEXEC);
if (ioctl(s, FIONBIO, &on) == -1)
lerr(1, "request ioctl(FIONBIO)");
@@ -801,6 +804,10 @@ exec_cgi(struct request *c)
/* Parent process*/
close(s[1]);
close(s_err[1]);
+
+ fcntl(s[0], F_SETFD, FD_CLOEXEC);
+ fcntl(s_err[0], F_SETFD, FD_CLOEXEC);
+
if (ioctl(s[0], FIONBIO, &on) == -1)
lerr(1, "script ioctl(FIONBIO)");
if (ioctl(s_err[0], FIONBIO, &on) == -1)