summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPavel Dovgalyuk2019-09-17 13:58:13 +0200
committerKevin Wolf2019-10-14 17:12:48 +0200
commitae25dccb7df64ec9cbb52d7a0a67308d74372cfd (patch)
treeb826d3b161145d655a625e78d5f38e91579fc526
parentreplay: don't drain/flush bdrv queue while RR is working (diff)
downloadqemu-ae25dccb7df64ec9cbb52d7a0a67308d74372cfd.tar.gz
qemu-ae25dccb7df64ec9cbb52d7a0a67308d74372cfd.tar.xz
qemu-ae25dccb7df64ec9cbb52d7a0a67308d74372cfd.zip
replay: finish record/replay before closing the disks
After recent updates block devices cannot be closed on qemu exit. This happens due to the block request polling when replay is not finished. Therefore now we stop execution recording before closing the block devices. Signed-off-by: Pavel Dovgalyuk <pavel.dovgaluk@ispras.ru> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
-rw-r--r--replay/replay.c2
-rw-r--r--vl.c1
2 files changed, 3 insertions, 0 deletions
diff --git a/replay/replay.c b/replay/replay.c
index 713395b33d..5cc25bd2f8 100644
--- a/replay/replay.c
+++ b/replay/replay.c
@@ -385,6 +385,8 @@ void replay_finish(void)
g_free(replay_snapshot);
replay_snapshot = NULL;
+ replay_mode = REPLAY_MODE_NONE;
+
replay_finish_events();
}
diff --git a/vl.c b/vl.c
index fce9ce2364..57d4fd726f 100644
--- a/vl.c
+++ b/vl.c
@@ -4524,6 +4524,7 @@ int main(int argc, char **argv, char **envp)
/* No more vcpu or device emulation activity beyond this point */
vm_shutdown();
+ replay_finish();
job_cancel_sync_all();
bdrv_close_all();