diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-02-18 19:52:42 -0500 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-02-18 19:52:42 -0500 |
commit | e9417fffb39c299e556c5ad0c1545f0c02618e3c (patch) | |
tree | 90c04bef0567ff4df7c7b57986a756b8b11b506c /src/process/fork.c | |
parent | 446b4207cc7a30d8a4d5b2445a5a1b27d440f55d (diff) | |
download | musl-e9417fffb39c299e556c5ad0c1545f0c02618e3c.tar.gz musl-e9417fffb39c299e556c5ad0c1545f0c02618e3c.tar.xz musl-e9417fffb39c299e556c5ad0c1545f0c02618e3c.zip |
add pthread_atfork interface
note that this presently does not handle consistency of the libc's own global state during forking. as per POSIX 2008, if the parent process was threaded, the child process may only call async-signal-safe functions until one of the exec-family functions is called, so the current behavior is believed to be conformant even if non-ideal. it may be improved at some later time.
Diffstat (limited to 'src/process/fork.c')
-rw-r--r-- | src/process/fork.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/process/fork.c b/src/process/fork.c index 1213f0f5..0638ed67 100644 --- a/src/process/fork.c +++ b/src/process/fork.c @@ -1,9 +1,12 @@ #include <unistd.h> #include "syscall.h" - -/* FIXME: add support for atfork stupidity */ +#include "libc.h" pid_t fork(void) { - return syscall0(__NR_fork); + pid_t ret; + if (libc.fork_handler) libc.fork_handler(-1); + ret = syscall0(__NR_fork); + if (libc.fork_handler) libc.fork_handler(!ret); + return ret; } |