render / rpms / libvirt

Forked from rpms/libvirt 5 months ago
Clone
Pablo Greco 40546a
From 2d8d4379690e55d8d9a0b194ddef33d073154c7b Mon Sep 17 00:00:00 2001
Pablo Greco 40546a
Message-Id: <2d8d4379690e55d8d9a0b194ddef33d073154c7b@dist-git>
Pablo Greco 40546a
From: Jiri Denemark <jdenemar@redhat.com>
Pablo Greco 40546a
Date: Fri, 21 Jun 2019 09:25:03 +0200
Pablo Greco 40546a
Subject: [PATCH] qemu_capabilities: Inroduce virQEMUCapsGetCPUModelX86Data
Pablo Greco 40546a
MIME-Version: 1.0
Pablo Greco 40546a
Content-Type: text/plain; charset=UTF-8
Pablo Greco 40546a
Content-Transfer-Encoding: 8bit
Pablo Greco 40546a
Pablo Greco 40546a
The code for transforming qemuMonitorCPUModelInfo data from QEMU into
Pablo Greco 40546a
virCPUDefPtr consumable by virCPU* APIs was hidden inside
Pablo Greco 40546a
virQEMUCapsInitCPUModelX86. This patch moves it into a new function to
Pablo Greco 40546a
make it usable in tests.
Pablo Greco 40546a
Pablo Greco 40546a
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Pablo Greco 40546a
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Pablo Greco 40546a
(cherry picked from commit 30e4faac2f3e72aec29be9963d7a5394153e812f)
Pablo Greco 40546a
Pablo Greco 40546a
https://bugzilla.redhat.com/show_bug.cgi?id=1686895
Pablo Greco 40546a
Pablo Greco 40546a
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Pablo Greco 40546a
Message-Id: <e91c6c1e8de59a6cc151154f7c2a9eae79249fa5.1561068591.git.jdenemar@redhat.com>
Pablo Greco 40546a
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Pablo Greco 40546a
---
Pablo Greco 40546a
 src/qemu/qemu_capabilities.c | 50 ++++++++++++++++++++++++------------
Pablo Greco 40546a
 src/qemu/qemu_capspriv.h     |  4 +++
Pablo Greco 40546a
 2 files changed, 38 insertions(+), 16 deletions(-)
Pablo Greco 40546a
Pablo Greco 40546a
diff --git a/src/qemu/qemu_capabilities.c b/src/qemu/qemu_capabilities.c
Pablo Greco 40546a
index 5539d168cd..5a7160d02e 100644
Pablo Greco 40546a
--- a/src/qemu/qemu_capabilities.c
Pablo Greco 40546a
+++ b/src/qemu/qemu_capabilities.c
Pablo Greco 40546a
@@ -2812,28 +2812,17 @@ virQEMUCapsInitCPUModelS390(virQEMUCapsPtr qemuCaps,
Pablo Greco 40546a
 }
Pablo Greco 40546a
 
Pablo Greco 40546a
 
