|
|
9bac43 |
From 9e1beaad709ba68a82a54738ad7b50cac69861cc Mon Sep 17 00:00:00 2001
|
|
|
9bac43 |
From: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
9bac43 |
Date: Fri, 17 Nov 2017 11:19:04 +0100
|
|
|
9bac43 |
Subject: [PATCH 05/15] throttle-groups: drain before detaching ThrottleState
|
|
|
9bac43 |
|
|
|
9bac43 |
RH-Author: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
9bac43 |
Message-id: <20171117111908.8815-6-stefanha@redhat.com>
|
|
|
9bac43 |
Patchwork-id: 77740
|
|
|
9bac43 |
O-Subject: [RHV7.5 qemu-kvm-rhev PATCH 5/9] throttle-groups: drain before detaching ThrottleState
|
|
|
9bac43 |
Bugzilla: 1492295
|
|
|
9bac43 |
RH-Acked-by: John Snow <jsnow@redhat.com>
|
|
|
9bac43 |
RH-Acked-by: Laurent Vivier <lvivier@redhat.com>
|
|
|
9bac43 |
RH-Acked-by: Thomas Huth <thuth@redhat.com>
|
|
|
9bac43 |
|
|
|
9bac43 |
I/O requests hang after stop/cont commands at least since QEMU 2.10.0
|
|
|
9bac43 |
with -drive iops=100:
|
|
|
9bac43 |
|
|
|
9bac43 |
(guest)$ dd if=/dev/zero of=/dev/vdb oflag=direct count=1000
|
|
|
9bac43 |
(qemu) stop
|
|
|
9bac43 |
(qemu) cont
|
|
|
9bac43 |
...I/O is stuck...
|
|
|
9bac43 |
|
|
|
9bac43 |
This happens because blk_set_aio_context() detaches the ThrottleState
|
|
|
9bac43 |
while requests may still be in flight:
|
|
|
9bac43 |
|
|
|
9bac43 |
if (tgm->throttle_state) {
|
|
|
9bac43 |
throttle_group_detach_aio_context(tgm);
|
|
|
9bac43 |
throttle_group_attach_aio_context(tgm, new_context);
|
|
|
9bac43 |
}
|
|
|
9bac43 |
|
|
|
9bac43 |
This patch encloses the detach/attach calls in a drained region so no
|
|
|
9bac43 |
I/O request is left hanging. Also add assertions so we don't make the
|
|
|
9bac43 |
same mistake again in the future.
|
|
|
9bac43 |
|
|
|
9bac43 |
Reported-by: Yongxue Hong <yhong@redhat.com>
|
|
|
9bac43 |
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
9bac43 |
Reviewed-by: Alberto Garcia <berto@igalia.com>
|
|
|
9bac43 |
Message-id: 20171110151934.16883-1-stefanha@redhat.com
|
|
|
9bac43 |
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
9bac43 |
(cherry picked from commit dc868fb03b9b829ed9d2ecdae0fcc12f3fe19b4f)
|
|
|
9bac43 |
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
9bac43 |
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
9bac43 |
---
|
|
|
9bac43 |
block/block-backend.c | 2 ++
|
|
|
9bac43 |
block/throttle-groups.c | 6 ++++++
|
|
|
9bac43 |
2 files changed, 8 insertions(+)
|
|
|
9bac43 |
|
|
|
9bac43 |
diff --git a/block/block-backend.c b/block/block-backend.c
|
|
|
9bac43 |
index bfb3e84..520f2b2 100644
|
|
|
9bac43 |
--- a/block/block-backend.c
|
|
|
9bac43 |
+++ b/block/block-backend.c
|
|
|
9bac43 |
@@ -1771,8 +1771,10 @@ void blk_set_aio_context(BlockBackend *blk, AioContext *new_context)
|
|
|
9bac43 |
|
|
|
9bac43 |
if (bs) {
|
|
|
9bac43 |
if (tgm->throttle_state) {
|
|
|
9bac43 |
+ bdrv_drained_begin(bs);
|
|
|
9bac43 |
throttle_group_detach_aio_context(tgm);
|
|
|
9bac43 |
throttle_group_attach_aio_context(tgm, new_context);
|
|
|
9bac43 |
+ bdrv_drained_end(bs);
|
|
|
9bac43 |
}
|
|
|
9bac43 |
bdrv_set_aio_context(bs, new_context);
|
|
|
9bac43 |
}
|
|
|
9bac43 |
diff --git a/block/throttle-groups.c b/block/throttle-groups.c
|
|
|
9bac43 |
index 7749cf0..44cc1e6 100644
|
|
|
9bac43 |
--- a/block/throttle-groups.c
|
|
|
9bac43 |
+++ b/block/throttle-groups.c
|
|
|
9bac43 |
@@ -568,6 +568,12 @@ void throttle_group_attach_aio_context(ThrottleGroupMember *tgm,
|
|
|
9bac43 |
void throttle_group_detach_aio_context(ThrottleGroupMember *tgm)
|
|
|
9bac43 |
{
|
|
|
9bac43 |
ThrottleTimers *tt = &tgm->throttle_timers;
|
|
|
9bac43 |
+
|
|
|
9bac43 |
+ /* Requests must have been drained */
|
|
|
9bac43 |
+ assert(tgm->pending_reqs[0] == 0 && tgm->pending_reqs[1] == 0);
|
|
|
9bac43 |
+ assert(qemu_co_queue_empty(&tgm->throttled_reqs[0]));
|
|
|
9bac43 |
+ assert(qemu_co_queue_empty(&tgm->throttled_reqs[1]));
|
|
|
9bac43 |
+
|
|
|
9bac43 |
throttle_timers_detach_aio_context(tt);
|
|
|
9bac43 |
tgm->aio_context = NULL;
|
|
|
9bac43 |
}
|
|
|
9bac43 |
--
|
|
|
9bac43 |
1.8.3.1
|
|
|
9bac43 |
|