From: Boris Ostrovsky Date: Tue, 20 Dec 2016 08:54:38 +0000 (+0100) Subject: acpi/x86: define ACPI IO registers for PVH guests X-Git-Tag: archive/raspbian/4.11.1-1+rpi1~1^2~66^2~3102 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=d6ac8e22c7c5525db1da79fd1d1f03ee6b557f0d;p=xen.git acpi/x86: define ACPI IO registers for PVH guests Define VCPU available map address (used by AML's PRSC method) and GPE0 CPU hotplug event number. Use these definitions in mk_dsdt instead hardcoded values. These definitions will later be used by both the hypervisor and the toolstack (initially for PVH guests only), thus they are placed in public headers. Signed-off-by: Boris Ostrovsky Reviewed-by: Jan Beulich --- diff --git a/tools/libacpi/mk_dsdt.c b/tools/libacpi/mk_dsdt.c index 639d21e6de..9421f3f993 100644 --- a/tools/libacpi/mk_dsdt.c +++ b/tools/libacpi/mk_dsdt.c @@ -18,6 +18,7 @@ #include #include #if defined(CONFIG_X86) +#include #include #elif defined(CONFIG_ARM_64) #include @@ -244,7 +245,8 @@ int main(int argc, char **argv) #endif /* Operation Region 'PRST': bitmask of online CPUs. */ - stmt("OperationRegion", "PRST, SystemIO, 0xaf00, 32"); + stmt("OperationRegion", "PRST, SystemIO, %#x, %d", + XEN_ACPI_CPU_MAP, XEN_ACPI_CPU_MAP_LEN); push_block("Field", "PRST, ByteAcc, NoLock, Preserve"); indent(); printf("PRS, %u\n", max_cpus); pop_block(); @@ -283,7 +285,8 @@ int main(int argc, char **argv) /* Define GPE control method. */ push_block("Scope", "\\_GPE"); push_block("Method", - dm_version == QEMU_XEN_TRADITIONAL ? "_L02" : "_E02"); + dm_version == QEMU_XEN_TRADITIONAL ? "_L%02d" : "_E%02d", + XEN_ACPI_GPE0_CPUHP_BIT); stmt("\\_SB.PRSC ()", NULL); pop_block(); pop_block(); diff --git a/tools/libacpi/static_tables.c b/tools/libacpi/static_tables.c index 13946aaef3..f3d859726a 100644 --- a/tools/libacpi/static_tables.c +++ b/tools/libacpi/static_tables.c @@ -31,6 +31,10 @@ struct acpi_20_facs Facs = { * Fixed ACPI Description Table (FADT). */ +/* + * These values must match register definitions in struct hvm_hw_acpi + * (in xen/include/public/arch-x86/hvm/save.h). + */ #define ACPI_PM1A_EVT_BLK_BIT_WIDTH 0x20 #define ACPI_PM1A_EVT_BLK_BIT_OFFSET 0x00 #define ACPI_PM1A_CNT_BLK_BIT_WIDTH 0x10 diff --git a/xen/include/public/arch-x86/xen.h b/xen/include/public/arch-x86/xen.h index cdd93c1c64..12f719ddad 100644 --- a/xen/include/public/arch-x86/xen.h +++ b/xen/include/public/arch-x86/xen.h @@ -291,6 +291,13 @@ struct xen_arch_domainconfig { XEN_X86_EMU_PIT) uint32_t emulation_flags; }; + +/* Location of online VCPU bitmap. */ +#define XEN_ACPI_CPU_MAP 0xaf00 +#define XEN_ACPI_CPU_MAP_LEN ((HVM_MAX_VCPUS + 7) / 8) + +/* GPE0 bit set during CPU hotplug */ +#define XEN_ACPI_GPE0_CPUHP_BIT 2 #endif #endif /* !__ASSEMBLY__ */