summaryrefslogtreecommitdiff
path: root/src/linux/daemon.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2011-02-17 10:30:00 -0500
committerRich Felker <dalias@aerifal.cx>2011-02-17 10:30:00 -0500
commit187fe29d5b89644b68cade75a34257a1c32a75f6 (patch)
tree563471dc8d0e4294ea3cd68338f3ff8e5470e3d6 /src/linux/daemon.c
parent19e35c500bd2b5e6146e42705ab9b69c155a2006 (diff)
downloadmusl-187fe29d5b89644b68cade75a34257a1c32a75f6.tar.gz
musl-187fe29d5b89644b68cade75a34257a1c32a75f6.tar.bz2
musl-187fe29d5b89644b68cade75a34257a1c32a75f6.tar.xz
musl-187fe29d5b89644b68cade75a34257a1c32a75f6.zip
make daemon try the operations that might fail before fork rather than after
Diffstat (limited to 'src/linux/daemon.c')
-rw-r--r--src/linux/daemon.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/src/linux/daemon.c b/src/linux/daemon.c
index 3750fc34..afb8019f 100644
--- a/src/linux/daemon.c
+++ b/src/linux/daemon.c
@@ -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;
}