From 87aef170444022cdcc901be0627c9a92b773af64 Mon Sep 17 00:00:00 2001 From: Bill Nottingham Date: Thu, 22 Feb 2001 04:33:18 +0000 Subject: close extra file descriptors before exec()ing commands in initlog --- src/process.c | 12 ++++++++++++ src/testd.c | 1 + 2 files changed, 13 insertions(+) (limited to 'src') diff --git a/src/process.c b/src/process.c index b320051f..ce0d459d 100644 --- a/src/process.c +++ b/src/process.c @@ -71,6 +71,8 @@ int forkCommand(char **args, int *outfd, int *errfd, int *cmdfd, int quiet) { return pid; } else { /* kid */ + int sc_open_max; + if (outfd) { if ( (dup2(fdout,1)==-1) ) { perror("dup2"); @@ -107,6 +109,16 @@ int forkCommand(char **args, int *outfd, int *errfd, int *cmdfd, int quiet) { close(*errfd); if (cmdfd) close(*cmdfd); + + /* close up extra fds, and hope this doesn't break anything */ + sc_open_max = sysconf(_SC_OPEN_MAX); + if(sc_open_max > 1) { + int fd; + for(fd = 3; fd < sc_open_max; fd++) { + close(fd); + } + } + execvp(args[0],args); perror("execvp"); exit(-1); diff --git a/src/testd.c b/src/testd.c index 7deb00eb..b2a5c7e6 100644 --- a/src/testd.c +++ b/src/testd.c @@ -1,5 +1,6 @@ #include #include +#include int main() { signal(SIGTERM, SIG_IGN); -- cgit v1.2.1