svn commit: r249983 - head/usr.sbin/syslogd

Jilles Tjoelker jilles at FreeBSD.org
Sat Apr 27 13:26:36 UTC 2013


Author: jilles
Date: Sat Apr 27 13:26:35 2013
New Revision: 249983
URL: http://svnweb.freebsd.org/changeset/base/249983

Log:
  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

Modified:
  head/usr.sbin/syslogd/syslogd.c

Modified: head/usr.sbin/syslogd/syslogd.c
==============================================================================
--- head/usr.sbin/syslogd/syslogd.c	Sat Apr 27 12:50:07 2013	(r249982)
+++ head/usr.sbin/syslogd/syslogd.c	Sat Apr 27 13:26:35 2013	(r249983)
@@ -2476,7 +2476,7 @@ validate(struct sockaddr *sa, const char
 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);


More information about the svn-src-all mailing list