Pablo Greco 40546a
-/**
Pablo Greco 40546a
- * Returns  0 when host CPU model provided by QEMU was filled in qemuCaps,
Pablo Greco 40546a
- *          1 when the caller should fall back to using virCapsPtr->host.cpu,
Pablo Greco 40546a
- *         -1 on error.
Pablo Greco 40546a
- */
Pablo Greco 40546a
-static int
Pablo Greco 40546a
-virQEMUCapsInitCPUModelX86(virQEMUCapsPtr qemuCaps,
Pablo Greco 40546a
-                           virDomainVirtType type,
Pablo Greco 40546a
-                           qemuMonitorCPUModelInfoPtr model,
Pablo Greco 40546a
-                           virCPUDefPtr cpu,
Pablo Greco 40546a
-                           bool migratable)
Pablo Greco 40546a
+virCPUDataPtr
Pablo Greco 40546a
+virQEMUCapsGetCPUModelX86Data(qemuMonitorCPUModelInfoPtr model,
Pablo Greco 40546a
+                              bool migratable)
Pablo Greco 40546a
 {
Pablo Greco 40546a
-    virCPUDataPtr data = NULL;
Pablo Greco 40546a
     unsigned long long sigFamily = 0;
Pablo Greco 40546a
     unsigned long long sigModel = 0;
Pablo Greco 40546a
     unsigned long long sigStepping = 0;
Pablo Greco 40546a
-    int ret = -1;
Pablo Greco 40546a
+    virCPUDataPtr data = NULL;
Pablo Greco 40546a
+    virCPUDataPtr ret = NULL;
Pablo Greco 40546a
     size_t i;
Pablo Greco 40546a
 
Pablo Greco 40546a
-    if (!model)
Pablo Greco 40546a
-        return 1;
Pablo Greco 40546a
-
Pablo Greco 40546a
     if (!(data = virCPUDataNew(VIR_ARCH_X86_64)))
Pablo Greco 40546a
         goto cleanup;
Pablo Greco 40546a
 
Pablo Greco 40546a
@@ -2874,6 +2863,35 @@ virQEMUCapsInitCPUModelX86(virQEMUCapsPtr qemuCaps,
Pablo Greco 40546a
     if (virCPUx86DataSetSignature(data, sigFamily, sigModel, sigStepping) < 0)
Pablo Greco 40546a
         goto cleanup;
Pablo Greco 40546a
 
Pablo Greco 40546a
+    VIR_STEAL_PTR(ret, data);
Pablo Greco 40546a
+
Pablo Greco 40546a
+ cleanup:
Pablo Greco 40546a
+    virCPUDataFree(data);
Pablo Greco 40546a
+    return ret;
Pablo Greco 40546a
+}
Pablo Greco 40546a
+
Pablo Greco 40546a
+
Pablo Greco 40546a
+/**
Pablo Greco 40546a
+ * Returns  0 when host CPU model provided by QEMU was filled in qemuCaps,
Pablo Greco 40546a
+ *          1 when the caller should fall back to using virCapsPtr->host.cpu,
Pablo Greco 40546a
+ *         -1 on error.
Pablo Greco 40546a
+ */
Pablo Greco 40546a
+static int
Pablo Greco 40546a
+virQEMUCapsInitCPUModelX86(virQEMUCapsPtr qemuCaps,
Pablo Greco 40546a
+                           virDomainVirtType type,
Pablo Greco 40546a
+                           qemuMonitorCPUModelInfoPtr model,
Pablo Greco 40546a
+                           virCPUDefPtr cpu,
Pablo Greco 40546a
+                           bool migratable)
Pablo Greco 40546a
+{
Pablo Greco 40546a
+    virCPUDataPtr data = NULL;
Pablo Greco 40546a
+    int ret = -1;
Pablo Greco 40546a
+
Pablo Greco 40546a
+    if (!model)
Pablo Greco 40546a
+        return 1;
Pablo Greco 40546a
+
Pablo Greco 40546a
+    if (!(data = virQEMUCapsGetCPUModelX86Data(model, migratable)))
Pablo Greco 40546a
+        goto cleanup;
Pablo Greco 40546a
+
Pablo Greco 40546a
     if (cpuDecode(cpu, data, virQEMUCapsGetCPUDefinitions(qemuCaps, type)) < 0)
Pablo Greco 40546a
         goto cleanup;
Pablo Greco 40546a
 
Pablo Greco 40546a
diff --git a/src/qemu/qemu_capspriv.h b/src/qemu/qemu_capspriv.h
Pablo Greco 40546a
index cb5e0dd9a9..70cdbbc504 100644
Pablo Greco 40546a
--- a/src/qemu/qemu_capspriv.h
Pablo Greco 40546a
+++ b/src/qemu/qemu_capspriv.h
Pablo Greco 40546a
@@ -80,6 +80,10 @@ virQEMUCapsSetCPUModelInfo(virQEMUCapsPtr qemuCaps,
Pablo Greco 40546a
                            virDomainVirtType type,
Pablo Greco 40546a
                            qemuMonitorCPUModelInfoPtr modelInfo);
Pablo Greco 40546a
 
Pablo Greco 40546a
+virCPUDataPtr
Pablo Greco 40546a
+virQEMUCapsGetCPUModelX86Data(qemuMonitorCPUModelInfoPtr model,
Pablo Greco 40546a
+                              bool migratable);
Pablo Greco 40546a
+
Pablo Greco 40546a
 virCPUDefPtr
Pablo Greco 40546a
 virQEMUCapsProbeHostCPUForEmulator(virArch hostArch,
Pablo Greco 40546a
                                    virQEMUCapsPtr qemuCaps,
Pablo Greco 40546a
-- 
Pablo Greco 40546a
2.22.0
Pablo Greco 40546a