Expand PMF_FN_* macros.
[netbsd-mini2440.git] / sys / arch / mips / include / lock.h
blobfd4d1c8d7a1673bb5b6f114150dcc2cb69c1930e
1 /* $NetBSD: lock.h,v 1.16 2008/04/28 20:23:28 martin Exp $ */
3 /*-
4 * Copyright (c) 2001, 2007 The NetBSD Foundation, Inc.
5 * All rights reserved.
7 * This code is derived from software contributed to The NetBSD Foundation
8 * by Wayne Knowles and Andrew Doran.
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
33 * Machine-dependent spin lock operations for MIPS processors.
35 * Note: R2000/R3000 doesn't have any atomic update instructions; this
36 * will cause problems for user applications using this header.
39 #ifndef _MIPS_LOCK_H_
40 #define _MIPS_LOCK_H_
42 #include <sys/param.h>
44 static __inline int
45 __SIMPLELOCK_LOCKED_P(__cpu_simple_lock_t *__ptr)
47 return *__ptr == __SIMPLELOCK_LOCKED;
50 static __inline int
51 __SIMPLELOCK_UNLOCKED_P(__cpu_simple_lock_t *__ptr)
53 return *__ptr == __SIMPLELOCK_UNLOCKED;
56 static __inline void
57 __cpu_simple_lock_clear(__cpu_simple_lock_t *__ptr)
59 *__ptr = __SIMPLELOCK_UNLOCKED;
62 static __inline void
63 __cpu_simple_lock_set(__cpu_simple_lock_t *__ptr)
65 *__ptr = __SIMPLELOCK_LOCKED;
68 #ifndef _HARDKERNEL
70 static __inline int
71 __cpu_simple_lock_try(__cpu_simple_lock_t *lp)
73 unsigned long t0, v0;
75 __asm volatile(
76 "# -- BEGIN __cpu_simple_lock_try\n"
77 " .set push \n"
78 " .set mips2 \n"
79 "1: ll %0, %4 \n"
80 " bnez %0, 2f \n"
81 " nop # BDslot \n"
82 " li %0, %3 \n"
83 " sc %0, %2 \n"
84 " beqz %0, 2f \n"
85 " nop # BDslot \n"
86 " li %1, 1 \n"
87 " sync \n"
88 " j 3f \n"
89 " nop \n"
90 " nop \n"
91 "2: li %1, 0 \n"
92 "3: \n"
93 " .set pop \n"
94 "# -- END __cpu_simple_lock_try \n"
95 : "=r" (t0), "=r" (v0), "+m" (*lp)
96 : "i" (__SIMPLELOCK_LOCKED), "m" (*lp));
98 return (v0 != 0);
101 #ifdef MIPS1
102 static __inline void
103 mb_read(void)
105 __insn_barrier();
108 static __inline void
109 mb_write(void)
111 __insn_barrier();
114 static __inline void
115 mb_memory(void)
117 __insn_barrier();
119 #else /* MIPS1*/
120 static __inline void
121 mb_read(void)
123 __asm volatile(
124 " .set push\n"
125 " .set mips2\n"
126 " sync\n"
127 " .set pop"
128 ::: "memory"
132 static __inline void
133 mb_write(void)
135 mb_read();
138 static __inline void
139 mb_memory(void)
141 mb_read();
143 #endif /* MIPS1 */
145 #else /* !_HARDKERNEL */
147 unsigned _atomic_cas_uint(volatile unsigned *, unsigned, unsigned);
148 void mb_read(void);
149 void mb_write(void);
150 void mb_memory(void);
152 static __inline int
153 __cpu_simple_lock_try(__cpu_simple_lock_t *lp)
156 return _atomic_cas_uint((volatile unsigned *)lp,
157 __SIMPLELOCK_UNLOCKED, __SIMPLELOCK_LOCKED) ==
158 __SIMPLELOCK_UNLOCKED;
161 #endif /* _HARDKERNEL */
163 static __inline void
164 __cpu_simple_lock_init(__cpu_simple_lock_t *lp)
167 *lp = __SIMPLELOCK_UNLOCKED;
168 mb_memory();
171 static __inline void
172 __cpu_simple_lock(__cpu_simple_lock_t *lp)
175 while (!__cpu_simple_lock_try(lp))
176 while (*lp == __SIMPLELOCK_LOCKED)
177 /* spin */;
180 static __inline void
181 __cpu_simple_unlock(__cpu_simple_lock_t *lp)
184 mb_memory();
185 *lp = __SIMPLELOCK_UNLOCKED;
188 #endif /* _MIPS_LOCK_H_ */