9ae3a8
From 8a7a5d92f6d6e0980e9f4119cdab88fd6e7b83e3 Mon Sep 17 00:00:00 2001
9ae3a8
From: Markus Armbruster <armbru@redhat.com>
9ae3a8
Date: Wed, 6 Nov 2013 09:11:26 +0100
9ae3a8
Subject: [PATCH 24/29] smbios: Factor out smbios_maybe_add_str()
9ae3a8
9ae3a8
RH-Author: Markus Armbruster <armbru@redhat.com>
9ae3a8
Message-id: <1383386488-29789-8-git-send-email-armbru@redhat.com>
9ae3a8
Patchwork-id: 55248
9ae3a8
O-Subject: [PATCH 7.0 qemu-kvm 07/11] smbios: Factor out smbios_maybe_add_str()
9ae3a8
Bugzilla: 994490
9ae3a8
RH-Acked-by: Michael S. Tsirkin <mst@redhat.com>
9ae3a8
RH-Acked-by: Laszlo Ersek <lersek@redhat.com>
9ae3a8
RH-Acked-by: Miroslav Rezanina <mrezanin@redhat.com>
9ae3a8
9ae3a8
From: Markus Armbruster <armbru@redhat.com>
9ae3a8
9ae3a8
Signed-off-by: Markus Armbruster <armbru@redhat.com>
9ae3a8
Reviewed-by: Eric Blake <eblake@redhat.com>
9ae3a8
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
9ae3a8
(cherry picked from commit e26d3e734650640fabd7d95ace4f3a6f88725e0b)
9ae3a8
---
9ae3a8
 hw/i386/smbios.c | 61 +++++++++++++++++++++++---------------------------------
9ae3a8
 1 file changed, 25 insertions(+), 36 deletions(-)
9ae3a8
9ae3a8
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
9ae3a8
---
9ae3a8
 hw/i386/smbios.c |   61 ++++++++++++++++++++++-------------------------------
9ae3a8
 1 files changed, 25 insertions(+), 36 deletions(-)
9ae3a8
9ae3a8
diff --git a/hw/i386/smbios.c b/hw/i386/smbios.c
9ae3a8
index d2dba6c..d3f1ee6 100644
9ae3a8
--- a/hw/i386/smbios.c
9ae3a8
+++ b/hw/i386/smbios.c
9ae3a8
@@ -210,21 +210,22 @@ static void smbios_add_field(int type, int offset, const void *data, size_t len)
9ae3a8
             cpu_to_le16(le16_to_cpu(*(uint16_t *)smbios_entries) + 1);
9ae3a8
 }
9ae3a8
 
9ae3a8
-static void smbios_build_type_0_fields(void)
9ae3a8
+static void smbios_maybe_add_str(int type, int offset, const char *data)
9ae3a8
 {
9ae3a8
-    if (type0.vendor) {
9ae3a8
-        smbios_add_field(0, offsetof(struct smbios_type_0, vendor_str),
9ae3a8
-                         type0.vendor, strlen(type0.vendor) + 1);
9ae3a8
-    }
9ae3a8
-    if (type0.version) {
9ae3a8
-        smbios_add_field(0, offsetof(struct smbios_type_0, bios_version_str),
9ae3a8
-                         type0.version, strlen(type0.version) + 1);
9ae3a8
+    if (data) {
9ae3a8
+        smbios_add_field(type, offset, data, strlen(data) + 1);
9ae3a8
     }
9ae3a8
-    if (type0.date) {
9ae3a8
-        smbios_add_field(0, offsetof(struct smbios_type_0,
9ae3a8
+}
9ae3a8
+
9ae3a8
+static void smbios_build_type_0_fields(void)
9ae3a8
+{
9ae3a8
+    smbios_maybe_add_str(0, offsetof(struct smbios_type_0, vendor_str),
9ae3a8
+                         type0.vendor);
9ae3a8
+    smbios_maybe_add_str(0, offsetof(struct smbios_type_0, bios_version_str),
9ae3a8
+                         type0.version);
9ae3a8
+    smbios_maybe_add_str(0, offsetof(struct smbios_type_0,
9ae3a8
                                      bios_release_date_str),
9ae3a8
-                         type0.date, strlen(type0.date) + 1);
9ae3a8
-    }
9ae3a8
+                         type0.date);
9ae3a8
     if (type0.have_major_minor) {
9ae3a8
         smbios_add_field(0, offsetof(struct smbios_type_0,
9ae3a8
                                      system_bios_major_release),
9ae3a8
@@ -237,30 +238,18 @@ static void smbios_build_type_0_fields(void)
9ae3a8
 
9ae3a8
 static void smbios_build_type_1_fields(void)
9ae3a8
 {
9ae3a8
-    if (type1.manufacturer) {
9ae3a8
-        smbios_add_field(1, offsetof(struct smbios_type_1, manufacturer_str),
9ae3a8
-                         type1.manufacturer, strlen(type1.manufacturer) + 1);
9ae3a8
-    }
9ae3a8
-    if (type1.product) {
9ae3a8
-        smbios_add_field(1, offsetof(struct smbios_type_1, product_name_str),
9ae3a8
-                         type1.product, strlen(type1.product) + 1);
9ae3a8
-    }
9ae3a8
-    if (type1.version) {
9ae3a8
-        smbios_add_field(1, offsetof(struct smbios_type_1, version_str),
9ae3a8
-                         type1.version, strlen(type1.version) + 1);
9ae3a8
-    }
9ae3a8
-    if (type1.serial) {
9ae3a8
-        smbios_add_field(1, offsetof(struct smbios_type_1, serial_number_str),
9ae3a8
-                         type1.serial, strlen(type1.serial) + 1);
9ae3a8
-    }
9ae3a8
-    if (type1.sku) {
9ae3a8
-        smbios_add_field(1, offsetof(struct smbios_type_1, sku_number_str),
9ae3a8
-                         type1.sku, strlen(type1.sku) + 1);
9ae3a8
-    }
9ae3a8
-    if (type1.family) {
9ae3a8
-        smbios_add_field(1, offsetof(struct smbios_type_1, family_str),
9ae3a8
-                         type1.family, strlen(type1.family) + 1);
9ae3a8
-    }
9ae3a8
+    smbios_maybe_add_str(1, offsetof(struct smbios_type_1, manufacturer_str),
9ae3a8
+                         type1.manufacturer);
9ae3a8
+    smbios_maybe_add_str(1, offsetof(struct smbios_type_1, product_name_str),
9ae3a8
+                         type1.product);
9ae3a8
+    smbios_maybe_add_str(1, offsetof(struct smbios_type_1, version_str),
9ae3a8
+                         type1.version);
9ae3a8
+    smbios_maybe_add_str(1, offsetof(struct smbios_type_1, serial_number_str),
9ae3a8
+                         type1.serial);
9ae3a8
+    smbios_maybe_add_str(1, offsetof(struct smbios_type_1, sku_number_str),
9ae3a8
+                         type1.sku);
9ae3a8
+    smbios_maybe_add_str(1, offsetof(struct smbios_type_1, family_str),
9ae3a8
+                         type1.family);
9ae3a8
     if (qemu_uuid_set) {
9ae3a8
         smbios_add_field(1, offsetof(struct smbios_type_1, uuid),
9ae3a8
                          qemu_uuid, 16);
9ae3a8
-- 
9ae3a8
1.7.1
9ae3a8