]> xenbits.xensource.com Git - xen.git/commitdiff
rwlock: allow arch to override write_unlock() atomic
authorJan Beulich <jbeulich@suse.com>
Fri, 9 Jan 2015 16:31:45 +0000 (17:31 +0100)
committerJan Beulich <jbeulich@suse.com>
Fri, 9 Jan 2015 16:31:45 +0000 (17:31 +0100)
... (for consistency with read_unlock()), and default it to xchg(),
being generally cheaper than cmpxchg().

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Tim Deegan <tim@xen.org>
Reviewed-by: Andrew Cooper <andrew.cooper3@citrix.com>
xen/common/spinlock.c

index f6925ec5f76353309ae2c1b891bbcf336e45846b..5fd8b1c84c61187c1e88825e2f35f27b957a1ef0 100644 (file)
@@ -438,10 +438,14 @@ int _write_trylock(rwlock_t *lock)
     return 1;
 }
 
-void _write_unlock(rwlock_t *lock)
+#ifndef _raw_write_unlock
+# define _raw_write_unlock(l) xchg(&(l)->lock, 0)
+#endif
+
+inline void _write_unlock(rwlock_t *lock)
 {
     preempt_enable();
-    if ( cmpxchg(&lock->lock, RW_WRITE_FLAG, 0) != RW_WRITE_FLAG )
+    if ( _raw_write_unlock(lock) != RW_WRITE_FLAG )
         BUG();
 }