X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=src%2Fthread%2Fpthread_detach.c;h=77772af2c6349fca2cd66860c71e910c3138b101;hb=bf14ef193b4203aa9a8b173faeeea06d98397f65;hp=651c38ebe86cc82ce51aca57731da21c48851e73;hpb=bbbe87e35cfeef593e23010e35528e722027567f;p=musl diff --git a/src/thread/pthread_detach.c b/src/thread/pthread_detach.c index 651c38eb..77772af2 100644 --- a/src/thread/pthread_detach.c +++ b/src/thread/pthread_detach.c @@ -1,11 +1,14 @@ #include "pthread_impl.h" +#include -int pthread_detach(pthread_t t) +static int __pthread_detach(pthread_t t) { - /* Cannot detach a thread that's already exiting */ - if (a_swap(t->exitlock, 1)) - return pthread_join(t, 0); - t->detached = 2; - __unlock(t->exitlock); + /* If the cas fails, detach state is either already-detached + * or exiting/exited, and pthread_join will trap or cleanup. */ + if (a_cas(&t->detach_state, DT_JOINABLE, DT_DETACHED) != DT_JOINABLE) + return __pthread_join(t, 0); return 0; } + +weak_alias(__pthread_detach, pthread_detach); +weak_alias(__pthread_detach, thrd_detach);