qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [v2 PATCH 12/13] SMBIOS: Build full type 20 tables


From: Gabriel L. Somlo
Subject: [Qemu-devel] [v2 PATCH 12/13] SMBIOS: Build full type 20 tables
Date: Tue, 11 Mar 2014 11:16:28 -0400

From: "Gabriel L. Somlo" <address@hidden>

Build full smbios type 20 (memory device mapped address) tables,
and make them available via fw_cfg.

Signed-off-by: Gabriel Somlo <address@hidden>
---
 hw/i386/smbios.c | 29 +++++++++++++++++++++++++++++
 1 file changed, 29 insertions(+)

diff --git a/hw/i386/smbios.c b/hw/i386/smbios.c
index c9cd295..9cf29d3 100644
--- a/hw/i386/smbios.c
+++ b/hw/i386/smbios.c
@@ -566,6 +566,23 @@ static void smbios_build_type_19_table(unsigned instance,
     SMBIOS_BUILD_TABLE_POST;
 }
 
+static void smbios_build_type_20_table(unsigned instance,
+                                       unsigned dev_hndl, unsigned array_hndl,
+                                       unsigned start_kb, unsigned size_kb)
+{
+    SMBIOS_BUILD_TABLE_PRE(20, 0x1400 + instance, true); /* required */
+
+    t->starting_address = start_kb;
+    t->ending_address = start_kb + size_kb - 1;
+    t->memory_device_handle = 0x1100 + dev_hndl; /* Type 17 (Memory Device) */
+    t->memory_array_mapped_address_handle = 0x1300 + array_hndl; /* Type 19 */
+    t->partition_row_position = 1; /* hardcoded in SeaBIOS */
+    t->interleave_position = 0; /* Not interleaved */
+    t->interleaved_data_depth = 0; /* Not interleaved */
+
+    SMBIOS_BUILD_TABLE_POST;
+}
+
 #define SMBIOS_SET_DEFAULT(field, value)                                  \
     if (!field) {                                                         \
         field = value;                                                    \
@@ -629,8 +646,20 @@ uint8_t *smbios_get_table(size_t *length)
             smbios_build_type_17_table(i, size_mb);
         }
         smbios_build_type_19_table(0, 0, smbios_below_4g_ram >> 10);
+        smbios_build_type_20_table(0, 0, 0, 0, smbios_below_4g_ram >> 10);
         if (smbios_above_4g_ram) {
+            uint32_t start_mb = 4096, size_mb, j;
             smbios_build_type_19_table(1, 4 << 20, smbios_above_4g_ram >> 10);
+            for (j = 1, i = 0; i < memdev_count; i++, j++) {
+                size_mb = (i == memdev_count - 1) ?
+                          ((ram_size_mb - 1) & 0x3FFF) + 1 : 0x4000;
+                if (i == 0) {
+                    size_mb -= smbios_below_4g_ram >> 20;
+                }
+                smbios_build_type_20_table(j, i, 1,
+                                           start_mb << 10, size_mb << 10);
+                start_mb += size_mb;
+            }
         }
         smbios_validate_table();
         smbios_immutable = true;
-- 
1.8.1.4




reply via email to

[Prev in Thread] Current Thread [Next in Thread]