X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fprocess%2Ffork.c;h=43c52bc4c0c8e9d28455611697e686b714ccf23e;hb=c0ed5a201b2bdb6d1896064bec0020c9973db0a1;hp=0638ed67db74df731bdfab80f4e4d05e12be7981;hpb=e9417fffb39c299e556c5ad0c1545f0c02618e3c;p=musl diff --git a/src/process/fork.c b/src/process/fork.c index 0638ed67..43c52bc4 100644 --- a/src/process/fork.c +++ b/src/process/fork.c @@ -1,12 +1,34 @@ #include +#include +#include #include "syscall.h" #include "libc.h" +#include "pthread_impl.h" + +static void dummy(int x) +{ +} + +weak_alias(dummy, __fork_handler); pid_t fork(void) { pid_t ret; - if (libc.fork_handler) libc.fork_handler(-1); - ret = syscall0(__NR_fork); - if (libc.fork_handler) libc.fork_handler(!ret); + sigset_t set; + __fork_handler(-1); + __block_all_sigs(&set); +#ifdef SYS_fork + ret = syscall(SYS_fork); +#else + ret = syscall(SYS_clone, SIGCHLD, 0); +#endif + if (libc.has_thread_pointer && !ret) { + pthread_t self = __pthread_self(); + self->tid = __syscall(SYS_gettid); + memset(&self->robust_list, 0, sizeof self->robust_list); + libc.threads_minus_1 = 0; + } + __restore_sigs(&set); + __fork_handler(!ret); return ret; }