From: Tilghman Lesher Date: Thu, 8 Apr 2010 22:03:00 +0000 (+0000) Subject: Backport /proc/%d/fd method of closing file descriptors to 1.6.2. X-Git-Tag: 1.6.2.8-rc1~71 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=19b7fe047a6e24ccd9ec13874853afdfa55260ba;p=thirdparty%2Fasterisk.git Backport /proc/%d/fd method of closing file descriptors to 1.6.2. git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.6.2@256483 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/main/app.c b/main/app.c index 2aa76edef2..eb26a9baba 100644 --- a/main/app.c +++ b/main/app.c @@ -36,6 +36,10 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") #include /* for getrlimit(2) */ #include /* for getrlimit(2) */ #include /* for closefrom(3) */ +#ifndef HAVE_CLOSEFROM +#include +#include /* for opendir(3) */ +#endif #ifdef HAVE_CAP #include #endif /* HAVE_CAP */ @@ -1984,20 +1988,37 @@ void ast_close_fds_above_n(int n) #ifdef HAVE_CLOSEFROM closefrom(n + 1); #else - int x, null; + long x, null; struct rlimit rl; - getrlimit(RLIMIT_NOFILE, &rl); - null = open("/dev/null", O_RDONLY); - for (x = n + 1; x < rl.rlim_cur; x++) { - if (x != null) { - /* Side effect of dup2 is that it closes any existing fd without error. - * This prevents valgrind and other debugging tools from sending up - * false error reports. */ - while (dup2(null, x) < 0 && errno == EINTR); - close(x); - } - } - close(null); + DIR *dir; + char path[16], *result; + struct dirent *entry; + snprintf(path, sizeof(path), "/proc/%d/fd", (int) getpid()); + if ((dir = opendir(path))) { + while ((entry = readdir(dir))) { + /* Skip . and .. */ + if (entry->d_name[0] == '.') { + continue; + } + if ((x = strtol(entry->d_name, &result, 10)) && x >= n) { + close(x); + } + } + closedir(dir); + } else { + getrlimit(RLIMIT_NOFILE, &rl); + null = open("/dev/null", O_RDONLY); + for (x = n + 1; x < rl.rlim_cur; x++) { + if (x != null) { + /* Side effect of dup2 is that it closes any existing fd without error. + * This prevents valgrind and other debugging tools from sending up + * false error reports. */ + while (dup2(null, x) < 0 && errno == EINTR); + close(x); + } + } + close(null); + } #endif }