mirror of https://gitee.com/openkylin/libvirt.git
Add USB option capability
To avoid the collision for creating USB controllers in machine->init() and -device xx command line, it needs to set usb=off to avoid one USB controller created in machine->init(). So that libvirt can use -device or -usb to create USB controller sucessfully. So QEMU_CAPS_MACHINE_USB_OPT capability is added, and it is for QEMU v1.3.0 onwards which supports USB option. Signed-off-by: Li Zhang <zhlcindy@linux.vnet.ibm.com>
This commit is contained in:
parent
6528b7044f
commit
a6e37aedff
|
@ -216,6 +216,7 @@ VIR_ENUM_IMPL(virQEMUCaps, QEMU_CAPS_LAST,
|
||||||
|
|
||||||
"ipv6-migration", /* 135 */
|
"ipv6-migration", /* 135 */
|
||||||
"machine-opt",
|
"machine-opt",
|
||||||
|
"machine-usb-opt",
|
||||||
);
|
);
|
||||||
|
|
||||||
struct _virQEMUCaps {
|
struct _virQEMUCaps {
|
||||||
|
@ -1078,6 +1079,10 @@ virQEMUCapsComputeCmdFlags(const char *help,
|
||||||
if (strstr(help, "-machine"))
|
if (strstr(help, "-machine"))
|
||||||
virQEMUCapsSet(qemuCaps, QEMU_CAPS_MACHINE_OPT);
|
virQEMUCapsSet(qemuCaps, QEMU_CAPS_MACHINE_OPT);
|
||||||
|
|
||||||
|
/* USB option is supported v1.3.0 onwards */
|
||||||
|
if (qemuCaps->version >= 1003000)
|
||||||
|
virQEMUCapsSet(qemuCaps, QEMU_CAPS_MACHINE_USB_OPT);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Handling of -incoming arg with varying features
|
* Handling of -incoming arg with varying features
|
||||||
* -incoming tcp (kvm >= 79, qemu >= 0.10.0)
|
* -incoming tcp (kvm >= 79, qemu >= 0.10.0)
|
||||||
|
@ -2435,6 +2440,10 @@ virQEMUCapsInitQMP(virQEMUCapsPtr qemuCaps,
|
||||||
|
|
||||||
virQEMUCapsInitQMPBasic(qemuCaps);
|
virQEMUCapsInitQMPBasic(qemuCaps);
|
||||||
|
|
||||||
|
/* USB option is supported v1.3.0 onwards */
|
||||||
|
if (qemuCaps->version >= 1003000)
|
||||||
|
virQEMUCapsSet(qemuCaps, QEMU_CAPS_MACHINE_USB_OPT);
|
||||||
|
|
||||||
if (!(archstr = qemuMonitorGetTargetArch(mon)))
|
if (!(archstr = qemuMonitorGetTargetArch(mon)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
|
|
@ -176,6 +176,7 @@ enum virQEMUCapsFlags {
|
||||||
QEMU_CAPS_SCSI_MEGASAS = 134, /* -device megasas */
|
QEMU_CAPS_SCSI_MEGASAS = 134, /* -device megasas */
|
||||||
QEMU_CAPS_IPV6_MIGRATION = 135, /* -incoming [::] */
|
QEMU_CAPS_IPV6_MIGRATION = 135, /* -incoming [::] */
|
||||||
QEMU_CAPS_MACHINE_OPT = 136, /* -machine xxxx*/
|
QEMU_CAPS_MACHINE_OPT = 136, /* -machine xxxx*/
|
||||||
|
QEMU_CAPS_MACHINE_USB_OPT = 137, /* -machine xxx,usb=on/off */
|
||||||
|
|
||||||
QEMU_CAPS_LAST, /* this must always be the last item */
|
QEMU_CAPS_LAST, /* this must always be the last item */
|
||||||
};
|
};
|
||||||
|
|
|
@ -5257,6 +5257,12 @@ qemuBuildMachineArgStr(virCommandPtr cmd,
|
||||||
virCommandAddArg(cmd, "-machine");
|
virCommandAddArg(cmd, "-machine");
|
||||||
virBufferAdd(&buf, def->os.machine, -1);
|
virBufferAdd(&buf, def->os.machine, -1);
|
||||||
|
|
||||||
|
/* To avoid the collision of creating USB controllers when calling
|
||||||
|
* machine->init in QEMU, it needs to set usb=off
|
||||||
|
*/
|
||||||
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_MACHINE_USB_OPT))
|
||||||
|
virBufferAsprintf(&buf, ",usb=off");
|
||||||
|
|
||||||
if (def->mem.dump_core) {
|
if (def->mem.dump_core) {
|
||||||
if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DUMP_GUEST_CORE)) {
|
if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DUMP_GUEST_CORE)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test /usr/bin/qemu \
|
||||||
|
-S -machine pc,usb=off -m 214 -smp 1 -nographic \
|
||||||
|
-monitor unix:/tmp/test-monitor,server,nowait -no-acpi -boot c -usb \
|
||||||
|
-hda /dev/HostVG/QEMUGuest1 -net none -serial \
|
||||||
|
none -parallel none
|
|
@ -0,0 +1,26 @@
|
||||||
|
<domain type='qemu'>
|
||||||
|
<name>QEMUGuest1</name>
|
||||||
|
<uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
||||||
|
<memory unit='KiB'>219100</memory>
|
||||||
|
<currentMemory unit='KiB'>219100</currentMemory>
|
||||||
|
<vcpu placement='static'>1</vcpu>
|
||||||
|
<os>
|
||||||
|
<type arch='i686' machine='pc'>hvm</type>
|
||||||
|
<boot dev='hd'/>
|
||||||
|
</os>
|
||||||
|
<clock offset='utc'/>
|
||||||
|
<on_poweroff>destroy</on_poweroff>
|
||||||
|
<on_reboot>restart</on_reboot>
|
||||||
|
<on_crash>destroy</on_crash>
|
||||||
|
<devices>
|
||||||
|
<emulator>/usr/bin/qemu</emulator>
|
||||||
|
<disk type='block' device='disk'>
|
||||||
|
<source dev='/dev/HostVG/QEMUGuest1'/>
|
||||||
|
<target dev='hda' bus='ide'/>
|
||||||
|
<address type='drive' controller='0' bus='0' target='0' unit='0'/>
|
||||||
|
</disk>
|
||||||
|
<controller type='usb' index='0'/>
|
||||||
|
<controller type='ide' index='0'/>
|
||||||
|
<memballoon model='virtio'/>
|
||||||
|
</devices>
|
||||||
|
</domain>
|
|
@ -369,6 +369,8 @@ mymain(void)
|
||||||
QEMU_CAPS_DUMP_GUEST_CORE);
|
QEMU_CAPS_DUMP_GUEST_CORE);
|
||||||
DO_TEST_FAILURE("machine-core-on", NONE);
|
DO_TEST_FAILURE("machine-core-on", NONE);
|
||||||
DO_TEST_FAILURE("machine-core-on", QEMU_CAPS_MACHINE_OPT);
|
DO_TEST_FAILURE("machine-core-on", QEMU_CAPS_MACHINE_OPT);
|
||||||
|
DO_TEST("machine-usb-opt", QEMU_CAPS_MACHINE_OPT,
|
||||||
|
QEMU_CAPS_MACHINE_USB_OPT);
|
||||||
DO_TEST("boot-cdrom", NONE);
|
DO_TEST("boot-cdrom", NONE);
|
||||||
DO_TEST("boot-network", NONE);
|
DO_TEST("boot-network", NONE);
|
||||||
DO_TEST("boot-floppy", NONE);
|
DO_TEST("boot-floppy", NONE);
|
||||||
|
|
Loading…
Reference in New Issue