[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v3 04/19] acpi/hvmloader: Make providing IOAPIC in MADT optional
Signed-off-by: Boris Ostrovsky <boris.ostrovsky@xxxxxxxxxx> Reviewed-by: Jan Beulich <jbeulich@xxxxxxxx> --- tools/firmware/hvmloader/acpi/build.c | 70 ++++++++++++++++++--------------- tools/firmware/hvmloader/acpi/libacpi.h | 1 + tools/firmware/hvmloader/util.c | 2 +- 3 files changed, 40 insertions(+), 33 deletions(-) diff --git a/tools/firmware/hvmloader/acpi/build.c b/tools/firmware/hvmloader/acpi/build.c index 80386b9..7e7c11f 100644 --- a/tools/firmware/hvmloader/acpi/build.c +++ b/tools/firmware/hvmloader/acpi/build.c @@ -99,43 +99,49 @@ static struct acpi_20_madt *construct_madt(const struct acpi_config *config, madt->lapic_addr = LAPIC_BASE_ADDRESS; madt->flags = ACPI_PCAT_COMPAT; - intsrcovr = (struct acpi_20_madt_intsrcovr *)(madt + 1); - for ( i = 0; i < 16; i++ ) - { - memset(intsrcovr, 0, sizeof(*intsrcovr)); - intsrcovr->type = ACPI_INTERRUPT_SOURCE_OVERRIDE; - intsrcovr->length = sizeof(*intsrcovr); - intsrcovr->source = i; - - if ( i == 0 ) - { - /* ISA IRQ0 routed to IOAPIC GSI 2. */ - intsrcovr->gsi = 2; - intsrcovr->flags = 0x0; - } - else if ( PCI_ISA_IRQ_MASK & (1U << i) ) - { - /* PCI: active-low level-triggered. */ - intsrcovr->gsi = i; - intsrcovr->flags = 0xf; - } - else + if ( config->table_flags & ACPI_HAS_IOAPIC ) + { + intsrcovr = (struct acpi_20_madt_intsrcovr *)(madt + 1); + for ( i = 0; i < 16; i++ ) { - /* No need for a INT source override structure. */ - continue; + memset(intsrcovr, 0, sizeof(*intsrcovr)); + intsrcovr->type = ACPI_INTERRUPT_SOURCE_OVERRIDE; + intsrcovr->length = sizeof(*intsrcovr); + intsrcovr->source = i; + + if ( i == 0 ) + { + /* ISA IRQ0 routed to IOAPIC GSI 2. */ + intsrcovr->gsi = 2; + intsrcovr->flags = 0x0; + } + else if ( PCI_ISA_IRQ_MASK & (1U << i) ) + { + /* PCI: active-low level-triggered. */ + intsrcovr->gsi = i; + intsrcovr->flags = 0xf; + } + else + { + /* No need for a INT source override structure. */ + continue; + } + + intsrcovr++; } - intsrcovr++; - } + io_apic = (struct acpi_20_madt_ioapic *)intsrcovr; + memset(io_apic, 0, sizeof(*io_apic)); + io_apic->type = ACPI_IO_APIC; + io_apic->length = sizeof(*io_apic); + io_apic->ioapic_id = IOAPIC_ID; + io_apic->ioapic_addr = ioapic_base_address; - io_apic = (struct acpi_20_madt_ioapic *)intsrcovr; - memset(io_apic, 0, sizeof(*io_apic)); - io_apic->type = ACPI_IO_APIC; - io_apic->length = sizeof(*io_apic); - io_apic->ioapic_id = IOAPIC_ID; - io_apic->ioapic_addr = ioapic_base_address; + lapic = (struct acpi_20_madt_lapic *)(io_apic + 1); + } + else + lapic = (struct acpi_20_madt_lapic *)(madt + 1); - lapic = (struct acpi_20_madt_lapic *)(io_apic + 1); info->nr_cpus = hvminfo->nr_vcpus; info->madt_lapic0_addr = (uint32_t)lapic; for ( i = 0; i < hvminfo->nr_vcpus; i++ ) diff --git a/tools/firmware/hvmloader/acpi/libacpi.h b/tools/firmware/hvmloader/acpi/libacpi.h index cc57a9c..b089cc5 100644 --- a/tools/firmware/hvmloader/acpi/libacpi.h +++ b/tools/firmware/hvmloader/acpi/libacpi.h @@ -30,6 +30,7 @@ #define ACPI_HAS_SSDT_S3 (1<<5) #define ACPI_HAS_SSDT_S4 (1<<6) #define ACPI_HAS_TCPA (1<<7) +#define ACPI_HAS_IOAPIC (1<<8) struct acpi_numa { diff --git a/tools/firmware/hvmloader/util.c b/tools/firmware/hvmloader/util.c index 8875675..aa5fc20 100644 --- a/tools/firmware/hvmloader/util.c +++ b/tools/firmware/hvmloader/util.c @@ -919,7 +919,7 @@ void hvmloader_acpi_build_tables(struct acpi_config *config, if ( !strncmp(xenstore_read("platform/acpi_s4", "1"), "1", 1) ) config->table_flags |= ACPI_HAS_SSDT_S4; - config->table_flags |= ACPI_HAS_TCPA; + config->table_flags |= (ACPI_HAS_TCPA | ACPI_HAS_IOAPIC); config->tis_hdr = (uint16_t *)ACPI_TIS_HDR_ADDRESS; -- 1.8.3.1 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |