[BACK]Return to atomic.h CVS log [TXT][DIR] Up to [local] / sys / arch / amd64 / include

Annotation of sys/arch/amd64/include/atomic.h, Revision 1.1.1.1

1.1       nbrk        1: /*     $OpenBSD: atomic.h,v 1.6 2007/05/25 16:22:11 art Exp $  */
                      2: /*     $NetBSD: atomic.h,v 1.1 2003/04/26 18:39:37 fvdl Exp $  */
                      3:
                      4: /*
                      5:  * Copyright 2002 (c) Wasabi Systems, Inc.
                      6:  * All rights reserved.
                      7:  *
                      8:  * Written by Frank van der Linden for Wasabi Systems, Inc.
                      9:  *
                     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.
                     18:  * 3. All advertising materials mentioning features or use of this software
                     19:  *    must display the following acknowledgement:
                     20:  *      This product includes software developed for the NetBSD Project by
                     21:  *      Wasabi Systems, Inc.
                     22:  * 4. The name of Wasabi Systems, Inc. may not be used to endorse
                     23:  *    or promote products derived from this software without specific prior
                     24:  *    written permission.
                     25:  *
                     26:  * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
                     27:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
                     28:  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
                     29:  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL WASABI SYSTEMS, INC
                     30:  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
                     31:  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
                     32:  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
                     33:  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
                     34:  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
                     35:  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
                     36:  * POSSIBILITY OF SUCH DAMAGE.
                     37:  */
                     38:
                     39: #ifndef _AMD64_ATOMIC_H
                     40: #define _AMD64_ATOMIC_H
                     41:
                     42: /*
                     43:  * Perform atomic operations on memory. Should be atomic with respect
                     44:  * to interrupts and multiple processors.
                     45:  *
                     46:  * void atomic_setbits_int(volatile u_int *a, u_int mask) { *a |= mask; }
                     47:  * void atomic_clearbits_int(volatile u_int *a, u_int mas) { *a &= ~mask; }
                     48:  */
                     49:
                     50: #if defined(_KERNEL) && !defined(_LOCORE)
                     51:
                     52: #ifdef MULTIPROCESSOR
                     53: #define LOCK "lock"
                     54: #else
                     55: #define LOCK
                     56: #endif
                     57:
                     58: static __inline u_int64_t
                     59: x86_atomic_testset_u64(volatile u_int64_t *ptr, u_int64_t val)
                     60: {
                     61:        __asm__ volatile ("xchgq %0,(%2)" :"=r" (val):"0" (val),"r" (ptr));
                     62:        return val;
                     63: }
                     64:
                     65: static __inline u_int32_t
                     66: x86_atomic_testset_u32(volatile u_int32_t *ptr, u_int32_t val)
                     67: {
                     68:        __asm__ volatile ("xchgl %0,(%2)" :"=r" (val):"0" (val),"r" (ptr));
                     69:        return val;
                     70: }
                     71:
                     72: static __inline int32_t
                     73: x86_atomic_testset_i32(volatile int32_t *ptr, int32_t val)
                     74: {
                     75:        __asm__ volatile ("xchgl %0,(%2)" :"=r" (val):"0" (val),"r" (ptr));
                     76:        return val;
                     77: }
                     78:
                     79:
                     80:
                     81: static __inline void
                     82: x86_atomic_setbits_u32(volatile u_int32_t *ptr, u_int32_t bits)
                     83: {
                     84:        __asm __volatile(LOCK " orl %1,%0" :  "=m" (*ptr) : "ir" (bits));
                     85: }
                     86:
                     87: static __inline void
                     88: x86_atomic_clearbits_u32(volatile u_int32_t *ptr, u_int32_t bits)
                     89: {
                     90:        __asm __volatile(LOCK " andl %1,%0" :  "=m" (*ptr) : "ir" (~bits));
                     91: }
                     92:
                     93: static __inline u_long
                     94: x86_atomic_cas_ul(volatile u_long *ptr, u_long expect, u_long set)
                     95: {
                     96:        u_long res;
                     97:
                     98:        __asm volatile(LOCK " cmpxchgq %2, %1" : "=a" (res), "=m" (*ptr)
                     99:            : "r" (set), "a" (expect), "m" (*ptr) : "memory");
                    100:
                    101:        return (res);
                    102: }
                    103:
                    104: /*
                    105:  * XXX XXX XXX
                    106:  * theoretically 64bit cannot be used as
                    107:  * an "i" and thus if we ever try to give
                    108:  * these anything from the high dword there
                    109:  * is an asm error pending
                    110:  */
                    111: static __inline void
                    112: x86_atomic_setbits_u64(volatile u_int64_t *ptr, u_int64_t bits)
                    113: {
                    114:        __asm __volatile(LOCK " orq %1,%0" :  "=m" (*ptr) : "ir" (bits));
                    115: }
                    116:
                    117: static __inline void
                    118: x86_atomic_clearbits_u64(volatile u_int64_t *ptr, u_int64_t bits)
                    119: {
                    120:        __asm __volatile(LOCK " andq %1,%0" :  "=m" (*ptr) : "ir" (~bits));
                    121: }
                    122:
                    123: #define x86_atomic_testset_ul  x86_atomic_testset_u32
                    124: #define x86_atomic_testset_i   x86_atomic_testset_i32
                    125: #define x86_atomic_setbits_l   x86_atomic_setbits_u32
                    126: #define x86_atomic_setbits_ul  x86_atomic_setbits_u32
                    127: #define x86_atomic_clearbits_l x86_atomic_clearbits_u32
                    128: #define x86_atomic_clearbits_ul        x86_atomic_clearbits_u32
                    129:
                    130: #define atomic_setbits_int x86_atomic_setbits_u32
                    131: #define atomic_clearbits_int x86_atomic_clearbits_u32
                    132:
                    133: #undef LOCK
                    134:
                    135: #endif /* defined(_KERNEL) && !defined(_LOCORE) */
                    136: #endif /* _AMD64_ATOMIC_H_ */

CVSweb