pid_t ret;
if (libc.fork_handler) libc.fork_handler(-1);
ret = syscall(SYS_fork);
- if (libc.threaded && !ret) {
+ if (libc.main_thread && !ret) {
pthread_t self = __pthread_self();
self->tid = self->pid = syscall(SYS_getpid);
libc.threads_minus_1 = 0;
+ libc.main_thread = self;
}
if (libc.fork_handler) libc.fork_handler(!ret);
return ret;
static const void *dummy[1] = { 0 };
weak_alias(dummy, __pthread_tsd_main);
-#undef errno
static int *errno_location()
{
return __pthread_self()->errno_ptr;
static int init_main_thread()
{
+ if (__set_thread_area(&main_thread) < 0) return -1;
main_thread.canceldisable = libc.canceldisable;
main_thread.tsd = (void **)__pthread_tsd_main;
- main_thread.self = &main_thread;
- if (__set_thread_area(&main_thread) < 0)
- return -1;
+ main_thread.self = libc.main_thread = &main_thread;
main_thread.errno_ptr = __errno_location();
libc.errno_location = errno_location;
main_thread.tid = main_thread.pid =
int pthread_setcancelstate(int new, int *old)
{
if (new > 1U) return EINVAL;
- if (libc.threaded) {
+ if (libc.main_thread) {
struct pthread *self = __pthread_self();
if (old) *old = self->canceldisable;
self->canceldisable = new;