summaryrefslogtreecommitdiff
path: root/src/thread
diff options
context:
space:
mode:
Diffstat (limited to 'src/thread')
-rw-r--r--src/thread/pthread_create.c6
-rw-r--r--src/thread/pthread_detach.c4
-rw-r--r--src/thread/pthread_kill.c4
3 files changed, 7 insertions, 7 deletions
diff --git a/src/thread/pthread_create.c b/src/thread/pthread_create.c
index ae2f9e4e..94dc308d 100644
--- a/src/thread/pthread_create.c
+++ b/src/thread/pthread_create.c
@@ -24,12 +24,12 @@ void pthread_exit(void *result)
__pthread_tsd_run_dtors();
- __lock(&self->exitlock);
+ __lock(self->exitlock);
/* Mark this thread dead before decrementing count */
- __lock(&self->killlock);
+ __lock(self->killlock);
self->dead = 1;
- a_store(&self->killlock, 0);
+ __unlock(self->killlock);
do n = libc.threads_minus_1;
while (n && a_cas(&libc.threads_minus_1, n, n-1)!=n);
diff --git a/src/thread/pthread_detach.c b/src/thread/pthread_detach.c
index e8032398..651c38eb 100644
--- a/src/thread/pthread_detach.c
+++ b/src/thread/pthread_detach.c
@@ -3,9 +3,9 @@
int pthread_detach(pthread_t t)
{
/* Cannot detach a thread that's already exiting */
- if (a_swap(&t->exitlock, 1))
+ if (a_swap(t->exitlock, 1))
return pthread_join(t, 0);
t->detached = 2;
- a_store(&t->exitlock, 0);
+ __unlock(t->exitlock);
return 0;
}
diff --git a/src/thread/pthread_kill.c b/src/thread/pthread_kill.c
index 15f70fb9..d9a5096a 100644
--- a/src/thread/pthread_kill.c
+++ b/src/thread/pthread_kill.c
@@ -3,8 +3,8 @@
int pthread_kill(pthread_t t, int sig)
{
int r;
- __lock(&t->killlock);
+ __lock(t->killlock);
r = t->dead ? ESRCH : -__syscall(SYS_tgkill, t->pid, t->tid, sig);
- __unlock(&t->killlock);
+ __unlock(t->killlock);
return r;
}