b971b8
From 6fa7baf5345b053e8215b34f721316f6f72f1cf3 Mon Sep 17 00:00:00 2001
b971b8
Message-Id: <6fa7baf5345b053e8215b34f721316f6f72f1cf3@dist-git>
b971b8
From: Jiri Denemark <jdenemar@redhat.com>
b971b8
Date: Tue, 26 May 2020 10:59:00 +0200
b971b8
Subject: [PATCH] cpu_x86: Use glib allocation for virCPU{, x86}Data
b971b8
MIME-Version: 1.0
b971b8
Content-Type: text/plain; charset=UTF-8
b971b8
Content-Transfer-Encoding: 8bit
b971b8
b971b8
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
b971b8
Reviewed-by: Ján Tomko <jtomko@redhat.com>
b971b8
(cherry picked from commit 800868583012e20fb60eb4be9fb1ccc018677006)
b971b8
b971b8
https://bugzilla.redhat.com/show_bug.cgi?id=1840010
b971b8
b971b8
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
b971b8
Message-Id: <dbb07df3c1ad3f47f21caa1b9555bd37db037694.1590483392.git.jdenemar@redhat.com>
b971b8
Reviewed-by: Ján Tomko <jtomko@redhat.com>
b971b8
---
b971b8
 src/cpu/cpu_x86.c | 45 ++++++++++++++++++++++-----------------------
b971b8
 1 file changed, 22 insertions(+), 23 deletions(-)
b971b8
b971b8
diff --git a/src/cpu/cpu_x86.c b/src/cpu/cpu_x86.c
b971b8
index 1b388ec1b2..4d82d85746 100644
b971b8
--- a/src/cpu/cpu_x86.c
b971b8
+++ b/src/cpu/cpu_x86.c
b971b8
@@ -468,8 +468,9 @@ virCPUx86DataClear(virCPUx86Data *data)
b971b8
     if (!data)
b971b8
         return;
b971b8
 
b971b8
-    VIR_FREE(data->items);
b971b8
+    g_free(data->items);
b971b8
 }
b971b8
+G_DEFINE_AUTO_CLEANUP_CLEAR_FUNC(virCPUx86Data, virCPUx86DataClear);
b971b8
 
b971b8
 
b971b8
 static void
b971b8
@@ -481,21 +482,19 @@ virCPUx86DataFree(virCPUDataPtr data)
b971b8
     virCPUx86DataClear(&data->data.x86);
b971b8
     VIR_FREE(data);
b971b8
 }
b971b8
+G_DEFINE_AUTOPTR_CLEANUP_FUNC(virCPUData, virCPUx86DataFree);
b971b8
 
b971b8
 
b971b8
-static int
b971b8
+static void
b971b8
 x86DataCopy(virCPUx86Data *dst, const virCPUx86Data *src)
b971b8
 {
b971b8
     size_t i;
b971b8
 
b971b8
-    if (VIR_ALLOC_N(dst->items, src->len) < 0)
b971b8
-        return -1;
b971b8
-
b971b8
+    dst->items = g_new0(virCPUx86DataItem, src->len);
b971b8
     dst->len = src->len;
b971b8
+
b971b8
     for (i = 0; i < src->len; i++)
b971b8
         dst->items[i] = src->items[i];
b971b8
-
b971b8
-    return 0;
b971b8
 }
b971b8
 
b971b8
 
