|
|
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 |
|