]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
acpi: enable writing ACPI tables on QEMU
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Tue, 19 Dec 2023 15:04:04 +0000 (16:04 +0100)
committerSimon Glass <sjg@chromium.org>
Sun, 7 Jan 2024 20:49:15 +0000 (13:49 -0700)
Invoke write_acpi_tables() via EVT_LAST_STAGE_INIT on QEMU except on X86.
X86 calls write_acpi_tables() in write_tables().

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
drivers/misc/qfw_acpi.c

index 6e14b2a50427968b4f9f1fb52bee1dd847ae22e4..7ffed1e8c02d06b8534a2450382cdd5755104255 100644 (file)
@@ -9,9 +9,11 @@
 #include <acpi/acpi_table.h>
 #include <errno.h>
 #include <malloc.h>
+#include <mapmem.h>
 #include <qfw.h>
 #include <tables_csum.h>
 #include <stdio.h>
+#include <linux/sizes.h>
 #include <asm/byteorder.h>
 #include <asm/global_data.h>
 
@@ -254,3 +256,26 @@ ulong acpi_get_rsdp_addr(void)
        file = qfw_find_file(dev, "etc/acpi/rsdp");
        return file->addr;
 }
+
+#ifndef CONFIG_X86
+static int evt_write_acpi_tables(void)
+{
+       ulong addr, end;
+       void *ptr;
+
+       /* Reserve 64K for ACPI tables, aligned to a 4K boundary */
+       ptr = memalign(SZ_4K, SZ_64K);
+       if (!ptr)
+               return -ENOMEM;
+       addr = map_to_sysmem(ptr);
+
+       /* Generate ACPI tables */
+       end = write_acpi_tables(addr);
+       gd->arch.table_start = addr;
+       gd->arch.table_end = addr;
+
+       return 0;
+}
+
+EVENT_SPY_SIMPLE(EVT_LAST_STAGE_INIT, evt_write_acpi_tables);
+#endif