X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fprocess%2Ffork.c;h=fb42478ae709a3e11619740a11b7a344cb63655a;hb=1ef37aa00ea830dfda76e04e3d941cafa74d8b76;hp=f8cf21e7ca01d94cd67a2add5bcda4ccaff7af40;hpb=dd5f50da6f6c3df5647e922e47f8568a8896a752;p=musl diff --git a/src/process/fork.c b/src/process/fork.c index f8cf21e7..fb42478a 100644 --- a/src/process/fork.c +++ b/src/process/fork.c @@ -18,17 +18,20 @@ pid_t fork(void) __fork_handler(-1); __block_all_sigs(&set); #ifdef SYS_fork - ret = syscall(SYS_fork); + ret = __syscall(SYS_fork); #else - ret = syscall(SYS_clone, SIGCHLD, 0); + ret = __syscall(SYS_clone, SIGCHLD, 0); #endif - if (libc.has_thread_pointer && !ret) { + if (!ret) { pthread_t self = __pthread_self(); - self->tid = self->pid = __syscall(SYS_getpid); - memset(&self->robust_list, 0, sizeof self->robust_list); + self->tid = __syscall(SYS_gettid); + self->robust_list.off = 0; + self->robust_list.pending = 0; + self->next = self->prev = self; + __thread_list_lock = 0; libc.threads_minus_1 = 0; } __restore_sigs(&set); __fork_handler(!ret); - return ret; + return __syscall_ret(ret); }