b971b8
@@ -781,9 +780,8 @@ x86DataToCPU(const virCPUx86Data *data,
b971b8
 
b971b8
     cpu->model = g_strdup(model->name);
b971b8
 
b971b8
-    if (x86DataCopy(&copy, data) < 0 ||
b971b8
-        x86DataCopy(&modelData, &model->data) < 0)
b971b8
-        goto error;
b971b8
+    x86DataCopy(&copy, data);
b971b8
+    x86DataCopy(&modelData, &model->data);
b971b8
 
b971b8
     if ((vendor = x86DataToVendor(&copy, map)))
b971b8
         cpu->vendor = g_strdup(vendor->name);
b971b8
@@ -1183,11 +1181,11 @@ x86ModelCopy(virCPUx86ModelPtr model)
b971b8
 
b971b8
     copy->name = g_strdup(model->name);
b971b8
 
b971b8
-    if (x86ModelCopySignatures(copy, model) < 0 ||
b971b8
-        x86DataCopy(&copy->data, &model->data) < 0) {
b971b8
+    if (x86ModelCopySignatures(copy, model) < 0) {
b971b8
         x86ModelFree(copy);
b971b8
         return NULL;
b971b8
     }
b971b8
+    x86DataCopy(&copy->data, &model->data);
b971b8
 
b971b8
     copy->vendor = model->vendor;
b971b8
 
b971b8
@@ -1415,10 +1413,11 @@ x86ModelParseAncestor(virCPUx86ModelPtr model,
b971b8
     }
b971b8
 
b971b8
     model->vendor = ancestor->vendor;
b971b8
-    if (x86ModelCopySignatures(model, ancestor) < 0 ||
b971b8
-        x86DataCopy(&model->data, &ancestor->data) < 0)
b971b8
+    if (x86ModelCopySignatures(model, ancestor) < 0)
b971b8
         return -1;
b971b8
 
b971b8
+    x86DataCopy(&model->data, &ancestor->data);
b971b8
+
b971b8
     return 0;
b971b8
 }
b971b8
 
b971b8
@@ -1904,9 +1903,9 @@ x86Compute(virCPUDefPtr host,
b971b8
 
b971b8
         x86DataSubtract(&guest_model->data, &cpu_disable->data);
b971b8
 
b971b8
-        if (!(guestData = virCPUDataNew(arch)) ||
b971b8
-            x86DataCopy(&guestData->data.x86, &guest_model->data) < 0)
b971b8
+        if (!(guestData = virCPUDataNew(arch)))
b971b8
             goto error;
b971b8
+        x86DataCopy(&guestData->data.x86, &guest_model->data);
b971b8
 
b971b8
         *guest = guestData;
b971b8
     }
b971b8
@@ -2139,9 +2138,11 @@ x86Decode(virCPUDefPtr cpu,
b971b8
     ssize_t i;
b971b8
     int rc;
b971b8
 
b971b8
-    if (!cpuData || x86DataCopy(&data, cpuData) < 0)
b971b8
+    if (!cpuData)
b971b8
         return -1;
b971b8
 
b971b8
+    x86DataCopy(&data, cpuData);
b971b8
+
b971b8
     if (!(map = virCPUx86GetMap()))
b971b8
         goto cleanup;
b971b8
 
b971b8
@@ -3055,13 +3056,11 @@ virCPUx86UpdateLive(virCPUDefPtr cpu,
b971b8
         !(modelDisabled = x86ModelFromCPU(cpu, map, VIR_CPU_FEATURE_DISABLE)))
b971b8
         goto cleanup;
b971b8
 
b971b8
-    if (dataEnabled &&
b971b8
-        x86DataCopy(&enabled, &dataEnabled->data.x86) < 0)
b971b8
-        goto cleanup;
b971b8
+    if (dataEnabled)
b971b8
+        x86DataCopy(&enabled, &dataEnabled->data.x86);
b971b8
 
b971b8
-    if (dataDisabled &&
b971b8
-        x86DataCopy(&disabled, &dataDisabled->data.x86) < 0)
b971b8
-        goto cleanup;
b971b8
+    if (dataDisabled)
b971b8
+        x86DataCopy(&disabled, &dataDisabled->data.x86);
b971b8
 
b971b8
     for (i = 0; i < map->nfeatures; i++) {
b971b8
         virCPUx86FeaturePtr feature = map->features[i];
b971b8
-- 
b971b8
2.26.2
b971b8