mirror of
git://git.musl-libc.org/musl
synced 2025-03-25 04:18:21 +00:00
as a result of commit 12e1e32468
, kernel
processing of the robust list is only needed for process-shared
mutexes. previously the first attempt to lock any owner-tracked mutex
resulted in robust list initialization and a set_robust_list syscall.
this is no longer necessary, and since the kernel's record of the
robust list must now be cleared at thread exit time for detached
threads, optimizing it out is more worthwhile than before too.
36 lines
646 B
C
36 lines
646 B
C
#include <unistd.h>
|
|
#include <string.h>
|
|
#include <signal.h>
|
|
#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;
|
|
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);
|
|
self->robust_list.off = 0;
|
|
self->robust_list.pending = 0;
|
|
libc.threads_minus_1 = 0;
|
|
}
|
|
__restore_sigs(&set);
|
|
__fork_handler(!ret);
|
|
return ret;
|
|
}
|