]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
qemu-capabilities: Fix query-cpu-model-expansion on s390 with older kernel
authorCollin L. Walling <walling@linux.vnet.ibm.com>
Thu, 12 Jan 2017 16:18:11 +0000 (11:18 -0500)
committerJiri Denemark <jdenemar@redhat.com>
Fri, 13 Jan 2017 15:55:58 +0000 (16:55 +0100)
When running on s390 with a kernel that does not support cpu model checking and
with a Qemu new enough to support query-cpu-model-expansion, the gathering of qemu
capabilities will fail. Qemu responds to the query-cpu-model-expansion qmp
command with an error because the needed kernel ioct does not exist. When this
happens a guest cannot even be defined due to missing qemu capabilities data.

This patch fixes the problem by silently ignoring generic errors stemming from
calls to query-cpu-model-expansion.

Reported-by: Farhan Ali <alifm@linux.vnet.ibm.com>
Signed-off-by: Collin L. Walling <walling@linux.vnet.ibm.com>
Signed-off-by: Jason J. Herne <jjherne@linux.vnet.ibm.com>
src/qemu/qemu_monitor_json.c

index 3afd56f3860341a14550a1a29720300940be94c3..5e057997c370adae0f54676573c71bc01d80f0c8 100644 (file)
@@ -5032,6 +5032,15 @@ qemuMonitorJSONGetCPUModelExpansion(qemuMonitorPtr mon,
     if (qemuMonitorJSONCommand(mon, cmd, &reply) < 0)
         goto cleanup;
 
+    /* Even though query-cpu-model-expansion is advertised by query-commands it
+     * may just return GenericError if it is not implemented for the requested
+     * guest architecture or it is not supported in the host environment.
+     */
+    if (qemuMonitorJSONHasError(reply, "GenericError")) {
+        ret = 0;
+        goto cleanup;
+    }
+
     if (qemuMonitorJSONCheckError(cmd, reply) < 0)
         goto cleanup;