ports/134537: misc/e2fsprogs-libuuid closes too manu descriptors [patch]

Mark Andrews Mark_Andrews at isc.org
Thu May 14 11:30:01 UTC 2009


>Number:         134537
>Category:       ports
>Synopsis:       misc/e2fsprogs-libuuid closes too manu descriptors [patch]
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          sw-bug
>Submitter-Id:   current-users
>Arrival-Date:   Thu May 14 11:30:01 UTC 2009
>Closed-Date:
>Last-Modified:
>Originator:     Mark Andrews
>Release:        FreeBSD 6.4-STABLE i386
>Organization:
ISC
>Environment:
System: FreeBSD drugs.dv.isc.org 6.4-STABLE FreeBSD 6.4-STABLE #31: Thu Apr 30 07:41:29 EST 2009 marka at drugs.dv.isc.org:/usr/obj/usr/src/sys/DRUGS i386


>Description:

	close_all_fds() is called just before execing uuidd which results
	in a uuidd start with no file descriptors open.  This is not
	expected and results in uuidd accidently closing the socket
	it just opened when it becomes a daemon.

	See also ports/134526 and ports/134535.

>How-To-Repeat:

>Fix:

	Don't close descriptor 0, 1 and 2 or close and re-open with
	/dev/null.  Since uuidd is invoked in a manner that will
	result in it closing these descriptors I choose the former.

--- gen_uuid.c.orig	2009-05-14 21:12:51.000000000 +1000
+++ gen_uuid.c	2009-05-14 21:12:15.000000000 +1000
@@ -436,7 +436,7 @@
 }
 
 /*
- * Close all file descriptors
+ * Close all file descriptors except for stdio.
  */
 static void close_all_fds(void)
 {
@@ -455,7 +455,7 @@
 	max = OPEN_MAX;
 #endif
 
-	for (i=0; i < max; i++)
+	for (i=3; i < max; i++)
 		close(i);
 }
 
>Release-Note:
>Audit-Trail:
>Unformatted:



More information about the freebsd-ports-bugs mailing list