mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-12 07:42:56 +00:00
qemuDomainBlockCommit: Move checks depending on capabilities after liveness check
Since capabilities are not present for inactive VMs we'd report that we don't support '--delete' or committing while checkpoints exist rather than the proper error. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
parent
0ce8b0fbe2
commit
d4b5bb5d56
@ -18413,9 +18413,6 @@ qemuDomainBlockCommit(virDomainPtr dom,
|
|||||||
if (virDomainBlockCommitEnsureACL(dom->conn, vm->def) < 0)
|
if (virDomainBlockCommitEnsureACL(dom->conn, vm->def) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuDomainSupportsCheckpointsBlockjobs(vm) < 0)
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_MODIFY) < 0)
|
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_MODIFY) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -18424,12 +18421,6 @@ qemuDomainBlockCommit(virDomainPtr dom,
|
|||||||
|
|
||||||
blockdev = virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BLOCKDEV);
|
blockdev = virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BLOCKDEV);
|
||||||
|
|
||||||
if (!blockdev && (flags & VIR_DOMAIN_BLOCK_COMMIT_DELETE)) {
|
|
||||||
virReportError(VIR_ERR_OPERATION_UNSUPPORTED, "%s",
|
|
||||||
_("deleting committed images is not supported by this VM"));
|
|
||||||
goto endjob;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Convert bandwidth MiB to bytes, if necessary */
|
/* Convert bandwidth MiB to bytes, if necessary */
|
||||||
if (!(flags & VIR_DOMAIN_BLOCK_COMMIT_BANDWIDTH_BYTES)) {
|
if (!(flags & VIR_DOMAIN_BLOCK_COMMIT_BANDWIDTH_BYTES)) {
|
||||||
if (speed > LLONG_MAX >> 20) {
|
if (speed > LLONG_MAX >> 20) {
|
||||||
@ -18454,6 +18445,15 @@ qemuDomainBlockCommit(virDomainPtr dom,
|
|||||||
if (qemuDomainDiskBlockJobIsActive(disk))
|
if (qemuDomainDiskBlockJobIsActive(disk))
|
||||||
goto endjob;
|
goto endjob;
|
||||||
|
|
||||||
|
if (qemuDomainSupportsCheckpointsBlockjobs(vm) < 0)
|
||||||
|
goto endjob;
|
||||||
|
|
||||||
|
if (!blockdev && (flags & VIR_DOMAIN_BLOCK_COMMIT_DELETE)) {
|
||||||
|
virReportError(VIR_ERR_OPERATION_UNSUPPORTED, "%s",
|
||||||
|
_("deleting committed images is not supported by this VM"));
|
||||||
|
goto endjob;
|
||||||
|
}
|
||||||
|
|
||||||
if (!top || STREQ(top, disk->dst))
|
if (!top || STREQ(top, disk->dst))
|
||||||
topSource = disk->src;
|
topSource = disk->src;
|
||||||
else if (virStorageFileParseChainIndex(disk->dst, top, &topIndex) < 0 ||
|
else if (virStorageFileParseChainIndex(disk->dst, top, &topIndex) < 0 ||
|
||||||
|
Loading…
x
Reference in New Issue
Block a user