mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 09:17:52 +03:00
qemu: hotplug: Refactor qemuDomainAttachDeviceDiskLiveInternal
We now explicitly handle media change elsewhere so we can drop the switch statement. This will also make it more intuitive once CDROM device hotplug might be supported. Signed-off-by: Peter Krempa <pkrempa@redhat.com>
This commit is contained in:
parent
a1d3fc09f8
commit
0d981bcefc
@ -1113,52 +1113,42 @@ qemuDomainAttachDeviceDiskLiveInternal(virQEMUDriverPtr driver,
|
|||||||
if (qemuDomainDetermineDiskChain(driver, vm, disk, true) < 0)
|
if (qemuDomainDetermineDiskChain(driver, vm, disk, true) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
switch ((virDomainDiskDevice) disk->device) {
|
for (i = 0; i < vm->def->ndisks; i++) {
|
||||||
case VIR_DOMAIN_DISK_DEVICE_DISK:
|
if (virDomainDiskDefCheckDuplicateInfo(vm->def->disks[i], disk) < 0)
|
||||||
case VIR_DOMAIN_DISK_DEVICE_LUN:
|
goto cleanup;
|
||||||
for (i = 0; i < vm->def->ndisks; i++) {
|
}
|
||||||
if (virDomainDiskDefCheckDuplicateInfo(vm->def->disks[i], disk) < 0)
|
|
||||||
goto cleanup;
|
switch ((virDomainDiskBus) disk->bus) {
|
||||||
}
|
case VIR_DOMAIN_DISK_BUS_USB:
|
||||||
|
if (disk->device == VIR_DOMAIN_DISK_DEVICE_LUN) {
|
||||||
switch ((virDomainDiskBus) disk->bus) {
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
case VIR_DOMAIN_DISK_BUS_USB:
|
_("disk device='lun' is not supported for usb bus"));
|
||||||
if (disk->device == VIR_DOMAIN_DISK_DEVICE_LUN) {
|
break;
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
|
||||||
_("disk device='lun' is not supported for usb bus"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
ret = qemuDomainAttachUSBMassStorageDevice(driver, vm, disk);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VIR_DOMAIN_DISK_BUS_VIRTIO:
|
|
||||||
ret = qemuDomainAttachVirtioDiskDevice(driver, vm, disk);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VIR_DOMAIN_DISK_BUS_SCSI:
|
|
||||||
ret = qemuDomainAttachSCSIDisk(driver, vm, disk);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VIR_DOMAIN_DISK_BUS_IDE:
|
|
||||||
case VIR_DOMAIN_DISK_BUS_FDC:
|
|
||||||
case VIR_DOMAIN_DISK_BUS_XEN:
|
|
||||||
case VIR_DOMAIN_DISK_BUS_UML:
|
|
||||||
case VIR_DOMAIN_DISK_BUS_SATA:
|
|
||||||
case VIR_DOMAIN_DISK_BUS_SD:
|
|
||||||
/* Note that SD card hotplug support should be added only once
|
|
||||||
* they support '-device' (don't require -drive only).
|
|
||||||
* See also: qemuDiskBusNeedsDriveArg */
|
|
||||||
case VIR_DOMAIN_DISK_BUS_LAST:
|
|
||||||
virReportError(VIR_ERR_OPERATION_UNSUPPORTED,
|
|
||||||
_("disk bus '%s' cannot be hotplugged."),
|
|
||||||
virDomainDiskBusTypeToString(disk->bus));
|
|
||||||
}
|
}
|
||||||
|
ret = qemuDomainAttachUSBMassStorageDevice(driver, vm, disk);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_DISK_DEVICE_CDROM:
|
case VIR_DOMAIN_DISK_BUS_VIRTIO:
|
||||||
case VIR_DOMAIN_DISK_DEVICE_FLOPPY:
|
ret = qemuDomainAttachVirtioDiskDevice(driver, vm, disk);
|
||||||
case VIR_DOMAIN_DISK_DEVICE_LAST:
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_DISK_BUS_SCSI:
|
||||||
|
ret = qemuDomainAttachSCSIDisk(driver, vm, disk);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_DISK_BUS_IDE:
|
||||||
|
case VIR_DOMAIN_DISK_BUS_FDC:
|
||||||
|
case VIR_DOMAIN_DISK_BUS_XEN:
|
||||||
|
case VIR_DOMAIN_DISK_BUS_UML:
|
||||||
|
case VIR_DOMAIN_DISK_BUS_SATA:
|
||||||
|
case VIR_DOMAIN_DISK_BUS_SD:
|
||||||
|
/* Note that SD card hotplug support should be added only once
|
||||||
|
* they support '-device' (don't require -drive only).
|
||||||
|
* See also: qemuDiskBusNeedsDriveArg */
|
||||||
|
case VIR_DOMAIN_DISK_BUS_LAST:
|
||||||
|
virReportError(VIR_ERR_OPERATION_UNSUPPORTED,
|
||||||
|
_("disk bus '%s' cannot be hotplugged."),
|
||||||
|
virDomainDiskBusTypeToString(disk->bus));
|
||||||
}
|
}
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
Loading…
Reference in New Issue
Block a user