[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 4/5] qht: convert to use lock guards
From: |
Paolo Bonzini |
Subject: |
[Qemu-devel] [PATCH 4/5] qht: convert to use lock guards |
Date: |
Fri, 8 Dec 2017 11:55:52 +0100 |
Signed-off-by: Paolo Bonzini <address@hidden>
---
util/qht.c | 59 +++++++++++++++++++++++++++++------------------------------
1 file changed, 29 insertions(+), 30 deletions(-)
diff --git a/util/qht.c b/util/qht.c
index ff4d2e6974..95ac32f990 100644
--- a/util/qht.c
+++ b/util/qht.c
@@ -248,18 +248,18 @@ void qht_map_lock_buckets__no_stale(struct qht *ht,
struct qht_map **pmap)
map = atomic_rcu_read(&ht->map);
qht_map_lock_buckets(map);
if (likely(!qht_map_is_stale__locked(ht, map))) {
- *pmap = map;
- return;
+ goto out;
}
qht_map_unlock_buckets(map);
/* we raced with a resize; acquire ht->lock to see the updated ht->map */
- qemu_mutex_lock(&ht->lock);
- map = ht->map;
- qht_map_lock_buckets(map);
- qemu_mutex_unlock(&ht->lock);
+ QEMU_WITH_LOCK(QemuMutex, ht_guard, &ht->lock) {
+ map = ht->map;
+ qht_map_lock_buckets(map);
+ }
+
+out:
*pmap = map;
- return;
}
/*
@@ -282,17 +282,18 @@ struct qht_bucket *qht_bucket_lock__no_stale(struct qht
*ht, uint32_t hash,
qemu_spin_lock(&b->lock);
if (likely(!qht_map_is_stale__locked(ht, map))) {
- *pmap = map;
- return b;
+ goto out;
}
qemu_spin_unlock(&b->lock);
/* we raced with a resize; acquire ht->lock to see the updated ht->map */
- qemu_mutex_lock(&ht->lock);
- map = ht->map;
- b = qht_map_to_bucket(map, hash);
- qemu_spin_lock(&b->lock);
- qemu_mutex_unlock(&ht->lock);
+ QEMU_WITH_LOCK(QemuMutex, ht_guard, &ht->lock) {
+ map = ht->map;
+ b = qht_map_to_bucket(map, hash);
+ qemu_spin_lock(&b->lock);
+ }
+
+out:
*pmap = map;
return b;
}
@@ -427,13 +428,13 @@ bool qht_reset_size(struct qht *ht, size_t n_elems)
n_buckets = qht_elems_to_buckets(n_elems);
- qemu_mutex_lock(&ht->lock);
- map = ht->map;
- if (n_buckets != map->n_buckets) {
- new = qht_map_create(n_buckets);
+ QEMU_WITH_LOCK(QemuMutex, ht_guard, &ht->lock) {
+ map = ht->map;
+ if (n_buckets != map->n_buckets) {
+ new = qht_map_create(n_buckets);
+ }
+ qht_do_resize_and_reset(ht, new);
}
- qht_do_resize_and_reset(ht, new);
- qemu_mutex_unlock(&ht->lock);
return !!new;
}
@@ -771,19 +772,17 @@ static void qht_do_resize_reset(struct qht *ht, struct
qht_map *new, bool reset)
bool qht_resize(struct qht *ht, size_t n_elems)
{
size_t n_buckets = qht_elems_to_buckets(n_elems);
- size_t ret = false;
- qemu_mutex_lock(&ht->lock);
- if (n_buckets != ht->map->n_buckets) {
- struct qht_map *new;
+ QEMU_WITH_LOCK(QemuMutex, ht_guard, &ht->lock) {
+ if (n_buckets != ht->map->n_buckets) {
+ struct qht_map *new;
- new = qht_map_create(n_buckets);
- qht_do_resize(ht, new);
- ret = true;
+ new = qht_map_create(n_buckets);
+ qht_do_resize(ht, new);
+ return true;
+ }
}
- qemu_mutex_unlock(&ht->lock);
-
- return ret;
+ return false;
}
/* pass @stats to qht_statistics_destroy() when done */
--
2.14.3
[Qemu-devel] [PATCH 3/5] qemu-timer: convert to use lock guards, Paolo Bonzini, 2017/12/08
[Qemu-devel] [PATCH 4/5] qht: convert to use lock guards,
Paolo Bonzini <=
[Qemu-devel] [PATCH 5/5] thread-pool: convert to use lock guards, Paolo Bonzini, 2017/12/08
Re: [Qemu-devel] [PATCH 5/5] thread-pool: convert to use lock guards, Eric Blake, 2017/12/08
Re: [Qemu-devel] [PATCH 5/5] thread-pool: convert to use lock guards, Peter Xu, 2017/12/11
Re: [Qemu-devel] [RFC PATCH 0/5] Scoped locks using attribute((cleanup)), Eric Blake, 2017/12/08