mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-12 07:42:56 +00:00
qemu: Move exit monitor calls in failure paths
Since qemuDomainObjExitMonitor can also generate error messages, let's move it inside any error message saving code on error paths for various hotplug add activities. Signed-off-by: John Ferlan <jferlan@redhat.com>
This commit is contained in:
parent
7c2b7891cc
commit
e49af42c22
@ -442,13 +442,13 @@ qemuDomainAttachVirtioDiskDevice(virConnectPtr conn,
|
|||||||
ignore_value(qemuMonitorDelObject(priv->mon, secinfo->s.aes.alias));
|
ignore_value(qemuMonitorDelObject(priv->mon, secinfo->s.aes.alias));
|
||||||
if (encobjAdded)
|
if (encobjAdded)
|
||||||
ignore_value(qemuMonitorDelObject(priv->mon, encinfo->s.aes.alias));
|
ignore_value(qemuMonitorDelObject(priv->mon, encinfo->s.aes.alias));
|
||||||
|
if (qemuDomainObjExitMonitor(driver, vm) < 0)
|
||||||
|
releaseaddr = false;
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuDomainObjExitMonitor(driver, vm) < 0)
|
|
||||||
releaseaddr = false;
|
|
||||||
|
|
||||||
virDomainAuditDisk(vm, NULL, disk->src, "attach", false);
|
virDomainAuditDisk(vm, NULL, disk->src, "attach", false);
|
||||||
|
|
||||||
@ -728,13 +728,12 @@ qemuDomainAttachSCSIDisk(virConnectPtr conn,
|
|||||||
ignore_value(qemuMonitorDelObject(priv->mon, secinfo->s.aes.alias));
|
ignore_value(qemuMonitorDelObject(priv->mon, secinfo->s.aes.alias));
|
||||||
if (encobjAdded)
|
if (encobjAdded)
|
||||||
ignore_value(qemuMonitorDelObject(priv->mon, encinfo->s.aes.alias));
|
ignore_value(qemuMonitorDelObject(priv->mon, encinfo->s.aes.alias));
|
||||||
|
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
|
||||||
|
|
||||||
virDomainAuditDisk(vm, NULL, disk->src, "attach", false);
|
virDomainAuditDisk(vm, NULL, disk->src, "attach", false);
|
||||||
|
|
||||||
error:
|
error:
|
||||||
@ -822,12 +821,12 @@ qemuDomainAttachUSBMassStorageDevice(virQEMUDriverPtr driver,
|
|||||||
VIR_WARN("Unable to remove drive %s (%s) after failed "
|
VIR_WARN("Unable to remove drive %s (%s) after failed "
|
||||||
"qemuMonitorAddDevice", drivealias, drivestr);
|
"qemuMonitorAddDevice", drivealias, drivestr);
|
||||||
}
|
}
|
||||||
|
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
|
||||||
virDomainAuditDisk(vm, NULL, disk->src, "attach", false);
|
virDomainAuditDisk(vm, NULL, disk->src, "attach", false);
|
||||||
|
|
||||||
error:
|
error:
|
||||||
@ -1679,11 +1678,11 @@ int qemuDomainAttachRedirdevDevice(virConnectPtr conn,
|
|||||||
ignore_value(qemuMonitorDelObject(priv->mon, tlsAlias));
|
ignore_value(qemuMonitorDelObject(priv->mon, tlsAlias));
|
||||||
if (secobjAdded)
|
if (secobjAdded)
|
||||||
ignore_value(qemuMonitorDelObject(priv->mon, secAlias));
|
ignore_value(qemuMonitorDelObject(priv->mon, secAlias));
|
||||||
|
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
|
||||||
goto audit;
|
goto audit;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1973,12 +1972,12 @@ int qemuDomainAttachChrDevice(virConnectPtr conn,
|
|||||||
ignore_value(qemuMonitorDelObject(priv->mon, tlsAlias));
|
ignore_value(qemuMonitorDelObject(priv->mon, tlsAlias));
|
||||||
if (secobjAdded)
|
if (secobjAdded)
|
||||||
ignore_value(qemuMonitorDelObject(priv->mon, secAlias));
|
ignore_value(qemuMonitorDelObject(priv->mon, secAlias));
|
||||||
|
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
|
||||||
goto audit;
|
goto audit;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2159,13 +2158,13 @@ qemuDomainAttachRNGDevice(virConnectPtr conn,
|
|||||||
ignore_value(qemuMonitorDelObject(priv->mon, tlsAlias));
|
ignore_value(qemuMonitorDelObject(priv->mon, tlsAlias));
|
||||||
if (secobjAdded)
|
if (secobjAdded)
|
||||||
ignore_value(qemuMonitorDelObject(priv->mon, secAlias));
|
ignore_value(qemuMonitorDelObject(priv->mon, secAlias));
|
||||||
|
if (qemuDomainObjExitMonitor(driver, vm) < 0)
|
||||||
|
releaseaddr = false;
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuDomainObjExitMonitor(driver, vm) < 0)
|
|
||||||
releaseaddr = false;
|
|
||||||
goto audit;
|
goto audit;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2279,14 +2278,14 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
|
|||||||
orig_err = virSaveLastError();
|
orig_err = virSaveLastError();
|
||||||
if (objAdded)
|
if (objAdded)
|
||||||
ignore_value(qemuMonitorDelObject(priv->mon, objalias));
|
ignore_value(qemuMonitorDelObject(priv->mon, objalias));
|
||||||
|
if (qemuDomainObjExitMonitor(driver, vm) < 0)
|
||||||
|
mem = NULL;
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
if (qemuDomainObjExitMonitor(driver, vm) < 0) {
|
if (!mem)
|
||||||
mem = NULL;
|
|
||||||
goto audit;
|
goto audit;
|
||||||
}
|
|
||||||
|
|
||||||
removedef:
|
removedef:
|
||||||
if ((id = virDomainMemoryFindByDef(vm->def, mem)) >= 0)
|
if ((id = virDomainMemoryFindByDef(vm->def, mem)) >= 0)
|
||||||
@ -2509,12 +2508,12 @@ qemuDomainAttachHostSCSIDevice(virConnectPtr conn,
|
|||||||
"qemuMonitorAddDevice",
|
"qemuMonitorAddDevice",
|
||||||
drvstr, devstr);
|
drvstr, devstr);
|
||||||
}
|
}
|
||||||
|
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
ignore_value(qemuDomainObjExitMonitor(driver, vm));
|
|
||||||
virDomainAuditHostdev(vm, hostdev, "attach", false);
|
virDomainAuditHostdev(vm, hostdev, "attach", false);
|
||||||
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -2801,14 +2800,14 @@ qemuDomainAttachShmemDevice(virQEMUDriverPtr driver,
|
|||||||
ignore_value(qemuMonitorDelObject(priv->mon, memAlias));
|
ignore_value(qemuMonitorDelObject(priv->mon, memAlias));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (qemuDomainObjExitMonitor(driver, vm) < 0)
|
||||||
|
release_address = false;
|
||||||
|
|
||||||
if (orig_err) {
|
if (orig_err) {
|
||||||
virSetError(orig_err);
|
virSetError(orig_err);
|
||||||
virFreeError(orig_err);
|
virFreeError(orig_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuDomainObjExitMonitor(driver, vm) < 0)
|
|
||||||
release_address = false;
|
|
||||||
|
|
||||||
goto audit;
|
goto audit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user