[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 30/35] qemu_co_rwlock_unlock
From: |
Paolo Bonzini |
Subject: |
[PATCH 30/35] qemu_co_rwlock_unlock |
Date: |
Thu, 10 Mar 2022 13:44:08 +0100 |
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
---
util/qemu-coroutine-lock.c | 25 +++++++++++++++++++++----
1 file changed, 21 insertions(+), 4 deletions(-)
diff --git a/util/qemu-coroutine-lock.c b/util/qemu-coroutine-lock.c
index e7eb446566..c164cf6b15 100644
--- a/util/qemu-coroutine-lock.c
+++ b/util/qemu-coroutine-lock.c
@@ -449,15 +449,21 @@ CoroutineAction qemu_co_rwlock_rdlock(CoRwlock *lock)
return CO_INIT_FRAME(qemu_co_rwlock_rdlock, lock);
}
-#if 0
-void qemu_co_rwlock_unlock(CoRwlock *lock)
+CO_DECLARE_FRAME(qemu_co_rwlock_unlock, CoRwlock *lock);
+static CoroutineAction co__qemu_co_rwlock_unlock(void *_frame)
{
+ struct FRAME__qemu_co_rwlock_unlock *_f = _frame;
+ CO_ARG(lock);
Coroutine *self = qemu_coroutine_self();
+switch(_f->_step) {
+case 0:
+_f->_step = 1;
assert(qemu_in_coroutine());
self->locks_held--;
- qemu_co_mutex_lock(&lock->mutex);
+ return qemu_co_mutex_lock(&lock->mutex);
+case 1:
if (lock->owners > 0) {
lock->owners--;
} else {
@@ -465,9 +471,20 @@ void qemu_co_rwlock_unlock(CoRwlock *lock)
lock->owners = 0;
}
- qemu_co_rwlock_maybe_wake_one(lock);
+_f->_step = 2;
+ return qemu_co_rwlock_maybe_wake_one(lock);
+case 2:
+ break;
+}
+return stack_free(&_f->common);
}
+CoroutineAction qemu_co_rwlock_unlock(CoRwlock *lock)
+{
+ return CO_INIT_FRAME(qemu_co_rwlock_unlock, lock);
+}
+
+#if 0
void qemu_co_rwlock_downgrade(CoRwlock *lock)
{
qemu_co_mutex_lock(&lock->mutex);
--
2.35.1
- [PATCH 06/35] disable some code, (continued)
- [PATCH 06/35] disable some code, Paolo Bonzini, 2022/03/10
- [PATCH 15/35] /basic/self, Paolo Bonzini, 2022/03/10
- [PATCH 03/35] coroutine: introduce QemuCoLockable, Paolo Bonzini, 2022/03/10
- [PATCH 18/35] /basic/order, Paolo Bonzini, 2022/03/10
- [PATCH 21/35] /perf/yield, Paolo Bonzini, 2022/03/10
- [PATCH 08/35] /basic/lifecycle, Paolo Bonzini, 2022/03/10
- [PATCH 10/35] enable tail call optimization of qemu_co_mutex_lock, Paolo Bonzini, 2022/03/10
- [PATCH 12/35] define magic macros for stackless coroutines, Paolo Bonzini, 2022/03/10
- [PATCH 27/35] /locking/co-mutex/lockable, Paolo Bonzini, 2022/03/10
- [PATCH 16/35] /basic/entered, Paolo Bonzini, 2022/03/10
- [PATCH 30/35] qemu_co_rwlock_unlock,
Paolo Bonzini <=
- [PATCH 32/35] qemu_co_rwlock_wrlock, Paolo Bonzini, 2022/03/10
- [PATCH 13/35] /basic/yield, Paolo Bonzini, 2022/03/10
- [PATCH 14/35] /basic/nesting, Paolo Bonzini, 2022/03/10
- [PATCH 19/35] /perf/lifecycle, Paolo Bonzini, 2022/03/10
- [PATCH 20/35] /perf/nesting, Paolo Bonzini, 2022/03/10
- [PATCH 25/35] /locking/co-mutex, Paolo Bonzini, 2022/03/10
- [PATCH 26/35] convert qemu_co_mutex_lock_slowpath to magic macros, Paolo Bonzini, 2022/03/10
- [PATCH 29/35] qemu_co_rwlock_rdlock, Paolo Bonzini, 2022/03/10
- [PATCH 17/35] /basic/in_coroutine, Paolo Bonzini, 2022/03/10
- [PATCH 11/35] convert CoMutex to stackless coroutines, Paolo Bonzini, 2022/03/10