fix regression that made shared libs crash on arm
[musl] / src / thread / pthread_join.c
index 664abda..719c91c 100644 (file)
@@ -1,4 +1,5 @@
 #include "pthread_impl.h"
+#include <sys/mman.h>
 
 static void dummy(void *p)
 {
@@ -6,8 +7,8 @@ static void dummy(void *p)
 
 int pthread_join(pthread_t t, void **res)
 {
-       int tmp = t->tid;
-       if (tmp) __timedwait(&t->tid, tmp, 0, 0, dummy, 0, 1);
+       int tmp;
+       while ((tmp = t->tid)) __timedwait(&t->tid, tmp, 0, 0, dummy, 0, 0);
        if (res) *res = t->result;
        if (t->map_base) munmap(t->map_base, t->map_size);
        return 0;