Lines Matching refs:rw
110 #define arch_read_relax(rw) barrier() argument
111 #define arch_write_relax(rw) barrier() argument
116 static inline void arch_read_lock(arch_rwlock_t *rw) in arch_read_lock() argument
120 old = __atomic_add(1, &rw->cnts); in arch_read_lock()
122 arch_read_lock_wait(rw); in arch_read_lock()
125 static inline void arch_read_unlock(arch_rwlock_t *rw) in arch_read_unlock() argument
127 __atomic_add_const_barrier(-1, &rw->cnts); in arch_read_unlock()
130 static inline void arch_write_lock(arch_rwlock_t *rw) in arch_write_lock() argument
132 if (!__atomic_cmpxchg_bool(&rw->cnts, 0, 0x30000)) in arch_write_lock()
133 arch_write_lock_wait(rw); in arch_write_lock()
136 static inline void arch_write_unlock(arch_rwlock_t *rw) in arch_write_unlock() argument
138 __atomic_add_barrier(-0x30000, &rw->cnts); in arch_write_unlock()
142 static inline int arch_read_trylock(arch_rwlock_t *rw) in arch_read_trylock() argument
146 old = READ_ONCE(rw->cnts); in arch_read_trylock()
148 __atomic_cmpxchg_bool(&rw->cnts, old, old + 1)); in arch_read_trylock()
151 static inline int arch_write_trylock(arch_rwlock_t *rw) in arch_write_trylock() argument
155 old = READ_ONCE(rw->cnts); in arch_write_trylock()
156 return !old && __atomic_cmpxchg_bool(&rw->cnts, 0, 0x30000); in arch_write_trylock()