]> rtime.felk.cvut.cz Git - l4.git/blob - l4/pkg/uclibc/lib/contrib/uclibc/libpthread/linuxthreads/sysdeps/powerpc/powerpc64/pspinlock.c
update
[l4.git] / l4 / pkg / uclibc / lib / contrib / uclibc / libpthread / linuxthreads / sysdeps / powerpc / powerpc64 / pspinlock.c
1 /* POSIX spinlock implementation.  PowerPC version.
2    Copyright (C) 2000, 2003 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public License as
7    published by the Free Software Foundation; either version 2.1 of the
8    License, or (at your option) any later version.
9
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
14
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; see the file COPYING.LIB.  If
17    not, see <http://www.gnu.org/licenses/>.  */
18
19 #include <errno.h>
20 #include <pthread.h>
21 #include "internals.h"
22
23 int
24 __pthread_spin_lock (pthread_spinlock_t *lock)
25 {
26   while (! __compare_and_swap32 ((int *)lock, 0, 1))
27     ;
28   return 0;
29 }
30 weak_alias (__pthread_spin_lock, pthread_spin_lock)
31
32
33 int
34 __pthread_spin_trylock (pthread_spinlock_t *lock)
35 {
36   return __compare_and_swap32 ((int *)lock, 0, 1) ? 0 : EBUSY;
37 }
38 weak_alias (__pthread_spin_trylock, pthread_spin_trylock)
39
40
41 int
42 __pthread_spin_unlock (pthread_spinlock_t *lock)
43 {
44   MEMORY_BARRIER ();
45   *lock = 0;
46   return 0;
47 }
48 weak_alias (__pthread_spin_unlock, pthread_spin_unlock)
49
50
51 int
52 __pthread_spin_init (pthread_spinlock_t *lock, int pshared)
53 {
54   /* We can ignore the `pshared' parameter.  Since we are busy-waiting
55      all processes which can access the memory location `lock' points
56      to can use the spinlock.  */
57   *lock = 0;
58   return 0;
59 }
60 weak_alias (__pthread_spin_init, pthread_spin_init)
61
62
63 int
64 __pthread_spin_destroy (pthread_spinlock_t *lock)
65 {
66   /* Nothing to do.  */
67   return 0;
68 }
69 weak_alias (__pthread_spin_destroy, pthread_spin_destroy)