svn commit: r229966 - head/lib/libutil

Guy Helmer ghelmer at FreeBSD.org
Wed Jan 11 16:35:26 UTC 2012


Author: ghelmer
Date: Wed Jan 11 16:35:26 2012
New Revision: 229966
URL: http://svn.freebsd.org/changeset/base/229966

Log:
  jilles pointed out that O_CLOEXEC could be used in the open(2) flags
  rather than using fcntl(2) later, and in addition to saving a system
  call, removes a possible race with fork/exec from threads or signal
  handlers.

Modified:
  head/lib/libutil/pidfile.c

Modified: head/lib/libutil/pidfile.c
==============================================================================
--- head/lib/libutil/pidfile.c	Wed Jan 11 15:00:16 2012	(r229965)
+++ head/lib/libutil/pidfile.c	Wed Jan 11 16:35:26 2012	(r229966)
@@ -117,7 +117,7 @@ pidfile_open(const char *path, mode_t mo
 	 * pidfile_write() can be called multiple times.
 	 */
 	fd = flopen(pfh->pf_path,
-	    O_WRONLY | O_CREAT | O_TRUNC | O_NONBLOCK, mode);
+	    O_WRONLY | O_CREAT | O_TRUNC | O_CLOEXEC | O_NONBLOCK, mode);
 	if (fd == -1) {
 		if (errno == EWOULDBLOCK && pidptr != NULL) {
 			count = 20;
@@ -139,19 +139,6 @@ pidfile_open(const char *path, mode_t mo
 	}
 
 	/*
-	 * Prevent the file descriptor from escaping to other
-	 * programs via exec(3).
-	 */
-	if (fcntl(fd, F_SETFD, FD_CLOEXEC) == -1) {
-		error = errno;
-		unlink(pfh->pf_path);
-		close(fd);
-		free(pfh);
-		errno = error;
-		return (NULL);
-	}
-
-	/*
 	 * Remember file information, so in pidfile_write() we are sure we write
 	 * to the proper descriptor.
 	 */


More information about the svn-src-head mailing list