* sysdeps/powerpc/pspinlock.c (__pthread_spin_lock): Implement. (__pthread_spin_trylo...
authorGeoff Keating <geoffk@cygnus.com>
Mon, 12 Jun 2000 07:00:35 +0000 (07:00 +0000)
committerGeoff Keating <geoffk@cygnus.com>
Mon, 12 Jun 2000 07:00:35 +0000 (07:00 +0000)
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.

linuxthreads/ChangeLog
linuxthreads/sysdeps/powerpc/pspinlock.c

index c508e8d..c948fe3 100644 (file)
@@ -1,7 +1,15 @@
+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.
+
 2000-06-10  Ulrich Drepper  <drepper@redhat.com>
 
        * sysdeps/pthread/timer_routines.c (list_append): Little fix to
-       reall append the entry.
+       really append the entry.
 
 2000-06-10  Andreas Jaeger  <aj@suse.de>
 
index 6858ee1..77cad0c 100644 (file)
 
 #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)