mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 04:25:18 +00:00
lxcDomainDetachDeviceFlags: Parse XML twice rather than use virDomainDeviceDefCopy
'virDomainDeviceDefCopy' formats the definition and parses it back. Since we already are parsing the XML here, we're better off parsing it twice and save the formatting step. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
904d80b773
commit
5b09af96f9
@ -4416,8 +4416,10 @@ static int lxcDomainDetachDeviceFlags(virDomainPtr dom,
|
|||||||
g_autoptr(virCaps) caps = NULL;
|
g_autoptr(virCaps) caps = NULL;
|
||||||
virDomainObj *vm = NULL;
|
virDomainObj *vm = NULL;
|
||||||
g_autoptr(virDomainDef) vmdef = NULL;
|
g_autoptr(virDomainDef) vmdef = NULL;
|
||||||
virDomainDeviceDef *dev = NULL;
|
g_autoptr(virDomainDeviceDef) dev_config = NULL;
|
||||||
virDomainDeviceDef *dev_copy = NULL;
|
g_autoptr(virDomainDeviceDef) dev_live = NULL;
|
||||||
|
unsigned int parse_flags = VIR_DOMAIN_DEF_PARSE_SKIP_VALIDATE |
|
||||||
|
VIR_DOMAIN_DEF_PARSE_INACTIVE;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
g_autoptr(virLXCDriverConfig) cfg = virLXCDriverGetConfig(driver);
|
g_autoptr(virLXCDriverConfig) cfg = virLXCDriverGetConfig(driver);
|
||||||
|
|
||||||
@ -4439,22 +4441,15 @@ static int lxcDomainDetachDeviceFlags(virDomainPtr dom,
|
|||||||
if (!(caps = virLXCDriverGetCapabilities(driver, false)))
|
if (!(caps = virLXCDriverGetCapabilities(driver, false)))
|
||||||
goto endjob;
|
goto endjob;
|
||||||
|
|
||||||
dev = dev_copy = virDomainDeviceDefParse(xml, vm->def,
|
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
|
||||||
driver->xmlopt, NULL,
|
if (!(dev_config = virDomainDeviceDefParse(xml, vm->def, driver->xmlopt,
|
||||||
VIR_DOMAIN_DEF_PARSE_INACTIVE |
|
NULL, parse_flags)))
|
||||||
VIR_DOMAIN_DEF_PARSE_SKIP_VALIDATE);
|
goto endjob;
|
||||||
if (dev == NULL)
|
}
|
||||||
goto endjob;
|
|
||||||
|
|
||||||
if (flags & VIR_DOMAIN_AFFECT_CONFIG &&
|
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
||||||
flags & VIR_DOMAIN_AFFECT_LIVE) {
|
if (!(dev_live = virDomainDeviceDefParse(xml, vm->def, driver->xmlopt,
|
||||||
/* If we are affecting both CONFIG and LIVE
|
NULL, parse_flags)))
|
||||||
* create a deep copy of device as adding
|
|
||||||
* to CONFIG takes one instance.
|
|
||||||
*/
|
|
||||||
dev_copy = virDomainDeviceDefCopy(dev, vm->def,
|
|
||||||
driver->xmlopt, NULL);
|
|
||||||
if (!dev_copy)
|
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4464,12 +4459,12 @@ static int lxcDomainDetachDeviceFlags(virDomainPtr dom,
|
|||||||
if (!vmdef)
|
if (!vmdef)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
|
|
||||||
if ((ret = lxcDomainDetachDeviceConfig(vmdef, dev_copy)) < 0)
|
if ((ret = lxcDomainDetachDeviceConfig(vmdef, dev_config)) < 0)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
||||||
if ((ret = lxcDomainDetachDeviceLive(driver, vm, dev)) < 0)
|
if ((ret = lxcDomainDetachDeviceLive(driver, vm, dev_live)) < 0)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
/*
|
/*
|
||||||
* update domain status forcibly because the domain status may be
|
* update domain status forcibly because the domain status may be
|
||||||
@ -4493,9 +4488,6 @@ static int lxcDomainDetachDeviceFlags(virDomainPtr dom,
|
|||||||
virDomainObjEndJob(vm);
|
virDomainObjEndJob(vm);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if (dev != dev_copy)
|
|
||||||
virDomainDeviceDefFree(dev_copy);
|
|
||||||
virDomainDeviceDefFree(dev);
|
|
||||||
virDomainObjEndAPI(&vm);
|
virDomainObjEndAPI(&vm);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user