[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH RFC 04/20] acpi/hvmloader: Decide which SSDTs to build in hvmloader
With that, xenstore_read() won't need to be done in ACPI code Signed-off-by: Boris Ostrovsky <boris.ostrovsky@xxxxxxxxxx> --- tools/firmware/hvmloader/acpi/acpi2_0.h | 6 ++++++ tools/firmware/hvmloader/acpi/build.c | 20 +++++++------------- tools/firmware/hvmloader/util.c | 12 ++++++++++++ 3 files changed, 25 insertions(+), 13 deletions(-) diff --git a/tools/firmware/hvmloader/acpi/acpi2_0.h b/tools/firmware/hvmloader/acpi/acpi2_0.h index 275981e..1ed0d44 100644 --- a/tools/firmware/hvmloader/acpi/acpi2_0.h +++ b/tools/firmware/hvmloader/acpi/acpi2_0.h @@ -451,6 +451,11 @@ struct acpi_20_slit { #pragma pack () +/* Flags indicating which tables to build */ +#define ACPI_BUILD_SSDT_PM (1<<0) +#define ACPI_BUILD_SSDT_S3 (1<<1) +#define ACPI_BUILD_SSDT_S4 (1<<2) + /* * Located at ACPI_INFO_PHYSICAL_ADDRESS. * @@ -475,6 +480,7 @@ struct acpi_config { int dsdt_15cpu_len; struct acpi_info acpi_info; uint64_t vm_gid[2]; + uint32_t table_flags; }; void acpi_build_tables(struct acpi_config *config, unsigned int physical); diff --git a/tools/firmware/hvmloader/acpi/build.c b/tools/firmware/hvmloader/acpi/build.c index e3e8b05..9f45f26 100644 --- a/tools/firmware/hvmloader/acpi/build.c +++ b/tools/firmware/hvmloader/acpi/build.c @@ -56,11 +56,6 @@ static void set_checksum( p[checksum_offset] = -sum; } -static uint8_t battery_port_exists(void) -{ - return (inb(0x88) == 0x1F); -} - static struct acpi_20_madt *construct_madt(struct acpi_info *info) { struct acpi_20_madt *madt; @@ -322,7 +317,7 @@ static int construct_passthrough_tables(unsigned long *table_ptrs, } static int construct_secondary_tables(unsigned long *table_ptrs, - struct acpi_info *info) + struct acpi_config *config) { int nr_tables = 0; struct acpi_20_madt *madt; @@ -337,13 +332,13 @@ static int construct_secondary_tables(unsigned long *table_ptrs, /* MADT. */ if ( (hvm_info->nr_vcpus > 1) || hvm_info->apic_mode ) { - madt = construct_madt(info); + madt = construct_madt(&config->acpi_info); if (!madt) return -1; table_ptrs[nr_tables++] = (unsigned long)madt; } /* HPET. */ - if ( info->hpet_present ) + if ( config->acpi_info.hpet_present ) { hpet = construct_hpet(); if (!hpet) return -1; @@ -355,7 +350,7 @@ static int construct_secondary_tables(unsigned long *table_ptrs, if (!waet) return -1; table_ptrs[nr_tables++] = (unsigned long)waet; - if ( battery_port_exists() ) + if ( config->table_flags & ACPI_BUILD_SSDT_PM ) { ssdt = mem_alloc(sizeof(ssdt_pm), 16); if (!ssdt) return -1; @@ -363,7 +358,7 @@ static int construct_secondary_tables(unsigned long *table_ptrs, table_ptrs[nr_tables++] = (unsigned long)ssdt; } - if ( !strncmp(xenstore_read("platform/acpi_s3", "1"), "1", 1) ) + if ( config->table_flags & ACPI_BUILD_SSDT_S3 ) { ssdt = mem_alloc(sizeof(ssdt_s3), 16); if (!ssdt) return -1; @@ -373,7 +368,7 @@ static int construct_secondary_tables(unsigned long *table_ptrs, printf("S3 disabled\n"); } - if ( !strncmp(xenstore_read("platform/acpi_s4", "1"), "1", 1) ) + if ( config->table_flags & ACPI_BUILD_SSDT_S4 ) { ssdt = mem_alloc(sizeof(ssdt_s4), 16); if (!ssdt) return -1; @@ -543,8 +538,7 @@ void acpi_build_tables(struct acpi_config *config, unsigned int physical) offsetof(struct acpi_header, checksum), sizeof(struct acpi_20_fadt)); - nr_secondaries = construct_secondary_tables(secondary_tables, - &config->acpi_info); + nr_secondaries = construct_secondary_tables(secondary_tables, config); if ( nr_secondaries < 0 ) goto oom; diff --git a/tools/firmware/hvmloader/util.c b/tools/firmware/hvmloader/util.c index e4c188c..54261ae 100644 --- a/tools/firmware/hvmloader/util.c +++ b/tools/firmware/hvmloader/util.c @@ -858,6 +858,11 @@ int hpet_exists(unsigned long hpet_base) return ((hpet_id >> 16) == 0x8086); } +static uint8_t battery_port_exists(void) +{ + return (inb(0x88) == 0x1F); +} + void hvmloader_acpi_build_tables(struct acpi_config *config, unsigned int physical) { @@ -888,6 +893,13 @@ void hvmloader_acpi_build_tables(struct acpi_config *config, config->vm_gid[1] = strtoll(end+1, NULL, 0); } + if ( battery_port_exists() ) + config->table_flags |= ACPI_BUILD_SSDT_PM; + if ( !strncmp(xenstore_read("platform/acpi_s3", "1"), "1", 1) ) + config->table_flags |= ACPI_BUILD_SSDT_S3; + if ( !strncmp(xenstore_read("platform/acpi_s4", "1"), "1", 1) ) + config->table_flags |= ACPI_BUILD_SSDT_S4; + acpi_build_tables(config, physical); hvm_param_set(HVM_PARAM_VM_GENERATION_ID_ADDR, config->acpi_info.vm_gid_addr); -- 2.4.3 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |