]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
Do not format CPU features without a model
authorJán Tomko <jtomko@redhat.com>
Fri, 5 Dec 2014 11:32:18 +0000 (12:32 +0100)
committerCole Robinson <crobinso@redhat.com>
Tue, 28 Apr 2015 00:02:02 +0000 (20:02 -0400)
For host-passthrough CPU we don't honor the CPU
features specified in the XML, but we allow
outputting them via the UPDATE_CPU flag for dumpxml,
this gives user a rough idea of what features the CPU
might have.

After restoring a managedsave'd domain, the features
might end up in the live status XML (in /var/run) without
the model. This XML cannot be parsed by the daemon after
restart and the domain might disappear.

This fix skips formatting the features for HOST_PASSTHROUGH
when UPDATE_CPU is not specified, so the newly restored domains
and newly created snapshots won't be affected.

Note: this doesn't fix existing snapshots or already restored
running domains.

https://bugzilla.redhat.com/show_bug.cgi?id=1030793
https://bugzilla.redhat.com/show_bug.cgi?id=1151885
(cherry picked from commit dd324bb2703b9cf619c521b2a04f186cd9734f0a)

src/conf/cpu_conf.c

index 9b7fbb080b0104dea588eb29590a31a4e8d96986..5f447498b794a9bd1bf40a721d9b0616f9f27650 100644 (file)
@@ -666,7 +666,7 @@ virCPUDefFormatBuf(virBufferPtr buf,
         virBufferAddLit(buf, "/>\n");
     }
 
-    for (i = 0; i < def->nfeatures; i++) {
+    for (i = 0; formatModel && i < def->nfeatures; i++) {
         virCPUFeatureDefPtr feature = def->features + i;
 
         if (!feature->name) {