mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-03-03 07:33:50 +00:00
qemu: Use -machine accel=tcg|kvm when available
This is a better interface to choose accelerator than guessing whether we should enable or disable kvm to get the right one.
This commit is contained in:
parent
cfe24c1a18
commit
6d4804858e
@ -5274,11 +5274,80 @@ no_memory:
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
qemuBuildObsoleteAccelArg(virCommandPtr cmd,
|
||||||
|
const virDomainDefPtr def,
|
||||||
|
virQEMUCapsPtr qemuCaps)
|
||||||
|
{
|
||||||
|
int disableKQEMU = 0;
|
||||||
|
int enableKQEMU = 0;
|
||||||
|
int disableKVM = 0;
|
||||||
|
int enableKVM = 0;
|
||||||
|
|
||||||
|
switch (def->virtType) {
|
||||||
|
case VIR_DOMAIN_VIRT_QEMU:
|
||||||
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KQEMU))
|
||||||
|
disableKQEMU = 1;
|
||||||
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM))
|
||||||
|
disableKVM = 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_VIRT_KQEMU:
|
||||||
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM))
|
||||||
|
disableKVM = 1;
|
||||||
|
|
||||||
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_ENABLE_KQEMU)) {
|
||||||
|
enableKQEMU = 1;
|
||||||
|
} else if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_KQEMU)) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
|
_("the QEMU binary does not support kqemu"));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_VIRT_KVM:
|
||||||
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KQEMU))
|
||||||
|
disableKQEMU = 1;
|
||||||
|
|
||||||
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_ENABLE_KVM)) {
|
||||||
|
enableKVM = 1;
|
||||||
|
} else if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM)) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
|
_("the QEMU binary does not support kvm"));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_VIRT_XEN:
|
||||||
|
/* XXX better check for xenner */
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("the QEMU binary does not support %s"),
|
||||||
|
virDomainVirtTypeToString(def->virtType));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (disableKQEMU)
|
||||||
|
virCommandAddArg(cmd, "-no-kqemu");
|
||||||
|
else if (enableKQEMU)
|
||||||
|
virCommandAddArgList(cmd, "-enable-kqemu", "-kernel-kqemu", NULL);
|
||||||
|
if (disableKVM)
|
||||||
|
virCommandAddArg(cmd, "-no-kvm");
|
||||||
|
if (enableKVM)
|
||||||
|
virCommandAddArg(cmd, "-enable-kvm");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
qemuBuildMachineArgStr(virCommandPtr cmd,
|
qemuBuildMachineArgStr(virCommandPtr cmd,
|
||||||
const virDomainDefPtr def,
|
const virDomainDefPtr def,
|
||||||
virQEMUCapsPtr qemuCaps)
|
virQEMUCapsPtr qemuCaps)
|
||||||
{
|
{
|
||||||
|
bool obsoleteAccel = false;
|
||||||
|
|
||||||
/* This should *never* be NULL, since we always provide
|
/* This should *never* be NULL, since we always provide
|
||||||
* a machine in the capabilities data for QEMU. So this
|
* a machine in the capabilities data for QEMU. So this
|
||||||
* check is just here as a safety in case the unexpected
|
* check is just here as a safety in case the unexpected
|
||||||
@ -5297,12 +5366,20 @@ qemuBuildMachineArgStr(virCommandPtr cmd,
|
|||||||
"with this QEMU binary"));
|
"with this QEMU binary"));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
obsoleteAccel = true;
|
||||||
} else {
|
} else {
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
|
|
||||||
virCommandAddArg(cmd, "-machine");
|
virCommandAddArg(cmd, "-machine");
|
||||||
virBufferAdd(&buf, def->os.machine, -1);
|
virBufferAdd(&buf, def->os.machine, -1);
|
||||||
|
|
||||||
|
if (def->virtType == VIR_DOMAIN_VIRT_QEMU)
|
||||||
|
virBufferAddLit(&buf, ",accel=tcg");
|
||||||
|
else if (def->virtType == VIR_DOMAIN_VIRT_KVM)
|
||||||
|
virBufferAddLit(&buf, ",accel=kvm");
|
||||||
|
else
|
||||||
|
obsoleteAccel = true;
|
||||||
|
|
||||||
/* To avoid the collision of creating USB controllers when calling
|
/* To avoid the collision of creating USB controllers when calling
|
||||||
* machine->init in QEMU, it needs to set usb=off
|
* machine->init in QEMU, it needs to set usb=off
|
||||||
*/
|
*/
|
||||||
@ -5325,6 +5402,10 @@ qemuBuildMachineArgStr(virCommandPtr cmd,
|
|||||||
virCommandAddArgBuffer(cmd, &buf);
|
virCommandAddArgBuffer(cmd, &buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (obsoleteAccel &&
|
||||||
|
qemuBuildObsoleteAccelArg(cmd, def, qemuCaps) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5771,10 +5852,6 @@ qemuBuildCommandLine(virConnectPtr conn,
|
|||||||
enum virNetDevVPortProfileOp vmop)
|
enum virNetDevVPortProfileOp vmop)
|
||||||
{
|
{
|
||||||
int i, j;
|
int i, j;
|
||||||
int disableKQEMU = 0;
|
|
||||||
int enableKQEMU = 0;
|
|
||||||
int disableKVM = 0;
|
|
||||||
int enableKVM = 0;
|
|
||||||
const char *emulator;
|
const char *emulator;
|
||||||
char uuid[VIR_UUID_STRING_BUFLEN];
|
char uuid[VIR_UUID_STRING_BUFLEN];
|
||||||
char *cpu;
|
char *cpu;
|
||||||
@ -5819,53 +5896,6 @@ qemuBuildCommandLine(virConnectPtr conn,
|
|||||||
(def->virtType == VIR_DOMAIN_VIRT_QEMU))
|
(def->virtType == VIR_DOMAIN_VIRT_QEMU))
|
||||||
virQEMUCapsClear(qemuCaps, QEMU_CAPS_DRIVE_BOOT);
|
virQEMUCapsClear(qemuCaps, QEMU_CAPS_DRIVE_BOOT);
|
||||||
|
|
||||||
switch (def->virtType) {
|
|
||||||
case VIR_DOMAIN_VIRT_QEMU:
|
|
||||||
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KQEMU))
|
|
||||||
disableKQEMU = 1;
|
|
||||||
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM))
|
|
||||||
disableKVM = 1;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VIR_DOMAIN_VIRT_KQEMU:
|
|
||||||
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM))
|
|
||||||
disableKVM = 1;
|
|
||||||
|
|
||||||
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_ENABLE_KQEMU)) {
|
|
||||||
enableKQEMU = 1;
|
|
||||||
} else if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_KQEMU)) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
|
||||||
_("the QEMU binary %s does not support kqemu"),
|
|
||||||
emulator);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VIR_DOMAIN_VIRT_KVM:
|
|
||||||
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KQEMU))
|
|
||||||
disableKQEMU = 1;
|
|
||||||
|
|
||||||
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_ENABLE_KVM)) {
|
|
||||||
enableKVM = 1;
|
|
||||||
} else if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM)) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
|
||||||
_("the QEMU binary %s does not support kvm"),
|
|
||||||
emulator);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VIR_DOMAIN_VIRT_XEN:
|
|
||||||
/* XXX better check for xenner */
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
|
||||||
_("the QEMU binary %s does not support %s"),
|
|
||||||
emulator, virDomainVirtTypeToString(def->virtType));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
cmd = virCommandNew(emulator);
|
cmd = virCommandNew(emulator);
|
||||||
|
|
||||||
virCommandAddEnvPassCommon(cmd);
|
virCommandAddEnvPassCommon(cmd);
|
||||||
@ -5885,15 +5915,6 @@ qemuBuildCommandLine(virConnectPtr conn,
|
|||||||
if (qemuBuildMachineArgStr(cmd, def, qemuCaps) < 0)
|
if (qemuBuildMachineArgStr(cmd, def, qemuCaps) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (disableKQEMU)
|
|
||||||
virCommandAddArg(cmd, "-no-kqemu");
|
|
||||||
else if (enableKQEMU)
|
|
||||||
virCommandAddArgList(cmd, "-enable-kqemu", "-kernel-kqemu", NULL);
|
|
||||||
if (disableKVM)
|
|
||||||
virCommandAddArg(cmd, "-no-kvm");
|
|
||||||
if (enableKVM)
|
|
||||||
virCommandAddArg(cmd, "-enable-kvm");
|
|
||||||
|
|
||||||
if (qemuBuildCpuArgStr(driver, def, emulator, qemuCaps,
|
if (qemuBuildCpuArgStr(driver, def, emulator, qemuCaps,
|
||||||
hostarch, &cpu, &hasHwVirt, !!migrateFrom) < 0)
|
hostarch, &cpu, &hasHwVirt, !!migrateFrom) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
4
tests/qemuxml2argvdata/qemuxml2argv-kvm.args
Normal file
4
tests/qemuxml2argvdata/qemuxml2argv-kvm.args
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test \
|
||||||
|
/usr/libexec/qemu-kvm -S -machine pc-1.0,accel=kvm -m 4096 \
|
||||||
|
-smp 4 -nographic -monitor unix:/tmp/test-monitor,server,nowait \
|
||||||
|
-no-acpi -boot c -usb -net none -serial none -parallel none
|
22
tests/qemuxml2argvdata/qemuxml2argv-kvm.xml
Normal file
22
tests/qemuxml2argvdata/qemuxml2argv-kvm.xml
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<domain type='kvm'>
|
||||||
|
<name>kvm</name>
|
||||||
|
<uuid>d091ea82-29e6-2e34-3005-f02617b36e87</uuid>
|
||||||
|
<memory unit='KiB'>4194304</memory>
|
||||||
|
<currentMemory unit='KiB'>4194304</currentMemory>
|
||||||
|
<vcpu placement='static'>4</vcpu>
|
||||||
|
<os>
|
||||||
|
<type arch='x86_64' machine='pc-1.0'>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/libexec/qemu-kvm</emulator>
|
||||||
|
<controller type='usb' index='0'>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x2'/>
|
||||||
|
</controller>
|
||||||
|
<memballoon model='none'/>
|
||||||
|
</devices>
|
||||||
|
</domain>
|
@ -1,5 +1,5 @@
|
|||||||
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test /usr/bin/qemu \
|
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test /usr/bin/qemu \
|
||||||
-S -machine pc,dump-guest-core=off -m 214 -smp 1 -nographic \
|
-S -machine pc,accel=tcg,dump-guest-core=off -m 214 -smp 1 -nographic \
|
||||||
-monitor unix:/tmp/test-monitor,server,nowait -no-acpi -boot c -usb \
|
-monitor unix:/tmp/test-monitor,server,nowait -no-acpi -boot c -usb \
|
||||||
-hda /dev/HostVG/QEMUGuest1 -net none -serial \
|
-hda /dev/HostVG/QEMUGuest1 -net none -serial \
|
||||||
none -parallel none
|
none -parallel none
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test /usr/bin/qemu \
|
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test /usr/bin/qemu \
|
||||||
-S -machine pc,dump-guest-core=on -m 214 -smp 1 -nographic \
|
-S -machine pc,accel=tcg,dump-guest-core=on -m 214 -smp 1 -nographic \
|
||||||
-monitor unix:/tmp/test-monitor,server,nowait -no-acpi -boot c -usb \
|
-monitor unix:/tmp/test-monitor,server,nowait -no-acpi -boot c -usb \
|
||||||
-hda /dev/HostVG/QEMUGuest1 -net none -serial \
|
-hda /dev/HostVG/QEMUGuest1 -net none -serial \
|
||||||
none -parallel none
|
none -parallel none
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test /usr/bin/qemu \
|
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 \
|
-S -machine pc,accel=tcg,usb=off -m 214 -smp 1 -nographic \
|
||||||
-monitor unix:/tmp/test-monitor,server,nowait -no-acpi -boot c -usb \
|
-monitor unix:/tmp/test-monitor,server,nowait -no-acpi -boot c -usb \
|
||||||
-hda /dev/HostVG/QEMUGuest1 -net none -serial \
|
-hda /dev/HostVG/QEMUGuest1 -net none -serial \
|
||||||
none -parallel none
|
none -parallel none
|
||||||
|
@ -372,6 +372,7 @@ mymain(void)
|
|||||||
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,
|
DO_TEST("machine-usb-opt", QEMU_CAPS_MACHINE_OPT,
|
||||||
QEMU_CAPS_MACHINE_USB_OPT);
|
QEMU_CAPS_MACHINE_USB_OPT);
|
||||||
|
DO_TEST("kvm", QEMU_CAPS_MACHINE_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…
x
Reference in New Issue
Block a user