mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-31 18:15:25 +00:00
qemu: Introduce qemuDomainDefCheckABIStability
https://bugzilla.redhat.com/show_bug.cgi?id=994364 Whenever we check for ABI stability, we have new xml (e.g. provided by user, or obtained from snapshot, whatever) which we compare to old xml and see if ABI won't break. However, if the new xml was produced via virDomainGetXMLDesc(..., VIR_DOMAIN_XML_MIGRATABLE) it lacks some devices, e.g. 'pci-root' controller. Hence, the ABI stability check fails even though it is stable. Moreover, we can't simply fix virDomainDefCheckABIStability because removing the correct devices is task for the driver. For instance, qemu driver wants to remove the usb controller too, while LXC driver doesn't. That's why we need special qemu wrapper over virDomainDefCheckABIStability which removes the correct devices from domain XML, produces MIGRATABLE xml and calls the check ABI stability function. Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
c643b64e30
commit
7d704812b9
@ -2342,3 +2342,25 @@ qemuDomainUpdateDeviceList(virQEMUDriverPtr driver,
|
|||||||
priv->qemuDevices = aliases;
|
priv->qemuDevices = aliases;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
qemuDomainDefCheckABIStability(virQEMUDriverPtr driver,
|
||||||
|
virDomainDefPtr src,
|
||||||
|
virDomainDefPtr dst)
|
||||||
|
{
|
||||||
|
virDomainDefPtr migratableDefSrc = NULL;
|
||||||
|
virDomainDefPtr migratableDefDst = NULL;
|
||||||
|
const int flags = VIR_DOMAIN_XML_SECURE | VIR_DOMAIN_XML_UPDATE_CPU | VIR_DOMAIN_XML_MIGRATABLE;
|
||||||
|
bool ret = false;
|
||||||
|
|
||||||
|
if (!(migratableDefSrc = qemuDomainDefCopy(driver, src, flags)) ||
|
||||||
|
!(migratableDefDst = qemuDomainDefCopy(driver, dst, flags)))
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
ret = virDomainDefCheckABIStability(migratableDefSrc, migratableDefDst);
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
virDomainDefFree(migratableDefSrc);
|
||||||
|
virDomainDefFree(migratableDefDst);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
@ -368,4 +368,7 @@ extern virDomainDefParserConfig virQEMUDriverDomainDefParserConfig;
|
|||||||
int qemuDomainUpdateDeviceList(virQEMUDriverPtr driver,
|
int qemuDomainUpdateDeviceList(virQEMUDriverPtr driver,
|
||||||
virDomainObjPtr vm);
|
virDomainObjPtr vm);
|
||||||
|
|
||||||
|
bool qemuDomainDefCheckABIStability(virQEMUDriverPtr driver,
|
||||||
|
virDomainDefPtr src,
|
||||||
|
virDomainDefPtr dst);
|
||||||
#endif /* __QEMU_DOMAIN_H__ */
|
#endif /* __QEMU_DOMAIN_H__ */
|
||||||
|
@ -3077,7 +3077,7 @@ qemuDomainSaveInternal(virQEMUDriverPtr driver, virDomainPtr dom,
|
|||||||
VIR_DOMAIN_XML_INACTIVE))) {
|
VIR_DOMAIN_XML_INACTIVE))) {
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
if (!virDomainDefCheckABIStability(vm->def, def)) {
|
if (!qemuDomainDefCheckABIStability(driver, vm->def, def)) {
|
||||||
virDomainDefFree(def);
|
virDomainDefFree(def);
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
@ -12887,7 +12887,6 @@ static int qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
qemuDomainObjPrivatePtr priv;
|
qemuDomainObjPrivatePtr priv;
|
||||||
int rc;
|
int rc;
|
||||||
virDomainDefPtr config = NULL;
|
virDomainDefPtr config = NULL;
|
||||||
virDomainDefPtr migratableDef = NULL;
|
|
||||||
virQEMUDriverConfigPtr cfg = NULL;
|
virQEMUDriverConfigPtr cfg = NULL;
|
||||||
virCapsPtr caps = NULL;
|
virCapsPtr caps = NULL;
|
||||||
|
|
||||||
@ -13004,11 +13003,7 @@ static int qemuDomainRevertToSnapshot(virDomainSnapshotPtr snapshot,
|
|||||||
/* Transitions 5, 6, 8, 9 */
|
/* Transitions 5, 6, 8, 9 */
|
||||||
/* Check for ABI compatibility. We need to do this check against
|
/* Check for ABI compatibility. We need to do this check against
|
||||||
* the migratable XML or it will always fail otherwise */
|
* the migratable XML or it will always fail otherwise */
|
||||||
if (!(migratableDef = qemuDomainDefCopy(driver, vm->def,
|
if (config && !qemuDomainDefCheckABIStability(driver, vm->def, config)) {
|
||||||
VIR_DOMAIN_XML_MIGRATABLE)))
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
if (config && !virDomainDefCheckABIStability(migratableDef, config)) {
|
|
||||||
virErrorPtr err = virGetLastError();
|
virErrorPtr err = virGetLastError();
|
||||||
|
|
||||||
if (!(flags & VIR_DOMAIN_SNAPSHOT_REVERT_FORCE)) {
|
if (!(flags & VIR_DOMAIN_SNAPSHOT_REVERT_FORCE)) {
|
||||||
@ -13213,7 +13208,6 @@ cleanup:
|
|||||||
}
|
}
|
||||||
if (vm)
|
if (vm)
|
||||||
virObjectUnlock(vm);
|
virObjectUnlock(vm);
|
||||||
virDomainDefFree(migratableDef);
|
|
||||||
virObjectUnref(caps);
|
virObjectUnref(caps);
|
||||||
virObjectUnref(cfg);
|
virObjectUnref(cfg);
|
||||||
|
|
||||||
|
@ -2039,7 +2039,7 @@ static char
|
|||||||
VIR_DOMAIN_XML_INACTIVE)))
|
VIR_DOMAIN_XML_INACTIVE)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!virDomainDefCheckABIStability(vm->def, def))
|
if (!qemuDomainDefCheckABIStability(driver, vm->def, def))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
rv = qemuDomainDefFormatLive(driver, def, false, true);
|
rv = qemuDomainDefFormatLive(driver, def, false, true);
|
||||||
@ -2242,7 +2242,7 @@ qemuMigrationPrepareAny(virQEMUDriverPtr driver,
|
|||||||
if (!newdef)
|
if (!newdef)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!virDomainDefCheckABIStability(*def, newdef)) {
|
if (!qemuDomainDefCheckABIStability(driver, *def, newdef)) {
|
||||||
virDomainDefFree(newdef);
|
virDomainDefFree(newdef);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user