]> git.ipfire.org Git - people/ms/u-boot.git/blame - lib/efi_loader/efi_smbios.c
ARM: Kconfig: Move TI_SECURE_DEVICE to a common area
[people/ms/u-boot.git] / lib / efi_loader / efi_smbios.c
CommitLineData
e663b350
AG
1/*
2 * EFI application tables support
3 *
4 * Copyright (c) 2016 Alexander Graf
5 *
6 * SPDX-License-Identifier: GPL-2.0+
7 */
8
9#include <common.h>
10#include <efi_loader.h>
11#include <inttypes.h>
12#include <smbios.h>
13
14static const efi_guid_t smbios_guid = SMBIOS_TABLE_GUID;
15
16void efi_smbios_register(void)
17{
18 /* Map within the low 32 bits, to allow for 32bit SMBIOS tables */
19 uint64_t dmi = 0xffffffff;
20 /* Reserve 4kb for SMBIOS */
21 uint64_t pages = 1;
22 int memtype = EFI_RUNTIME_SERVICES_DATA;
23
24 if (efi_allocate_pages(1, memtype, pages, &dmi) != EFI_SUCCESS)
25 return;
26
27 /* Generate SMBIOS tables */
28 write_smbios_table(dmi);
29
30 /* And expose them to our EFI payload */
31 efi_install_configuration_table(&smbios_guid, (void*)(uintptr_t)dmi);
32}