224 lines
9.4 KiB
Diff
224 lines
9.4 KiB
Diff
From e20a2c775a07aad3a5309785dd75909aacc48d95 Mon Sep 17 00:00:00 2001
|
|
Message-Id: <e20a2c775a07aad3a5309785dd75909aacc48d95.1384729563.git.crobinso@redhat.com>
|
|
From: =?UTF-8?q?J=C3=A1n=20Tomko?= <jtomko@redhat.com>
|
|
Date: Mon, 1 Jul 2013 18:28:50 +0200
|
|
Subject: [PATCH] qemu: don't use deprecated -no-kvm-pit-reinjection
|
|
|
|
Since qemu-kvm 1.1 [1] (since 1.3. in upstream QEMU [2])
|
|
'-no-kvm-pit-reinjection' has been deprecated.
|
|
Use -global kvm-pit.lost_tick_policy=discard instead.
|
|
|
|
https://bugzilla.redhat.com/show_bug.cgi?id=978719
|
|
|
|
[1] http://git.kernel.org/cgit/virt/kvm/qemu-kvm.git/commit/?id=4e4fa39
|
|
[2] http://git.qemu.org/?p=qemu.git;a=commitdiff;h=c21fb4f
|
|
|
|
(cherry picked from commit 1569fa14d8f6b6636cf78d7ee62ae3bd205f5638)
|
|
|
|
Conflicts:
|
|
tests/qemucapabilitiesdata/caps_1.2.2-1.caps
|
|
tests/qemucapabilitiesdata/caps_1.2.2-1.replies
|
|
tests/qemucapabilitiesdata/caps_1.3.1-1.caps
|
|
tests/qemucapabilitiesdata/caps_1.3.1-1.replies
|
|
tests/qemucapabilitiesdata/caps_1.4.2-1.caps
|
|
tests/qemucapabilitiesdata/caps_1.4.2-1.replies
|
|
tests/qemucapabilitiesdata/caps_1.5.3-1.caps
|
|
tests/qemucapabilitiesdata/caps_1.5.3-1.replies
|
|
tests/qemucapabilitiesdata/caps_1.6.0-1.caps
|
|
tests/qemucapabilitiesdata/caps_1.6.0-1.replies
|
|
tests/qemucapabilitiesdata/caps_1.6.50-1.caps
|
|
tests/qemucapabilitiesdata/caps_1.6.50-1.replies
|
|
(qemucapabilitiestest is not backported)
|
|
---
|
|
src/qemu/qemu_capabilities.c | 7 ++++++
|
|
src/qemu/qemu_capabilities.h | 1 +
|
|
src/qemu/qemu_command.c | 8 ++++--
|
|
.../qemuxml2argv-kvm-pit-delay.args | 5 ++++
|
|
.../qemuxml2argv-kvm-pit-delay.xml | 29 ++++++++++++++++++++++
|
|
.../qemuxml2argv-kvm-pit-device.args | 5 ++++
|
|
.../qemuxml2argv-kvm-pit-device.xml | 29 ++++++++++++++++++++++
|
|
tests/qemuxml2argvtest.c | 5 ++++
|
|
8 files changed, 87 insertions(+), 2 deletions(-)
|
|
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.args
|
|
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.xml
|
|
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.args
|
|
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.xml
|
|
|
|
diff --git a/src/qemu/qemu_capabilities.c b/src/qemu/qemu_capabilities.c
|
|
index dc8f0be..5e1ae93 100644
|
|
--- a/src/qemu/qemu_capabilities.c
|
|
+++ b/src/qemu/qemu_capabilities.c
|
|
@@ -242,6 +242,7 @@ VIR_ENUM_IMPL(virQEMUCaps, QEMU_CAPS_LAST,
|
|
"usb-storage.removable",
|
|
"virtio-mmio",
|
|
"ich9-intel-hda",
|
|
+ "kvm-pit-lost-tick-policy",
|
|
);
|
|
|
|
struct _virQEMUCaps {
|
|
@@ -1458,6 +1459,10 @@ static struct virQEMUCapsStringFlags virQEMUCapsObjectPropsUsbStorage[] = {
|
|
{ "removable", QEMU_CAPS_USB_STORAGE_REMOVABLE },
|
|
};
|
|
|
|
+static struct virQEMUCapsStringFlags virQEMUCapsObjectPropsKVMPit[] = {
|
|
+ { "lost_tick_policy", QEMU_CAPS_KVM_PIT_TICK_POLICY },
|
|
+};
|
|
+
|
|
struct virQEMUCapsObjectTypeProps {
|
|
const char *type;
|
|
struct virQEMUCapsStringFlags *props;
|
|
@@ -1501,6 +1506,8 @@ static struct virQEMUCapsObjectTypeProps virQEMUCapsObjectProps[] = {
|
|
ARRAY_CARDINALITY(virQEMUCapsObjectPropsQ35PciHost) },
|
|
{ "usb-storage", virQEMUCapsObjectPropsUsbStorage,
|
|
ARRAY_CARDINALITY(virQEMUCapsObjectPropsUsbStorage) },
|
|
+ { "kvm-pit", virQEMUCapsObjectPropsKVMPit,
|
|
+ ARRAY_CARDINALITY(virQEMUCapsObjectPropsKVMPit) },
|
|
};
|
|
|
|
|
|
diff --git a/src/qemu/qemu_capabilities.h b/src/qemu/qemu_capabilities.h
|
|
index f8dc728..7c05412 100644
|
|
--- a/src/qemu/qemu_capabilities.h
|
|
+++ b/src/qemu/qemu_capabilities.h
|
|
@@ -197,6 +197,7 @@ enum virQEMUCapsFlags {
|
|
QEMU_CAPS_USB_STORAGE_REMOVABLE = 156, /* usb-storage.removable */
|
|
QEMU_CAPS_DEVICE_VIRTIO_MMIO = 157, /* -device virtio-mmio */
|
|
QEMU_CAPS_DEVICE_ICH9_INTEL_HDA = 158, /* -device ich9-intel-hda */
|
|
+ QEMU_CAPS_KVM_PIT_TICK_POLICY = 159, /* kvm-pit.lost_tick_policy */
|
|
|
|
QEMU_CAPS_LAST, /* this must always be the last item */
|
|
};
|
|
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
|
|
index e3c2d0c..38fbd45 100644
|
|
--- a/src/qemu/qemu_command.c
|
|
+++ b/src/qemu/qemu_command.c
|
|
@@ -7968,11 +7968,15 @@ qemuBuildCommandLine(virConnectPtr conn,
|
|
case VIR_DOMAIN_TIMER_TICKPOLICY_DELAY:
|
|
/* delay is the default if we don't have kernel
|
|
(-no-kvm-pit), otherwise, the default is catchup. */
|
|
- if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_NO_KVM_PIT))
|
|
+ if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM_PIT_TICK_POLICY))
|
|
+ virCommandAddArgList(cmd, "-global",
|
|
+ "kvm-pit.lost_tick_policy=discard", NULL);
|
|
+ else if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_NO_KVM_PIT))
|
|
virCommandAddArg(cmd, "-no-kvm-pit-reinjection");
|
|
break;
|
|
case VIR_DOMAIN_TIMER_TICKPOLICY_CATCHUP:
|
|
- if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_NO_KVM_PIT)) {
|
|
+ if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_NO_KVM_PIT) ||
|
|
+ virQEMUCapsGet(qemuCaps, QEMU_CAPS_KVM_PIT_TICK_POLICY)) {
|
|
/* do nothing - this is default for kvm-pit */
|
|
} else if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_TDF)) {
|
|
/* -tdf switches to 'catchup' with userspace pit. */
|
|
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.args b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.args
|
|
new file mode 100644
|
|
index 0000000..ca5823f
|
|
--- /dev/null
|
|
+++ b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.args
|
|
@@ -0,0 +1,5 @@
|
|
+LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test QEMU_AUDIO_DRV=none \
|
|
+/usr/bin/qemu -S -M pc -m 214 -smp 2 -nographic \
|
|
+-monitor unix:/tmp/test-monitor,server,nowait \
|
|
+-no-kvm-pit-reinjection -no-acpi -boot c -usb -hda /dev/HostVG/QEMUGuest1 \
|
|
+-net none -serial none -parallel none
|
|
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.xml b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.xml
|
|
new file mode 100644
|
|
index 0000000..7835a1b
|
|
--- /dev/null
|
|
+++ b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-delay.xml
|
|
@@ -0,0 +1,29 @@
|
|
+<domain type='qemu'>
|
|
+ <name>QEMUGuest1</name>
|
|
+ <uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
|
+ <memory unit='KiB'>219136</memory>
|
|
+ <currentMemory unit='KiB'>219136</currentMemory>
|
|
+ <vcpu placement='static'>2</vcpu>
|
|
+ <os>
|
|
+ <type arch='i686' machine='pc'>hvm</type>
|
|
+ <boot dev='hd'/>
|
|
+ </os>
|
|
+ <clock offset='utc'>
|
|
+ <timer name='pit' tickpolicy='delay'/>
|
|
+ </clock>
|
|
+ <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'/>
|
|
+ <controller type='pci' index='0' model='pci-root'/>
|
|
+ <memballoon model='virtio'/>
|
|
+ </devices>
|
|
+</domain>
|
|
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.args b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.args
|
|
new file mode 100644
|
|
index 0000000..f03840f
|
|
--- /dev/null
|
|
+++ b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.args
|
|
@@ -0,0 +1,5 @@
|
|
+LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test QEMU_AUDIO_DRV=none \
|
|
+/usr/bin/qemu -S -M pc -m 214 -smp 2 -nographic \
|
|
+-monitor unix:/tmp/test-monitor,server,nowait \
|
|
+-global kvm-pit.lost_tick_policy=discard -no-acpi -boot c -usb \
|
|
+-hda /dev/HostVG/QEMUGuest1 -net none -serial none -parallel none
|
|
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.xml b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.xml
|
|
new file mode 100644
|
|
index 0000000..7835a1b
|
|
--- /dev/null
|
|
+++ b/tests/qemuxml2argvdata/qemuxml2argv-kvm-pit-device.xml
|
|
@@ -0,0 +1,29 @@
|
|
+<domain type='qemu'>
|
|
+ <name>QEMUGuest1</name>
|
|
+ <uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
|
+ <memory unit='KiB'>219136</memory>
|
|
+ <currentMemory unit='KiB'>219136</currentMemory>
|
|
+ <vcpu placement='static'>2</vcpu>
|
|
+ <os>
|
|
+ <type arch='i686' machine='pc'>hvm</type>
|
|
+ <boot dev='hd'/>
|
|
+ </os>
|
|
+ <clock offset='utc'>
|
|
+ <timer name='pit' tickpolicy='delay'/>
|
|
+ </clock>
|
|
+ <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'/>
|
|
+ <controller type='pci' index='0' model='pci-root'/>
|
|
+ <memballoon model='virtio'/>
|
|
+ </devices>
|
|
+</domain>
|
|
diff --git a/tests/qemuxml2argvtest.c b/tests/qemuxml2argvtest.c
|
|
index d23f545..15e21be 100644
|
|
--- a/tests/qemuxml2argvtest.c
|
|
+++ b/tests/qemuxml2argvtest.c
|
|
@@ -1083,6 +1083,11 @@ mymain(void)
|
|
QEMU_CAPS_DRIVE, QEMU_CAPS_DEVICE_VIRTIO_MMIO,
|
|
QEMU_CAPS_DEVICE_VIRTIO_RNG, QEMU_CAPS_OBJECT_RNG_RANDOM);
|
|
|
|
+ DO_TEST("kvm-pit-device", QEMU_CAPS_KVM_PIT_TICK_POLICY);
|
|
+ DO_TEST("kvm-pit-delay", QEMU_CAPS_NO_KVM_PIT);
|
|
+ DO_TEST("kvm-pit-device", QEMU_CAPS_NO_KVM_PIT,
|
|
+ QEMU_CAPS_KVM_PIT_TICK_POLICY);
|
|
+
|
|
virObjectUnref(driver.config);
|
|
virObjectUnref(driver.caps);
|
|
virObjectUnref(driver.xmlopt);
|
|
--
|
|
1.8.4.2
|
|
|