From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:50861) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1WQ3MQ-0000P6-53 for qemu-devel@nongnu.org; Tue, 18 Mar 2014 19:23:59 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1WQ3MK-0000X6-G8 for qemu-devel@nongnu.org; Tue, 18 Mar 2014 19:23:54 -0400 Received: from mail-qc0-x22b.google.com ([2607:f8b0:400d:c01::22b]:38856) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1WQ3MK-0000Wy-Cd for qemu-devel@nongnu.org; Tue, 18 Mar 2014 19:23:48 -0400 Received: by mail-qc0-f171.google.com with SMTP id c9so2956802qcz.16 for ; Tue, 18 Mar 2014 16:23:48 -0700 (PDT) From: "Gabriel L. Somlo" Date: Tue, 18 Mar 2014 19:23:27 -0400 Message-Id: <1395185009-26532-11-git-send-email-somlo@cmu.edu> In-Reply-To: <1395185009-26532-1-git-send-email-somlo@cmu.edu> References: <1395185009-26532-1-git-send-email-somlo@cmu.edu> Subject: [Qemu-devel] [v4 PATCH 10/12] SMBIOS: Build full tables for type 32 and 127 List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: alex.williamson@redhat.com, agraf@suse.de, armbru@redhat.com, gsomlo@gmail.com, kevin@koconnor.net, kraxel@redhat.com, imammedo@redhat.com, lersek@redhat.com Build full smbios type 32 (system boot info) and 127 (end-of-table) tables, and make them available via fw_cfg. Signed-off-by: Gabriel Somlo --- hw/i386/smbios.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/hw/i386/smbios.c b/hw/i386/smbios.c index 6510ff3..b1f1d46 100644 --- a/hw/i386/smbios.c +++ b/hw/i386/smbios.c @@ -615,6 +615,22 @@ static void smbios_build_type_20_table(unsigned instance, SMBIOS_BUILD_TABLE_POST; } +static void smbios_build_type_32_table(void) +{ + SMBIOS_BUILD_TABLE_PRE(32, 0x2000, true); /* required */ + + memset(t->reserved, 0, 6); + t->boot_status = 0; /* No errors detected */ + + SMBIOS_BUILD_TABLE_POST; +} + +static void smbios_build_type_127_table(void) +{ + SMBIOS_BUILD_TABLE_PRE(127, 0x7F00, true); /* required */ + SMBIOS_BUILD_TABLE_POST; +} + #define SMBIOS_SET_DEFAULT(field, value) \ if (!field) { \ field = value; \ @@ -754,6 +770,9 @@ uint8_t *smbios_get_table(size_t *length) } } + smbios_build_type_32_table(); + smbios_build_type_127_table(); + smbios_validate_table(); smbios_immutable = true; } -- 1.8.5.3