efi_loader: generated SMBIOS table below 4 GiB
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Mon, 20 Nov 2023 22:25:58 +0000 (23:25 +0100)
committerTom Rini <trini@konsulko.com>
Mon, 4 Dec 2023 18:42:40 +0000 (13:42 -0500)
We currently use an outdated format 32-bit format for SMBIOS tables.
So we must allocate SMBIOS tables below 4 GiB.

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Reviewed-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
Tested-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
lib/efi_loader/efi_smbios.c

index 48446f654d9bc3cf318d81115e6faf9e0ff37af3..0fbf51b98d0d726efc0c19f76eee9f4b1c3598d0 100644 (file)
@@ -49,25 +49,27 @@ efi_status_t efi_smbios_register(void)
 
 static int install_smbios_table(void)
 {
-       ulong addr;
-       void *buf;
+       u64 addr;
+       efi_status_t ret;
 
        if (!IS_ENABLED(CONFIG_GENERATE_SMBIOS_TABLE) || IS_ENABLED(CONFIG_X86))
                return 0;
 
-       /* Align the table to a 4KB boundary to keep EFI happy */
-       buf = memalign(SZ_4K, TABLE_SIZE);
-       if (!buf)
+       addr = SZ_4G;
+       ret = efi_allocate_pages(EFI_ALLOCATE_MAX_ADDRESS,
+                                EFI_RUNTIME_SERVICES_DATA,
+                                efi_size_in_pages(TABLE_SIZE), &addr);
+       if (ret != EFI_SUCCESS)
                return log_msg_ret("mem", -ENOMEM);
 
-       addr = map_to_sysmem(buf);
+       addr = map_to_sysmem((void *)(uintptr_t)addr);
        if (!write_smbios_table(addr)) {
                log_err("Failed to write SMBIOS table\n");
                return log_msg_ret("smbios", -EINVAL);
        }
 
        /* Make a note of where we put it */
-       log_debug("SMBIOS tables written to %lx\n", addr);
+       log_debug("SMBIOS tables written to %llx\n", addr);
        gd->arch.smbios_start = addr;
 
        return 0;