|
|
|
@ -130,7 +130,7 @@ int pthread_create(pthread_t *restrict res, const pthread_attr_t *restrict attr, |
|
|
|
} |
|
|
|
tsd = map + size - __pthread_tsd_size; |
|
|
|
} |
|
|
|
new = __copy_tls(tsd - libc.tls_size); |
|
|
|
new = __copy_tls(stack = tsd - libc.tls_size); |
|
|
|
new->map_base = map; |
|
|
|
new->map_size = size; |
|
|
|
new->pid = self->pid; |
|
|
|
@ -145,7 +145,6 @@ int pthread_create(pthread_t *restrict res, const pthread_attr_t *restrict attr, |
|
|
|
} |
|
|
|
new->unblock_cancel = self->cancel; |
|
|
|
new->canary = self->canary; |
|
|
|
stack = (void *)new; |
|
|
|
|
|
|
|
a_inc(&libc.threads_minus_1); |
|
|
|
ret = __clone(start, stack, flags, new, &new->tid, new, &new->tid); |
|
|
|
|