diff options
Diffstat (limited to 'src/thread')
| -rw-r--r-- | src/thread/__lock.c | 26 | ||||
| -rw-r--r-- | src/thread/pthread_atfork.c | 10 | 
2 files changed, 8 insertions, 28 deletions
diff --git a/src/thread/__lock.c b/src/thread/__lock.c index 5ba5dc5e..2f345ae7 100644 --- a/src/thread/__lock.c +++ b/src/thread/__lock.c @@ -1,32 +1,12 @@  #include "pthread_impl.h" -void __lock_2(volatile int *l) -{ -	if (!__syscall(SYS_futex, l, FUTEX_LOCK_PI, 0, 0)) -		return; -	int old, tid = __pthread_self()->tid|INT_MIN; -	while ((old = a_cas(l, 0, tid))) { -		a_cas(l, old, old|INT_MIN); -		__syscall(SYS_futex, l, FUTEX_WAIT, old|INT_MIN, 0); -	} -} -  void __lock(volatile int *l)  { -	if (a_cas(l, 0, __pthread_self()->tid)) __lock_2(l); -} - -void __unlock_2(volatile int *l) -{ -	if (__syscall(SYS_futex, l, FUTEX_UNLOCK_PI)) { -		*l = 0; -		__syscall(SYS_futex, l, FUTEX_WAKE, 1); -	} +	while (a_swap(l, 1)) __wait(l, l+1, 1, 1);  }  void __unlock(volatile int *l)  { -	int old = *l; -	if (!(old & INT_MIN) && a_cas(l, old, 0)==old) return; -	__unlock_2(l); +	a_store(l, 0); +	if (l[1]) __wake(l, 1, 1);  } diff --git a/src/thread/pthread_atfork.c b/src/thread/pthread_atfork.c index a7a82016..95fce207 100644 --- a/src/thread/pthread_atfork.c +++ b/src/thread/pthread_atfork.c @@ -8,14 +8,14 @@ static struct atfork_funcs {  	struct atfork_funcs *prev, *next;  } *funcs; -static int lock; +static int lock[2];  void __fork_handler(int who)  {  	struct atfork_funcs *p;  	if (!funcs) return;  	if (who < 0) { -		LOCK(&lock); +		LOCK(lock);  		for (p=funcs; p; p = p->next) {  			if (p->prepare) p->prepare();  			funcs = p; @@ -26,7 +26,7 @@ void __fork_handler(int who)  			else if (who && p->child) p->child();  			funcs = p;  		} -		UNLOCK(&lock); +		UNLOCK(lock);  	}  } @@ -35,7 +35,7 @@ int pthread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(vo  	struct atfork_funcs *new = malloc(sizeof *new);  	if (!new) return -1; -	LOCK(&lock); +	LOCK(lock);  	new->next = funcs;  	new->prev = 0;  	new->prepare = prepare; @@ -43,6 +43,6 @@ int pthread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(vo  	new->child = child;  	if (funcs) funcs->prev = new;  	funcs = new; -	UNLOCK(&lock); +	UNLOCK(lock);  	return 0;  }  | 
