/* $OpenBSD: _atomic_lock.c,v 1.3 2008/10/02 23:29:26 deraadt Exp $ */ /* David Leonard, . Public domain. */ /* * Atomic lock for m68k */ #include int _atomic_lock(volatile _spinlock_lock_t *lock) { _spinlock_lock_t old; /* * The Compare And Swap instruction (mc68020 and above) * compares its first operand with the memory addressed by * the third. If they are the same value, the second operand * is stored at the address. Otherwise the 1st operand (register) * is loaded with the contents of the 3rd operand. * * old = 0; * CAS(old, 1, *lock); * if (old == 1) { lock was acquired } * * From the MC68030 User's Manual (Motorola), page `3-13': * CAS Dc,Du,: * ( - Dc) -> cc; * if Z then Du -> * else -> Dc; */ old = _SPINLOCK_UNLOCKED; __asm__("casl %0, %2, %1" : "=d" (old), "=m" (*lock) : "d" (_SPINLOCK_LOCKED), "0" (old), "1" (*lock) : "cc"); return (old != _SPINLOCK_UNLOCKED); }