aboutsummaryrefslogtreecommitdiff
path: root/linuxthreads/sysdeps
diff options
context:
space:
mode:
authorGeoff Keating <geoffk@cygnus.com>2000-06-12 07:00:35 +0000
committerGeoff Keating <geoffk@cygnus.com>2000-06-12 07:00:35 +0000
commit2b72ebac3fdf9991e797f788b8bf636b9fcb2c7b (patch)
treefc26ec5b7b90396c9f78457a860ce51b41f6b136 /linuxthreads/sysdeps
parent38677aced0c16cd290b8250e07c174ae8c5c7292 (diff)
downloadglibc-2b72ebac3fdf9991e797f788b8bf636b9fcb2c7b.tar
glibc-2b72ebac3fdf9991e797f788b8bf636b9fcb2c7b.tar.gz
glibc-2b72ebac3fdf9991e797f788b8bf636b9fcb2c7b.tar.bz2
glibc-2b72ebac3fdf9991e797f788b8bf636b9fcb2c7b.zip
* sysdeps/powerpc/pspinlock.c (__pthread_spin_lock): Implement. (__pthread_spin_trylock): Implement. (__pthread_spin_unlock): Implement. (__pthread_spin_init): Implement. (__pthread_spin_destroy): Implement.
2000-06-11 Geoff Keating <geoffk@cygnus.com> * sysdeps/powerpc/pspinlock.c (__pthread_spin_lock): Implement. (__pthread_spin_trylock): Implement. (__pthread_spin_unlock): Implement. (__pthread_spin_init): Implement. (__pthread_spin_destroy): Implement. really append the entry.
Diffstat (limited to 'linuxthreads/sysdeps')
-rw-r--r--linuxthreads/sysdeps/powerpc/pspinlock.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/linuxthreads/sysdeps/powerpc/pspinlock.c b/linuxthreads/sysdeps/powerpc/pspinlock.c
index 6858ee1cf8..77cad0c8af 100644
--- a/linuxthreads/sysdeps/powerpc/pspinlock.c
+++ b/linuxthreads/sysdeps/powerpc/pspinlock.c
@@ -19,12 +19,15 @@
#include <errno.h>
#include <pthread.h>
+#include <pt-machine.h>
int
__pthread_spin_lock (pthread_spinlock_t *lock)
{
- XXX
+ while (! __compare_and_swap ((long int *)lock, 0, 1))
+ ;
+ return 0;
}
weak_alias (__pthread_spin_lock, pthread_spin_lock)
@@ -32,7 +35,7 @@ weak_alias (__pthread_spin_lock, pthread_spin_lock)
int
__pthread_spin_trylock (pthread_spinlock_t *lock)
{
- XXX
+ return __compare_and_swap ((long int *)lock, 0, 1) ? 0 : EBUSY;
}
weak_alias (__pthread_spin_trylock, pthread_spin_trylock)
@@ -40,7 +43,9 @@ weak_alias (__pthread_spin_trylock, pthread_spin_trylock)
int
__pthread_spin_unlock (pthread_spinlock_t *lock)
{
- XXX
+ MEMORY_BARRIER ();
+ *lock = 0;
+ return 0;
}
weak_alias (__pthread_spin_unlock, pthread_spin_unlock)
@@ -51,7 +56,7 @@ __pthread_spin_init (pthread_spinlock_t *lock, int pshared)
/* We can ignore the `pshared' parameter. Since we are busy-waiting
all processes which can access the memory location `lock' points
to can use the spinlock. */
- XXX
+ *lock = 1;
return 0;
}
weak_alias (__pthread_spin_init, pthread_spin_init)