17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate * CDDL HEADER START
37c478bd9Sstevel@tonic-gate *
47c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the
57c478bd9Sstevel@tonic-gate * Common Development and Distribution License, Version 1.0 only
67c478bd9Sstevel@tonic-gate * (the "License"). You may not use this file except in compliance
77c478bd9Sstevel@tonic-gate * with the License.
87c478bd9Sstevel@tonic-gate *
97c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
107c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing.
117c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions
127c478bd9Sstevel@tonic-gate * and limitations under the License.
137c478bd9Sstevel@tonic-gate *
147c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each
157c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
167c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the
177c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying
187c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner]
197c478bd9Sstevel@tonic-gate *
207c478bd9Sstevel@tonic-gate * CDDL HEADER END
217c478bd9Sstevel@tonic-gate */
227c478bd9Sstevel@tonic-gate /*
237c478bd9Sstevel@tonic-gate * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
247c478bd9Sstevel@tonic-gate * Use is subject to license terms.
25febac2a0SJosef 'Jeff' Sipek * Copyright 2014 Nexenta Systems, Inc. All rights reserved.
26*6a9ca708SJosef 'Jeff' Sipek * Copyright 2015 Josef 'Jeff' Sipek <jeffpc@josefsipek.net>
277c478bd9Sstevel@tonic-gate */
287c478bd9Sstevel@tonic-gate
297c478bd9Sstevel@tonic-gate #ifndef _ASM_ATOMIC_H
307c478bd9Sstevel@tonic-gate #define _ASM_ATOMIC_H
317c478bd9Sstevel@tonic-gate
326b7143d7SRichard Lowe #include <sys/ccompile.h>
337c478bd9Sstevel@tonic-gate #include <sys/types.h>
347c478bd9Sstevel@tonic-gate
357c478bd9Sstevel@tonic-gate #ifdef __cplusplus
367c478bd9Sstevel@tonic-gate extern "C" {
377c478bd9Sstevel@tonic-gate #endif
387c478bd9Sstevel@tonic-gate
397c478bd9Sstevel@tonic-gate #if !defined(__lint) && defined(__GNUC__)
407c478bd9Sstevel@tonic-gate
41febac2a0SJosef 'Jeff' Sipek /* BEGIN CSTYLED */
42febac2a0SJosef 'Jeff' Sipek /*
43febac2a0SJosef 'Jeff' Sipek * This file contains a number of static inline functions implementing
44febac2a0SJosef 'Jeff' Sipek * various atomic variable functions. Note that these are *not* all of the
45febac2a0SJosef 'Jeff' Sipek * atomic_* functions as defined in usr/src/uts/common/sys/atomic.h. All
46febac2a0SJosef 'Jeff' Sipek * possible atomic_* functions are implemented in usr/src/common/atomic in
47febac2a0SJosef 'Jeff' Sipek * pure assembly. In the absence of an identically named function in this
48febac2a0SJosef 'Jeff' Sipek * header file, any use of the function will result in the compiler emitting
49febac2a0SJosef 'Jeff' Sipek * a function call as usual. On the other hand, if an identically named
50febac2a0SJosef 'Jeff' Sipek * function exists in this header as a static inline, the compiler will
51febac2a0SJosef 'Jeff' Sipek * inline its contents and the linker never sees the symbol reference. We
52febac2a0SJosef 'Jeff' Sipek * use this to avoid implementing some of the more complex and less used
53febac2a0SJosef 'Jeff' Sipek * functions and instead falling back to function calls. Note that in some
54febac2a0SJosef 'Jeff' Sipek * cases (e.g., atomic_inc_64) we implement a static inline only on AMD64
55febac2a0SJosef 'Jeff' Sipek * but not i386.
56febac2a0SJosef 'Jeff' Sipek */
577c478bd9Sstevel@tonic-gate
58febac2a0SJosef 'Jeff' Sipek /*
59febac2a0SJosef 'Jeff' Sipek * Instruction suffixes for various operand sizes (assuming AMD64)
60febac2a0SJosef 'Jeff' Sipek */
61febac2a0SJosef 'Jeff' Sipek #define SUF_8 "b"
62febac2a0SJosef 'Jeff' Sipek #define SUF_16 "w"
63febac2a0SJosef 'Jeff' Sipek #define SUF_32 "l"
64febac2a0SJosef 'Jeff' Sipek #define SUF_64 "q"
65febac2a0SJosef 'Jeff' Sipek
66febac2a0SJosef 'Jeff' Sipek #if defined(__amd64)
67febac2a0SJosef 'Jeff' Sipek #define SUF_LONG SUF_64
68febac2a0SJosef 'Jeff' Sipek #define SUF_PTR SUF_64
69febac2a0SJosef 'Jeff' Sipek #define __ATOMIC_OP64(...) __ATOMIC_OPXX(__VA_ARGS__)
707c478bd9Sstevel@tonic-gate #elif defined(__i386)
71febac2a0SJosef 'Jeff' Sipek #define SUF_LONG SUF_32
72febac2a0SJosef 'Jeff' Sipek #define SUF_PTR SUF_32
73febac2a0SJosef 'Jeff' Sipek #define __ATOMIC_OP64(...)
74febac2a0SJosef 'Jeff' Sipek #else
75febac2a0SJosef 'Jeff' Sipek #error "port me"
76febac2a0SJosef 'Jeff' Sipek #endif
77febac2a0SJosef 'Jeff' Sipek
78febac2a0SJosef 'Jeff' Sipek #if defined(__amd64) || defined(__i386)
79febac2a0SJosef 'Jeff' Sipek
80febac2a0SJosef 'Jeff' Sipek #define __ATOMIC_OPXX(fxn, type, op) \
81febac2a0SJosef 'Jeff' Sipek extern __GNU_INLINE void \
82febac2a0SJosef 'Jeff' Sipek fxn(volatile type *target) \
83febac2a0SJosef 'Jeff' Sipek { \
84febac2a0SJosef 'Jeff' Sipek __asm__ __volatile__( \
85febac2a0SJosef 'Jeff' Sipek "lock; " op " %0" \
86*6a9ca708SJosef 'Jeff' Sipek : "+m" (*target) \
87*6a9ca708SJosef 'Jeff' Sipek : /* no inputs */ \
88*6a9ca708SJosef 'Jeff' Sipek : "cc"); \
89febac2a0SJosef 'Jeff' Sipek }
90febac2a0SJosef 'Jeff' Sipek
91febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_inc_8, uint8_t, "inc" SUF_8)
92febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_inc_16, uint16_t, "inc" SUF_16)
93febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_inc_32, uint32_t, "inc" SUF_32)
94febac2a0SJosef 'Jeff' Sipek __ATOMIC_OP64(atomic_inc_64, uint64_t, "inc" SUF_64)
95febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_inc_uchar, uchar_t, "inc" SUF_8)
96febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_inc_ushort, ushort_t, "inc" SUF_16)
97febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_inc_uint, uint_t, "inc" SUF_32)
98febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_inc_ulong, ulong_t, "inc" SUF_LONG)
99febac2a0SJosef 'Jeff' Sipek
100febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_dec_8, uint8_t, "dec" SUF_8)
101febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_dec_16, uint16_t, "dec" SUF_16)
102febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_dec_32, uint32_t, "dec" SUF_32)
103febac2a0SJosef 'Jeff' Sipek __ATOMIC_OP64(atomic_dec_64, uint64_t, "dec" SUF_64)
104febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_dec_uchar, uchar_t, "dec" SUF_8)
105febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_dec_ushort, ushort_t, "dec" SUF_16)
106febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_dec_uint, uint_t, "dec" SUF_32)
107febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_dec_ulong, ulong_t, "dec" SUF_LONG)
108febac2a0SJosef 'Jeff' Sipek
109febac2a0SJosef 'Jeff' Sipek #undef __ATOMIC_OPXX
110febac2a0SJosef 'Jeff' Sipek
111d8ccf998SJosef 'Jeff' Sipek #define __ATOMIC_OPXX(fxn, type1, type2, op, reg) \
112febac2a0SJosef 'Jeff' Sipek extern __GNU_INLINE void \
113febac2a0SJosef 'Jeff' Sipek fxn(volatile type1 *target, type2 delta) \
114febac2a0SJosef 'Jeff' Sipek { \
115febac2a0SJosef 'Jeff' Sipek __asm__ __volatile__( \
116febac2a0SJosef 'Jeff' Sipek "lock; " op " %1,%0" \
117febac2a0SJosef 'Jeff' Sipek : "+m" (*target) \
118*6a9ca708SJosef 'Jeff' Sipek : "i" reg (delta) \
119*6a9ca708SJosef 'Jeff' Sipek : "cc"); \
120febac2a0SJosef 'Jeff' Sipek }
121febac2a0SJosef 'Jeff' Sipek
122d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_add_8, uint8_t, int8_t, "add" SUF_8, "q")
123d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_add_16, uint16_t, int16_t, "add" SUF_16, "r")
124d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_add_32, uint32_t, int32_t, "add" SUF_32, "r")
125d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OP64(atomic_add_64, uint64_t, int64_t, "add" SUF_64, "r")
126d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_add_char, uchar_t, signed char, "add" SUF_8, "q")
127d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_add_short, ushort_t, short, "add" SUF_16, "r")
128d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_add_int, uint_t, int, "add" SUF_32, "r")
129d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_add_long, ulong_t, long, "add" SUF_LONG, "r")
130febac2a0SJosef 'Jeff' Sipek
131febac2a0SJosef 'Jeff' Sipek /*
132febac2a0SJosef 'Jeff' Sipek * We don't use the above macro here because atomic_add_ptr has an
133febac2a0SJosef 'Jeff' Sipek * inconsistent type. The first argument should really be a 'volatile void
134febac2a0SJosef 'Jeff' Sipek * **'.
135febac2a0SJosef 'Jeff' Sipek */
136febac2a0SJosef 'Jeff' Sipek extern __GNU_INLINE void
atomic_add_ptr(volatile void * target,ssize_t delta)137febac2a0SJosef 'Jeff' Sipek atomic_add_ptr(volatile void *target, ssize_t delta)
138febac2a0SJosef 'Jeff' Sipek {
139febac2a0SJosef 'Jeff' Sipek volatile void **tmp = (volatile void **)target;
140febac2a0SJosef 'Jeff' Sipek
141febac2a0SJosef 'Jeff' Sipek __asm__ __volatile__(
142febac2a0SJosef 'Jeff' Sipek "lock; add" SUF_PTR " %1,%0"
143febac2a0SJosef 'Jeff' Sipek : "+m" (*tmp)
144*6a9ca708SJosef 'Jeff' Sipek : "ir" (delta)
145*6a9ca708SJosef 'Jeff' Sipek : "cc");
146febac2a0SJosef 'Jeff' Sipek }
147febac2a0SJosef 'Jeff' Sipek
148d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_or_8, uint8_t, uint8_t, "or" SUF_8, "q")
149d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_or_16, uint16_t, uint16_t, "or" SUF_16, "r")
150d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_or_32, uint32_t, uint32_t, "or" SUF_32, "r")
151d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OP64(atomic_or_64, uint64_t, uint64_t, "or" SUF_64, "r")
152d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_or_uchar, uchar_t, uchar_t, "or" SUF_8, "q")
153d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_or_ushort, ushort_t, ushort_t, "or" SUF_16, "r")
154d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_or_uint, uint_t, uint_t, "or" SUF_32, "r")
155d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_or_ulong, ulong_t, ulong_t, "or" SUF_LONG, "r")
156febac2a0SJosef 'Jeff' Sipek
157d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_and_8, uint8_t, uint8_t, "and" SUF_8, "q")
158d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_and_16, uint16_t, uint16_t, "and" SUF_16, "r")
159d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_and_32, uint32_t, uint32_t, "and" SUF_32, "r")
160d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OP64(atomic_and_64, uint64_t, uint64_t, "and" SUF_64, "r")
161d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_and_uchar, uchar_t, uchar_t, "and" SUF_8, "q")
162d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_and_ushort, ushort_t, ushort_t, "and" SUF_16, "r")
163d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_and_uint, uint_t, uint_t, "and" SUF_32, "r")
164d8ccf998SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_and_ulong, ulong_t, ulong_t, "and" SUF_LONG, "r")
165febac2a0SJosef 'Jeff' Sipek
166febac2a0SJosef 'Jeff' Sipek #undef __ATOMIC_OPXX
167febac2a0SJosef 'Jeff' Sipek
168febac2a0SJosef 'Jeff' Sipek #define __ATOMIC_OPXX(fxn, type, op, reg) \
169febac2a0SJosef 'Jeff' Sipek extern __GNU_INLINE type \
170febac2a0SJosef 'Jeff' Sipek fxn(volatile type *target, type cmp, type new) \
171febac2a0SJosef 'Jeff' Sipek { \
172febac2a0SJosef 'Jeff' Sipek type ret; \
173febac2a0SJosef 'Jeff' Sipek __asm__ __volatile__( \
174febac2a0SJosef 'Jeff' Sipek "lock; " op " %2,%0" \
175febac2a0SJosef 'Jeff' Sipek : "+m" (*target), "=a" (ret) \
176febac2a0SJosef 'Jeff' Sipek : reg (new), "1" (cmp) \
177febac2a0SJosef 'Jeff' Sipek : "cc"); \
178febac2a0SJosef 'Jeff' Sipek return (ret); \
179febac2a0SJosef 'Jeff' Sipek }
180febac2a0SJosef 'Jeff' Sipek
181febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_cas_8, uint8_t, "cmpxchg" SUF_8, "q")
182febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_cas_16, uint16_t, "cmpxchg" SUF_16, "r")
183febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_cas_32, uint32_t, "cmpxchg" SUF_32, "r")
184febac2a0SJosef 'Jeff' Sipek __ATOMIC_OP64(atomic_cas_64, uint64_t, "cmpxchg" SUF_64, "r")
185febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_cas_uchar, uchar_t, "cmpxchg" SUF_8, "q")
186febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_cas_ushort, ushort_t, "cmpxchg" SUF_16, "r")
187febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_cas_uint, uint_t, "cmpxchg" SUF_32, "r")
188febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_cas_ulong, ulong_t, "cmpxchg" SUF_LONG, "r")
189febac2a0SJosef 'Jeff' Sipek
190febac2a0SJosef 'Jeff' Sipek #undef __ATOMIC_OPXX
191febac2a0SJosef 'Jeff' Sipek
192febac2a0SJosef 'Jeff' Sipek /*
193febac2a0SJosef 'Jeff' Sipek * We don't use the above macro here because atomic_cas_ptr has an
194febac2a0SJosef 'Jeff' Sipek * inconsistent type. The first argument should really be a 'volatile void
195febac2a0SJosef 'Jeff' Sipek * **'.
196febac2a0SJosef 'Jeff' Sipek */
197febac2a0SJosef 'Jeff' Sipek extern __GNU_INLINE void *
atomic_cas_ptr(volatile void * target,void * cmp,void * new)198febac2a0SJosef 'Jeff' Sipek atomic_cas_ptr(volatile void *target, void *cmp, void *new)
199febac2a0SJosef 'Jeff' Sipek {
200febac2a0SJosef 'Jeff' Sipek volatile void **tmp = (volatile void **)target;
201febac2a0SJosef 'Jeff' Sipek void *ret;
202febac2a0SJosef 'Jeff' Sipek
203febac2a0SJosef 'Jeff' Sipek __asm__ __volatile__(
204febac2a0SJosef 'Jeff' Sipek "lock; cmpxchg" SUF_PTR " %2,%0"
205febac2a0SJosef 'Jeff' Sipek : "+m" (*tmp), "=a" (ret)
206febac2a0SJosef 'Jeff' Sipek : "r" (new), "1" (cmp)
207febac2a0SJosef 'Jeff' Sipek : "cc");
208febac2a0SJosef 'Jeff' Sipek
209febac2a0SJosef 'Jeff' Sipek return (ret);
210febac2a0SJosef 'Jeff' Sipek }
211febac2a0SJosef 'Jeff' Sipek
212febac2a0SJosef 'Jeff' Sipek #define __ATOMIC_OPXX(fxn, type, op, reg) \
213febac2a0SJosef 'Jeff' Sipek extern __GNU_INLINE type \
214febac2a0SJosef 'Jeff' Sipek fxn(volatile type *target, type val) \
215febac2a0SJosef 'Jeff' Sipek { \
216febac2a0SJosef 'Jeff' Sipek __asm__ __volatile__( \
217febac2a0SJosef 'Jeff' Sipek op " %1,%0" \
218febac2a0SJosef 'Jeff' Sipek : "+m" (*target), "+" reg (val)); \
219febac2a0SJosef 'Jeff' Sipek return (val); \
220febac2a0SJosef 'Jeff' Sipek }
221febac2a0SJosef 'Jeff' Sipek
222febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_swap_8, uint8_t, "xchg" SUF_8, "q")
223febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_swap_16, uint16_t, "xchg" SUF_16, "r")
224febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_swap_32, uint32_t, "xchg" SUF_32, "r")
225febac2a0SJosef 'Jeff' Sipek __ATOMIC_OP64(atomic_swap_64, uint64_t, "xchg" SUF_64, "r")
226febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_swap_uchar, uchar_t, "xchg" SUF_8, "q")
227febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_swap_ushort, ushort_t, "xchg" SUF_16, "r")
228febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_swap_uint, uint_t, "xchg" SUF_32, "r")
229febac2a0SJosef 'Jeff' Sipek __ATOMIC_OPXX(atomic_swap_ulong, ulong_t, "xchg" SUF_LONG, "r")
230febac2a0SJosef 'Jeff' Sipek
231febac2a0SJosef 'Jeff' Sipek #undef __ATOMIC_OPXX
232febac2a0SJosef 'Jeff' Sipek
233febac2a0SJosef 'Jeff' Sipek /*
234febac2a0SJosef 'Jeff' Sipek * We don't use the above macro here because atomic_swap_ptr has an
235febac2a0SJosef 'Jeff' Sipek * inconsistent type. The first argument should really be a 'volatile void
236febac2a0SJosef 'Jeff' Sipek * **'.
237febac2a0SJosef 'Jeff' Sipek */
238febac2a0SJosef 'Jeff' Sipek extern __GNU_INLINE void *
atomic_swap_ptr(volatile void * target,void * val)239febac2a0SJosef 'Jeff' Sipek atomic_swap_ptr(volatile void *target, void *val)
240febac2a0SJosef 'Jeff' Sipek {
241febac2a0SJosef 'Jeff' Sipek volatile void **tmp = (volatile void **)target;
242febac2a0SJosef 'Jeff' Sipek
243febac2a0SJosef 'Jeff' Sipek __asm__ __volatile__(
244febac2a0SJosef 'Jeff' Sipek "xchg" SUF_PTR " %1,%0"
245febac2a0SJosef 'Jeff' Sipek : "+m" (*tmp), "+r" (val));
246febac2a0SJosef 'Jeff' Sipek
247febac2a0SJosef 'Jeff' Sipek return (val);
248febac2a0SJosef 'Jeff' Sipek }
2497c478bd9Sstevel@tonic-gate
2507c478bd9Sstevel@tonic-gate #else
2517c478bd9Sstevel@tonic-gate #error "port me"
2527c478bd9Sstevel@tonic-gate #endif
2537c478bd9Sstevel@tonic-gate
254febac2a0SJosef 'Jeff' Sipek #undef SUF_8
255febac2a0SJosef 'Jeff' Sipek #undef SUF_16
256febac2a0SJosef 'Jeff' Sipek #undef SUF_32
257febac2a0SJosef 'Jeff' Sipek #undef SUF_64
258febac2a0SJosef 'Jeff' Sipek #undef SUF_LONG
259febac2a0SJosef 'Jeff' Sipek #undef SUF_PTR
260febac2a0SJosef 'Jeff' Sipek
261febac2a0SJosef 'Jeff' Sipek #undef __ATOMIC_OP64
262febac2a0SJosef 'Jeff' Sipek
263febac2a0SJosef 'Jeff' Sipek /* END CSTYLED */
264febac2a0SJosef 'Jeff' Sipek
2657c478bd9Sstevel@tonic-gate #endif /* !__lint && __GNUC__ */
2667c478bd9Sstevel@tonic-gate
2677c478bd9Sstevel@tonic-gate #ifdef __cplusplus
2687c478bd9Sstevel@tonic-gate }
2697c478bd9Sstevel@tonic-gate #endif
2707c478bd9Sstevel@tonic-gate
2717c478bd9Sstevel@tonic-gate #endif /* _ASM_ATOMIC_H */
272