2018-02-19 12:38:54 +03:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2017-04-05 11:49:19 +03:00
|
|
|
From: Alexandre Derumier <aderumier@odiso.com>
|
|
|
|
Date: Mon, 7 Nov 2016 11:47:50 +0100
|
2018-08-30 16:00:07 +03:00
|
|
|
Subject: [PATCH] PVE: block: snapshot: qmp_delete_drive_snapshot : add
|
|
|
|
aiocontext
|
2017-04-05 11:49:19 +03:00
|
|
|
|
|
|
|
this fix snapshot delete of qcow2 with iothread enabled
|
|
|
|
|
|
|
|
Signed-off-by: Alexandre Derumier <aderumier@odiso.com>
|
|
|
|
---
|
|
|
|
savevm-async.c | 13 ++++++++++---
|
|
|
|
1 file changed, 10 insertions(+), 3 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/savevm-async.c b/savevm-async.c
|
2018-08-30 16:00:07 +03:00
|
|
|
index 87d5460a26..aa578c4a49 100644
|
2017-04-05 11:49:19 +03:00
|
|
|
--- a/savevm-async.c
|
|
|
|
+++ b/savevm-async.c
|
2018-08-30 16:00:07 +03:00
|
|
|
@@ -461,6 +461,7 @@ void qmp_delete_drive_snapshot(const char *device, const char *name,
|
2017-04-05 11:49:19 +03:00
|
|
|
BlockDriverState *bs;
|
|
|
|
QEMUSnapshotInfo sn1, *sn = &sn1;
|
|
|
|
Error *local_err = NULL;
|
|
|
|
+ AioContext *aio_context;
|
|
|
|
|
|
|
|
int ret;
|
|
|
|
|
2018-08-30 16:00:07 +03:00
|
|
|
@@ -477,22 +478,28 @@ void qmp_delete_drive_snapshot(const char *device, const char *name,
|
2017-04-05 11:49:19 +03:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ aio_context = bdrv_get_aio_context(bs);
|
|
|
|
+ aio_context_acquire(aio_context);
|
|
|
|
+
|
|
|
|
if (!bdrv_can_snapshot(bs)) {
|
|
|
|
error_setg(errp, QERR_UNSUPPORTED);
|
|
|
|
- return;
|
|
|
|
+ goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bdrv_snapshot_find(bs, sn, name) < 0) {
|
|
|
|
/* return success if snapshot does not exists */
|
|
|
|
- return;
|
|
|
|
+ goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
ret = bdrv_snapshot_delete(bs, NULL, name, &local_err);
|
|
|
|
if (ret < 0) {
|
|
|
|
error_set(errp, ERROR_CLASS_GENERIC_ERROR,
|
|
|
|
"Error while deleting snapshot on '%s'\n", device);
|
|
|
|
- return;
|
|
|
|
+ goto out;
|
|
|
|
}
|
|
|
|
+
|
|
|
|
+out:
|
|
|
|
+ aio_context_release(aio_context);
|
|
|
|
}
|
|
|
|
|
|
|
|
static ssize_t loadstate_get_buffer(void *opaque, uint8_t *buf, int64_t pos,
|
|
|
|
--
|
2017-04-05 12:51:17 +03:00
|
|
|
2.11.0
|
2017-04-05 11:49:19 +03:00
|
|
|
|