blob: 932f7582ec619b062567b3e7051c2ebb4a0662d2 [file] [log] [blame]
Tom Rini70df9d62018-05-07 17:02:21 -04001// SPDX-License-Identifier: GPL-2.0+
Alexander Graf66f96e12016-08-19 01:23:29 +02002/*
3 * EFI application tables support
4 *
5 * Copyright (c) 2016 Alexander Graf
Alexander Graf66f96e12016-08-19 01:23:29 +02006 */
7
8#include <common.h>
9#include <efi_loader.h>
10#include <inttypes.h>
11#include <smbios.h>
12
13static const efi_guid_t smbios_guid = SMBIOS_TABLE_GUID;
14
Heinrich Schuchardt7a369c42018-03-03 15:28:54 +010015/*
16 * Install the SMBIOS table as a configuration table.
17 *
18 * @return status code
19 */
20efi_status_t efi_smbios_register(void)
Alexander Graf66f96e12016-08-19 01:23:29 +020021{
22 /* Map within the low 32 bits, to allow for 32bit SMBIOS tables */
Heinrich Schuchardt7a369c42018-03-03 15:28:54 +010023 u64 dmi = U32_MAX;
24 efi_status_t ret;
Alexander Graf66f96e12016-08-19 01:23:29 +020025
Heinrich Schuchardt7a369c42018-03-03 15:28:54 +010026 /* Reserve 4kiB page for SMBIOS */
27 ret = efi_allocate_pages(EFI_ALLOCATE_MAX_ADDRESS,
28 EFI_RUNTIME_SERVICES_DATA, 1, &dmi);
Alexander Graf17990072018-06-18 17:23:00 +020029
30 if (ret != EFI_SUCCESS) {
31 /* Could not find space in lowmem, use highmem instead */
32 ret = efi_allocate_pages(EFI_ALLOCATE_ANY_PAGES,
33 EFI_RUNTIME_SERVICES_DATA, 1, &dmi);
34
35 if (ret != EFI_SUCCESS)
36 return ret;
37 }
Alexander Graf66f96e12016-08-19 01:23:29 +020038
Simon Glass2e2858f2018-05-16 09:42:19 -060039 /*
40 * Generate SMBIOS tables - we know that efi_allocate_pages() returns
41 * a 4k-aligned address, so it is safe to assume that
42 * write_smbios_table() will write the table at that address.
43 */
44 assert(!(dmi & 0xf));
Alexander Graf66f96e12016-08-19 01:23:29 +020045 write_smbios_table(dmi);
46
47 /* And expose them to our EFI payload */
Heinrich Schuchardt7a369c42018-03-03 15:28:54 +010048 return efi_install_configuration_table(&smbios_guid,
49 (void *)(uintptr_t)dmi);
Alexander Graf66f96e12016-08-19 01:23:29 +020050}