mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-02-22 19:32:19 +00:00
qemu_hotplug: remove extra function in middle of DetachController call chain
qemuDomainDetachDeviceControllerLive() just checks if the controller type is SCSI, and then either returns failure, or calls qemuDomainDetachControllerDevice(). Instead, lets just check for type != SCSI at the top of the latter function, and call it directly. Signed-off-by: Laine Stump <laine@laine.org> ACKed-by: Peter Krempa <pkrempa@redhat.com>
This commit is contained in:
parent
6a9c3fbade
commit
e4d96324b4
@ -5528,6 +5528,13 @@ int qemuDomainDetachControllerDevice(virQEMUDriverPtr driver,
|
||||
int idx, ret = -1;
|
||||
virDomainControllerDefPtr detach = NULL;
|
||||
|
||||
if (dev->data.controller->type != VIR_DOMAIN_CONTROLLER_TYPE_SCSI) {
|
||||
virReportError(VIR_ERR_OPERATION_UNSUPPORTED,
|
||||
_("'%s' controller cannot be hot unplugged."),
|
||||
virDomainControllerTypeToString(dev->data.controller->type));
|
||||
return -1;
|
||||
}
|
||||
|
||||
if ((idx = virDomainControllerFind(vm->def,
|
||||
dev->data.controller->type,
|
||||
dev->data.controller->idx)) < 0) {
|
||||
@ -6170,27 +6177,6 @@ qemuDomainDetachLease(virQEMUDriverPtr driver,
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
qemuDomainDetachDeviceControllerLive(virQEMUDriverPtr driver,
|
||||
virDomainObjPtr vm,
|
||||
virDomainDeviceDefPtr dev,
|
||||
bool async)
|
||||
{
|
||||
virDomainControllerDefPtr cont = dev->data.controller;
|
||||
int ret = -1;
|
||||
|
||||
switch (cont->type) {
|
||||
case VIR_DOMAIN_CONTROLLER_TYPE_SCSI:
|
||||
ret = qemuDomainDetachControllerDevice(driver, vm, dev, async);
|
||||
break;
|
||||
default :
|
||||
virReportError(VIR_ERR_OPERATION_UNSUPPORTED,
|
||||
_("'%s' controller cannot be hot unplugged."),
|
||||
virDomainControllerTypeToString(cont->type));
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
int
|
||||
qemuDomainDetachDeviceLive(virDomainObjPtr vm,
|
||||
virDomainDeviceDefPtr dev,
|
||||
@ -6204,7 +6190,7 @@ qemuDomainDetachDeviceLive(virDomainObjPtr vm,
|
||||
ret = qemuDomainDetachDeviceDiskLive(driver, vm, dev, async);
|
||||
break;
|
||||
case VIR_DOMAIN_DEVICE_CONTROLLER:
|
||||
ret = qemuDomainDetachDeviceControllerLive(driver, vm, dev, async);
|
||||
ret = qemuDomainDetachControllerDevice(driver, vm, dev, async);
|
||||
break;
|
||||
case VIR_DOMAIN_DEVICE_LEASE:
|
||||
ret = qemuDomainDetachLease(driver, vm, dev->data.lease);
|
||||
|
Loading…
x
Reference in New Issue
Block a user