summaryrefslogtreecommitdiffstats
path: root/usr.sbin/syslogd
diff options
context:
space:
mode:
authorjilles <jilles@FreeBSD.org>2013-04-27 13:26:35 +0000
committerjilles <jilles@FreeBSD.org>2013-04-27 13:26:35 +0000
commit72dbb34e66701a0d22f36de94acbb3f84e7fcb79 (patch)
tree5aa9e483274d2af7f5508cdbb7053c4be365119f /usr.sbin/syslogd
parentba8e6992c30d728a8b2f366027f189a6cafba364 (diff)
downloadFreeBSD-src-72dbb34e66701a0d22f36de94acbb3f84e7fcb79.zip
FreeBSD-src-72dbb34e66701a0d22f36de94acbb3f84e7fcb79.tar.gz
syslogd: Use closefrom() instead of getdtablesize()/close() loop.
When syslogd forks a process for '|' destinations, it closes all file descriptors greater than 2. Use closefrom() for this instead of a getdtablesize()/close() loop because it is both faster and avoids leaving file descriptors open because the limit was lowered after they were opened. MFC after: 1 week
Diffstat (limited to 'usr.sbin/syslogd')
-rw-r--r--usr.sbin/syslogd/syslogd.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/usr.sbin/syslogd/syslogd.c b/usr.sbin/syslogd/syslogd.c
index bb56b6b..8fc2678 100644
--- a/usr.sbin/syslogd/syslogd.c
+++ b/usr.sbin/syslogd/syslogd.c
@@ -2476,7 +2476,7 @@ validate(struct sockaddr *sa, const char *hname)
static int
p_open(const char *prog, pid_t *rpid)
{
- int pfd[2], nulldesc, i;
+ int pfd[2], nulldesc;
pid_t pid;
sigset_t omask, mask;
char *argv[4]; /* sh -c cmd NULL */
@@ -2526,8 +2526,7 @@ p_open(const char *prog, pid_t *rpid)
dup2(pfd[0], STDIN_FILENO);
dup2(nulldesc, STDOUT_FILENO);
dup2(nulldesc, STDERR_FILENO);
- for (i = getdtablesize(); i > 2; i--)
- (void)close(i);
+ closefrom(3);
(void)execvp(_PATH_BSHELL, argv);
_exit(255);
OpenPOWER on IntegriCloud