make daemon try the operations that might fail before fork rather than after
authorRich Felker <dalias@aerifal.cx>
Thu, 17 Feb 2011 15:30:00 +0000 (10:30 -0500)
committerRich Felker <dalias@aerifal.cx>
Thu, 17 Feb 2011 15:30:00 +0000 (10:30 -0500)
src/linux/daemon.c

index 3750fc3..afb8019 100644 (file)
@@ -3,7 +3,16 @@
 
 int daemon(int nochdir, int noclose)
 {
-       int fd;
+       if (!nochdir && chdir("/"))
+               return -1;
+       if (!noclose) {
+               int fd, failed = 0;
+               if ((fd = open("/dev/null", O_RDWR)) < 0) return -1;
+               if (dup2(fd, 0) < 0 || dup2(fd, 1) < 0 || dup2(fd, 2) < 0)
+                       failed++;
+               if (fd > 2) close(fd);
+               if (failed) return -1;
+       }
 
        switch(fork()) {
        case 0: break;
@@ -19,16 +28,5 @@ int daemon(int nochdir, int noclose)
        default: _exit(0);
        }
 
-       if (!nochdir && chdir("/"))
-               return -1;
-       if (!noclose) {
-               int failed = 0;
-               if ((fd = open("/dev/null", O_RDWR)) < 0) return -1;
-               if (dup2(fd, 0) < 0 || dup2(fd, 1) < 0 || dup2(fd, 2) < 0)
-                       failed++;
-               if (fd > 2) close(fd);
-               if (failed) return -1;
-       }
-
        return 0;
 }