Merge branches 'x86/apic', 'x86/asm', 'x86/cleanups', 'x86/debug', 'x86/kconfig'...
[linux-2.6/mini2440.git] / include / asm-generic / cmpxchg.h
blob213ac6e8fe392b536480898e626ad3ff523a1e5d
1 #ifndef __ASM_GENERIC_CMPXCHG_H
2 #define __ASM_GENERIC_CMPXCHG_H
4 /*
5 * Generic cmpxchg
7 * Uses the local cmpxchg. Does not support SMP.
8 */
9 #ifdef CONFIG_SMP
10 #error "Cannot use generic cmpxchg on SMP"
11 #endif
14 * Atomic compare and exchange.
16 * Do not define __HAVE_ARCH_CMPXCHG because we want to use it to check whether
17 * a cmpxchg primitive faster than repeated local irq save/restore exists.
19 #define cmpxchg(ptr, o, n) cmpxchg_local((ptr), (o), (n))
20 #define cmpxchg64(ptr, o, n) cmpxchg64_local((ptr), (o), (n))
22 #endif