@@ -33,6 +33,15 @@ menu "Architecture Features"
source "arch/Kconfig"
+config ACPI
+ bool
+ prompt "ACPI (Advanced Configuration and Power Interface) Support" if EXPERT = "y"
+ depends on ARM_64
+ ---help---
+
+ Advanced Configuration and Power Interface (ACPI) support for Xen is
+ an alternative to device tree on ARM64.
+
# Select HAS_GICV3 if GICv3 is supported
config HAS_GICV3
bool
@@ -10,14 +10,16 @@ DEFINE_XEN_GUEST_HANDLE(CHAR16);
#ifndef COMPAT
-#ifdef CONFIG_ARM /* Disabled until runtime services implemented */
-const bool_t efi_enabled = 0;
-#else
+/*
+ * Currently runtime services are not implemented on ARM. To boot Xen with ACPI,
+ * set efi_enabled to 1, so that Xen can get the ACPI root pointer from EFI.
+ */
+const bool_t efi_enabled = 1;
+
+#ifndef CONFIG_ARM
# include <asm/i387.h>
# include <asm/xstate.h>
# include <public/platform.h>
-
-const bool_t efi_enabled = 1;
#endif
unsigned int __read_mostly efi_num_ct;
@@ -31,6 +31,10 @@
#define CONFIG_ARM_L1_CACHE_SHIFT 7 /* XXX */
+#ifdef CONFIG_ACPI
+#define CONFIG_ACPI_BOOT 1
+#endif
+
#define CONFIG_SMP 1
#define CONFIG_IRQ_HAS_MULTIPLE_ACTION 1