aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>2022-03-03 20:43:42 +0100
committerHanna Reitz <hreitz@redhat.com>2022-03-07 09:33:30 +0100
commit3b7ca26bdf1eb1f9703048831d442adbb103069b (patch)
tree8c50aa395aad244b5928888dcbea622a31aa9e93
parenta6426475a75fb793d4c9dd9fe94815e8d18ddaa1 (diff)
downloadqemu-3b7ca26bdf1eb1f9703048831d442adbb103069b.zip
qemu-3b7ca26bdf1eb1f9703048831d442adbb103069b.tar.gz
qemu-3b7ca26bdf1eb1f9703048831d442adbb103069b.tar.bz2
block/reqlist: add reqlist_wait_all()
Add function to wait for all intersecting requests. To be used in the further commit. Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> Reviewed-by: Nikita Lapshin <nikita.lapshin@virtuozzo.com> Reviewed-by: Hanna Reitz <hreitz@redhat.com> Message-Id: <20220303194349.2304213-10-vsementsov@virtuozzo.com> Signed-off-by: Hanna Reitz <hreitz@redhat.com>
-rw-r--r--block/reqlist.c8
-rw-r--r--include/block/reqlist.h8
2 files changed, 16 insertions, 0 deletions
diff --git a/block/reqlist.c b/block/reqlist.c
index 09fecbd..08cb57c 100644
--- a/block/reqlist.c
+++ b/block/reqlist.c
@@ -58,6 +58,14 @@ bool coroutine_fn reqlist_wait_one(BlockReqList *reqs, int64_t offset,
return true;
}
+void coroutine_fn reqlist_wait_all(BlockReqList *reqs, int64_t offset,
+ int64_t bytes, CoMutex *lock)
+{
+ while (reqlist_wait_one(reqs, offset, bytes, lock)) {
+ /* continue */
+ }
+}
+
void coroutine_fn reqlist_shrink_req(BlockReq *req, int64_t new_bytes)
{
if (new_bytes == req->bytes) {
diff --git a/include/block/reqlist.h b/include/block/reqlist.h
index 0fa1eef..5253497 100644
--- a/include/block/reqlist.h
+++ b/include/block/reqlist.h
@@ -54,6 +54,14 @@ bool coroutine_fn reqlist_wait_one(BlockReqList *reqs, int64_t offset,
int64_t bytes, CoMutex *lock);
/*
+ * Wait for all intersecting requests. It just calls reqlist_wait_one() in a
+ * loop, caller is responsible to stop producing new requests in this region
+ * in parallel, otherwise reqlist_wait_all() may never return.
+ */
+void coroutine_fn reqlist_wait_all(BlockReqList *reqs, int64_t offset,
+ int64_t bytes, CoMutex *lock);
+
+/*
* Shrink request and wake all waiting coroutines (maybe some of them are not
* intersecting with shrunk request).
*/