new internal locking primitive; drop spinlocks
[musl] / src / thread / __lock.c
1 #include "pthread_impl.h"
2
3 void __lock_2(volatile int *l)
4 {
5         if (!__syscall(SYS_futex, l, FUTEX_LOCK_PI, 0, 0))
6                 return;
7         int old, tid = __pthread_self()->tid;
8         while ((old = a_cas(l, 0, tid))) {
9                 a_cas(l, old, old|INT_MIN);
10                 __syscall(SYS_futex, l, FUTEX_WAIT, old|INT_MIN, 0);
11         }
12 }
13
14 void __lock(volatile int *l)
15 {
16         if (a_cas(l, 0, __pthread_self()->tid)) __lock_2(l);
17 }
18
19 void __unlock_2(volatile int *l)
20 {
21         if (__syscall(SYS_futex, l, FUTEX_UNLOCK_PI)) {
22                 *l = 0;
23                 __syscall(SYS_futex, l, FUTEX_WAKE, 1);
24         }
25 }
26
27 void __unlock(volatile int *l)
28 {
29         int old = *l;
30         if (!(old & INT_MIN) && a_cas(l, old, 0)==old) return;
31         __unlock_2(l);
32 }