578369a7fe921ef30f622d7bbeb94b0a20521249
[kopensolaris-gnu/glibc.git] / linuxthreads / sysdeps / powerpc / pt-machine.h
1 /* Machine-dependent pthreads configuration and inline functions.
2    powerpc version.
3    Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
4    This file is part of the GNU C Library.
5
6    The GNU C Library is free software; you can redistribute it and/or
7    modify it under the terms of the GNU Library General Public License as
8    published by the Free Software Foundation; either version 2 of the
9    License, or (at your option) any later version.
10
11    The GNU C Library is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14    Library General Public License for more details.
15
16    You should have received a copy of the GNU Library General Public
17    License along with the GNU C Library; see the file COPYING.LIB.  If
18    not, write to the Free Software Foundation, Inc.,
19    59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
20
21 /* These routines are from Appendix G of the 'PowerPC 601 RISC Microprocessor
22    User's Manual', by IBM and Motorola.  */
23
24 #ifndef PT_EI
25 # define PT_EI extern inline
26 #endif
27
28 /* For multiprocessor systems, we want to ensure all memory accesses
29    are completed before we reset a lock.  */
30 #if 0
31 /* on non multiprocessor systems, you can just: */
32 #define sync() /* nothing */
33 #else
34 #define sync() __asm__ __volatile__ ("sync")
35 #endif
36
37 /* Get some notion of the current stack.  Need not be exactly the top
38    of the stack, just something somewhere in the current frame.  */
39 #define CURRENT_STACK_FRAME  stack_pointer
40 register char * stack_pointer __asm__ ("r1");
41
42 /* Compare-and-swap for semaphores. */
43 /* note that test-and-set(x) is the same as compare-and-swap(x, 0, 1) */
44
45 #define HAS_COMPARE_AND_SWAP
46 #if BROKEN_PPC_ASM_CR0
47 static
48 #else
49 PT_EI
50 #endif
51 int
52 __compare_and_swap (long int *p, long int oldval, long int newval)
53 {
54   int ret;
55
56   sync();
57   __asm__ __volatile__(
58                        "0:    lwarx %0,0,%1 ;"
59                        "      xor. %0,%3,%0;"
60                        "      bne 1f;"
61                        "      stwcx. %2,0,%1;"
62                        "      bne- 0b;"
63                        "1:    "
64         : "=&r"(ret)
65         : "r"(p), "r"(newval), "r"(oldval)
66         : "cr0", "memory");
67   sync();
68   return ret == 0;
69 }