mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 07:17:44 +00:00
qemu: Don't leak domain def when RevertToSnapshot fails
Once we copy the domain definition from virDomainSnapshotDef, we either need to assign it to the domain object or free it to avoid memory leaks. Signed-off-by: Jiri Denemark <jdenemar@redhat.com> Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
This commit is contained in:
parent
4933445a18
commit
33c05f8b44
@ -16568,6 +16568,7 @@ qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
virCPUDefPtr origCPU = NULL;
|
virCPUDefPtr origCPU = NULL;
|
||||||
unsigned int start_flags = VIR_QEMU_PROCESS_START_GEN_VMID;
|
unsigned int start_flags = VIR_QEMU_PROCESS_START_GEN_VMID;
|
||||||
qemuDomainAsyncJob jobType = QEMU_ASYNC_JOB_START;
|
qemuDomainAsyncJob jobType = QEMU_ASYNC_JOB_START;
|
||||||
|
bool defined = false;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_SNAPSHOT_REVERT_RUNNING |
|
virCheckFlags(VIR_DOMAIN_SNAPSHOT_REVERT_RUNNING |
|
||||||
VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED |
|
VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED |
|
||||||
@ -16779,6 +16780,8 @@ qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
virDomainObjAssignDef(vm, config, false, NULL);
|
virDomainObjAssignDef(vm, config, false, NULL);
|
||||||
virCPUDefFree(priv->origCPU);
|
virCPUDefFree(priv->origCPU);
|
||||||
VIR_STEAL_PTR(priv->origCPU, origCPU);
|
VIR_STEAL_PTR(priv->origCPU, origCPU);
|
||||||
|
config = NULL;
|
||||||
|
defined = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cookie && !cookie->slirpHelper)
|
if (cookie && !cookie->slirpHelper)
|
||||||
@ -16788,8 +16791,11 @@ qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
/* Transitions 2, 3 */
|
/* Transitions 2, 3 */
|
||||||
load:
|
load:
|
||||||
was_stopped = true;
|
was_stopped = true;
|
||||||
if (config)
|
if (config) {
|
||||||
virDomainObjAssignDef(vm, config, false, NULL);
|
virDomainObjAssignDef(vm, config, false, NULL);
|
||||||
|
config = NULL;
|
||||||
|
defined = true;
|
||||||
|
}
|
||||||
|
|
||||||
/* No cookie means libvirt which saved the domain was too old to
|
/* No cookie means libvirt which saved the domain was too old to
|
||||||
* mess up the CPU definitions.
|
* mess up the CPU definitions.
|
||||||
@ -16875,8 +16881,11 @@ qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
qemuProcessEndJob(driver, vm);
|
qemuProcessEndJob(driver, vm);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
if (config)
|
if (config) {
|
||||||
virDomainObjAssignDef(vm, config, false, NULL);
|
virDomainObjAssignDef(vm, config, false, NULL);
|
||||||
|
config = NULL;
|
||||||
|
defined = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (flags & (VIR_DOMAIN_SNAPSHOT_REVERT_RUNNING |
|
if (flags & (VIR_DOMAIN_SNAPSHOT_REVERT_RUNNING |
|
||||||
VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED)) {
|
VIR_DOMAIN_SNAPSHOT_REVERT_PAUSED)) {
|
||||||
@ -16942,7 +16951,7 @@ qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ret == 0 && config && vm->persistent &&
|
if (ret == 0 && defined && vm->persistent &&
|
||||||
!(ret = virDomainSaveConfig(cfg->configDir, driver->caps,
|
!(ret = virDomainSaveConfig(cfg->configDir, driver->caps,
|
||||||
vm->newDef ? vm->newDef : vm->def))) {
|
vm->newDef ? vm->newDef : vm->def))) {
|
||||||
detail = VIR_DOMAIN_EVENT_DEFINED_FROM_SNAPSHOT;
|
detail = VIR_DOMAIN_EVENT_DEFINED_FROM_SNAPSHOT;
|
||||||
@ -16958,6 +16967,7 @@ qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
virObjectUnref(cfg);
|
virObjectUnref(cfg);
|
||||||
virNWFilterUnlockFilterUpdates();
|
virNWFilterUnlockFilterUpdates();
|
||||||
virCPUDefFree(origCPU);
|
virCPUDefFree(origCPU);
|
||||||
|
virDomainDefFree(config);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user