Fixed incorrect use of mvcle introduced by 2001-07-12 change.
[kopensolaris-gnu/glibc.git] / sysdeps / powerpc / atomicity.h
1 /* Low-level functions for atomic operations.  PowerPC version.
2    Copyright (C) 1997, 1998, 1999, 2000 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
7    License as published by the Free Software Foundation; either
8    version 2.1 of the 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; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
19
20 #ifndef _ATOMICITY_H
21 #define _ATOMICITY_H    1
22
23 #include <inttypes.h>
24
25 #if BROKEN_PPC_ASM_CR0
26 # define __ATOMICITY_INLINE /* nothing */
27 #else
28 # define __ATOMICITY_INLINE inline
29 #endif
30
31 static __ATOMICITY_INLINE int
32 __attribute__ ((unused))
33 exchange_and_add (volatile uint32_t *mem, int val)
34 {
35   int tmp, result;
36   __asm__ ("\n\
37 0:      lwarx   %0,0,%2 \n\
38         add%I3  %1,%0,%3        \n\
39         stwcx.  %1,0,%2 \n\
40         bne-    0b      \n\
41 " : "=&b"(result), "=&r"(tmp) : "r" (mem), "Ir"(val) : "cr0", "memory");
42   return result;
43 }
44
45 static __ATOMICITY_INLINE void
46 __attribute__ ((unused))
47 atomic_add (volatile uint32_t *mem, int val)
48 {
49   int tmp;
50   __asm__ ("\n\
51 0:      lwarx   %0,0,%1 \n\
52         add%I2  %0,%0,%2        \n\
53         stwcx.  %0,0,%1 \n\
54         bne-    0b      \n\
55 " : "=&b"(tmp) : "r" (mem), "Ir"(val) : "cr0", "memory");
56 }
57
58 static __ATOMICITY_INLINE int
59 __attribute__ ((unused))
60 compare_and_swap (volatile long int *p, long int oldval, long int newval)
61 {
62   int result;
63   __asm__ ("\n\
64 0:      lwarx   %0,0,%1 \n\
65         sub%I2c.        %0,%0,%2        \n\
66         cntlzw  %0,%0   \n\
67         bne-    1f      \n\
68         stwcx.  %3,0,%1 \n\
69         bne-    0b      \n\
70 1:      \n\
71 " : "=&b"(result) : "r"(p), "Ir"(oldval), "r"(newval) : "cr0", "memory");
72   return result >> 5;
73 }
74
75 static __ATOMICITY_INLINE long int
76 __attribute__ ((unused))
77 always_swap (volatile long int *p, long int newval)
78 {
79   long int result;
80   __asm__ ("\n\
81 0:      lwarx   %0,0,%1 \n\
82         stwcx.  %2,0,%1 \n\
83         bne-    0b      \n\
84 " : "=&r"(result) : "r"(p), "r"(newval) : "cr0", "memory");
85   return result;
86 }
87
88 static __ATOMICITY_INLINE int
89 __attribute__ ((unused))
90 test_and_set (volatile long int *p, long int newval)
91 {
92   int result;
93   __asm__ ("\n\
94 0:      lwarx   %0,0,%1 \n\
95         cmpwi   %0,0    \n\
96         bne-    1f      \n\
97         stwcx.  %2,0,%1 \n\
98         bne-    0b      \n\
99 1:      \n\
100 " : "=&r"(result) : "r"(p), "r"(newval) : "cr0", "memory");
101   return result;
102 }
103
104 #endif /* atomicity.h */