X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fthread%2Fpthread_create.c;h=0e1dbb2d2e75adcd8299b6b48dc960a5b9c846bc;hb=8c6fc860a97f79146bf5c092d5cfb90fa6d9355a;hp=0189f02844f1e7af23f25e273b6ff321fdbceb57;hpb=3f39c9b3130cd6c142d358159879b799370a6663;p=musl diff --git a/src/thread/pthread_create.c b/src/thread/pthread_create.c index 0189f028..0e1dbb2d 100644 --- a/src/thread/pthread_create.c +++ b/src/thread/pthread_create.c @@ -8,14 +8,18 @@ weak_alias(dummy_0, __synccall_lock); weak_alias(dummy_0, __synccall_unlock); weak_alias(dummy_0, __pthread_tsd_run_dtors); -void __pthread_do_unwind(struct __ptcb *cb) +void pthread_exit(void *result) { pthread_t self = pthread_self(); int n; - if (cb->__next) { - self->cancelbuf = cb->__next->__next; - longjmp((void *)cb->__next->__jb, 1); + self->result = result; + + while (self->cancelbuf) { + void (*f)(void *) = self->cancelbuf->__f; + void *x = self->cancelbuf->__x; + self->cancelbuf = self->cancelbuf->__next; + f(x); } __pthread_tsd_run_dtors(); @@ -39,17 +43,16 @@ void __pthread_do_unwind(struct __ptcb *cb) __syscall(SYS_exit, 0); } -void __pthread_do_register(struct __ptcb *cb) +void __do_cleanup_push(struct __ptcb *cb, void (*f)(void *), void *x) { struct pthread *self = pthread_self(); cb->__next = self->cancelbuf; self->cancelbuf = cb; } -void __pthread_do_unregister(struct __ptcb *cb) +void __do_cleanup_pop(struct __ptcb *cb, int run) { - struct pthread *self = __pthread_self(); - self->cancelbuf = self->cancelbuf->__next; + __pthread_self()->cancelbuf = cb->__next; } static int start(void *p) @@ -134,11 +137,3 @@ int pthread_create(pthread_t *res, const pthread_attr_t *attr, void *(*entry)(vo *res = new; return 0; } - -void pthread_exit(void *result) -{ - struct pthread *self = pthread_self(); - struct __ptcb cb = { .__next = self->cancelbuf }; - self->result = result; - __pthread_do_unwind(&cb); -}