|
@@ -39,8 +39,7 @@ void queued_read_lock_slowpath(struct qrwlock *lock)
|
|
|
* so spin with ACQUIRE semantics until the lock is available
|
|
|
* without waiting in the queue.
|
|
|
*/
|
|
|
- atomic_cond_read_acquire(&lock->cnts, (VAL & _QW_WMASK)
|
|
|
- != _QW_LOCKED);
|
|
|
+ atomic_cond_read_acquire(&lock->cnts, !(VAL & _QW_LOCKED));
|
|
|
return;
|
|
|
}
|
|
|
atomic_sub(_QR_BIAS, &lock->cnts);
|
|
@@ -56,7 +55,7 @@ void queued_read_lock_slowpath(struct qrwlock *lock)
|
|
|
* that accesses can't leak upwards out of our subsequent critical
|
|
|
* section in the case that the lock is currently held for write.
|
|
|
*/
|
|
|
- atomic_cond_read_acquire(&lock->cnts, (VAL & _QW_WMASK) != _QW_LOCKED);
|
|
|
+ atomic_cond_read_acquire(&lock->cnts, !(VAL & _QW_LOCKED));
|
|
|
|
|
|
/*
|
|
|
* Signal the next one in queue to become queue head
|
|
@@ -79,19 +78,10 @@ void queued_write_lock_slowpath(struct qrwlock *lock)
|
|
|
(atomic_cmpxchg_acquire(&lock->cnts, 0, _QW_LOCKED) == 0))
|
|
|
goto unlock;
|
|
|
|
|
|
- /*
|
|
|
- * Set the waiting flag to notify readers that a writer is pending,
|
|
|
- * or wait for a previous writer to go away.
|
|
|
- */
|
|
|
- for (;;) {
|
|
|
- if (!READ_ONCE(lock->wmode) &&
|
|
|
- (cmpxchg_relaxed(&lock->wmode, 0, _QW_WAITING) == 0))
|
|
|
- break;
|
|
|
-
|
|
|
- cpu_relax();
|
|
|
- }
|
|
|
+ /* Set the waiting flag to notify readers that a writer is pending */
|
|
|
+ atomic_add(_QW_WAITING, &lock->cnts);
|
|
|
|
|
|
- /* When no more readers, set the locked flag */
|
|
|
+ /* When no more readers or writers, set the locked flag */
|
|
|
do {
|
|
|
atomic_cond_read_acquire(&lock->cnts, VAL == _QW_WAITING);
|
|
|
} while (atomic_cmpxchg_relaxed(&lock->cnts, _QW_WAITING,
|