diff mbox

ACPI: ARM: Present GIC version in MADT table

Message ID 1465960955-17388-1-git-send-email-zhaoshenglong@huawei.com
State New
Headers show

Commit Message

Shannon Zhao June 15, 2016, 3:22 a.m. UTC
From: Shannon Zhao <shannon.zhao@linaro.org>


In ACPI 5.1 Errata, it adds GIC version in GIC distributor structure.
This is useful for guest kernel to identify which version GIC hardware
is. Update GIC distributor structure and present GIC version in MADT
table.

Signed-off-by: Shannon Zhao <shannon.zhao@linaro.org>

---
 hw/arm/virt-acpi-build.c    | 1 +
 include/hw/acpi/acpi-defs.h | 4 +++-
 2 files changed, 4 insertions(+), 1 deletion(-)

-- 
2.0.4

Comments

Andrew Jones June 15, 2016, 8:52 a.m. UTC | #1
On Wed, Jun 15, 2016 at 11:22:35AM +0800, Shannon Zhao wrote:
> From: Shannon Zhao <shannon.zhao@linaro.org>

> 

> In ACPI 5.1 Errata, it adds GIC version in GIC distributor structure.

> This is useful for guest kernel to identify which version GIC hardware

> is. Update GIC distributor structure and present GIC version in MADT

> table.

> 

> Signed-off-by: Shannon Zhao <shannon.zhao@linaro.org>

> ---

>  hw/arm/virt-acpi-build.c    | 1 +

>  include/hw/acpi/acpi-defs.h | 4 +++-

>  2 files changed, 4 insertions(+), 1 deletion(-)

> 

> diff --git a/hw/arm/virt-acpi-build.c b/hw/arm/virt-acpi-build.c

> index 1fa0581..28fc59c 100644

> --- a/hw/arm/virt-acpi-build.c

> +++ b/hw/arm/virt-acpi-build.c

> @@ -523,6 +523,7 @@ build_madt(GArray *table_data, BIOSLinker *linker, VirtGuestInfo *guest_info)

>      gicd->type = ACPI_APIC_GENERIC_DISTRIBUTOR;

>      gicd->length = sizeof(*gicd);

>      gicd->base_address = memmap[VIRT_GIC_DIST].base;

> +    gicd->version = guest_info->gic_version;

>  

>      for (i = 0; i < guest_info->smp_cpus; i++) {

>          AcpiMadtGenericInterrupt *gicc = acpi_data_push(table_data,

> diff --git a/include/hw/acpi/acpi-defs.h b/include/hw/acpi/acpi-defs.h

> index 850a962..ea9be0b 100644

> --- a/include/hw/acpi/acpi-defs.h

> +++ b/include/hw/acpi/acpi-defs.h

> @@ -367,7 +367,9 @@ struct AcpiMadtGenericDistributor {

>      uint32_t gic_id;

>      uint64_t base_address;

>      uint32_t global_irq_base;

> -    uint32_t reserved2;

> +    /* ACPI 5.1 Errata 1228 Present GIC version in MADT table */

> +    uint8_t version;

> +    uint8_t reserved2[3];

>  } QEMU_PACKED;

>  

>  typedef struct AcpiMadtGenericDistributor AcpiMadtGenericDistributor;

> -- 

> 2.0.4


AFAICT, Linux is actually fine with version=0 (as before this patch).
One way or another it has already determined that the gic is either v3
or v4, and then just proceeds. That said, it does seem like the right
thing to do to set it

Reviewed-by: Andrew Jones <drjones@redhat.com>
Peter Maydell June 16, 2016, 2:30 p.m. UTC | #2
On 15 June 2016 at 09:52, Andrew Jones <drjones@redhat.com> wrote:
> On Wed, Jun 15, 2016 at 11:22:35AM +0800, Shannon Zhao wrote:

>> From: Shannon Zhao <shannon.zhao@linaro.org>

>>

>> In ACPI 5.1 Errata, it adds GIC version in GIC distributor structure.

>> This is useful for guest kernel to identify which version GIC hardware

>> is. Update GIC distributor structure and present GIC version in MADT

>> table.

>>

>> Signed-off-by: Shannon Zhao <shannon.zhao@linaro.org>


>

> AFAICT, Linux is actually fine with version=0 (as before this patch).

> One way or another it has already determined that the gic is either v3

> or v4, and then just proceeds. That said, it does seem like the right

> thing to do to set it

>

> Reviewed-by: Andrew Jones <drjones@redhat.com>


Applied to target-arm.next, thanks.

-- PMM
diff mbox

Patch

diff --git a/hw/arm/virt-acpi-build.c b/hw/arm/virt-acpi-build.c
index 1fa0581..28fc59c 100644
--- a/hw/arm/virt-acpi-build.c
+++ b/hw/arm/virt-acpi-build.c
@@ -523,6 +523,7 @@  build_madt(GArray *table_data, BIOSLinker *linker, VirtGuestInfo *guest_info)
     gicd->type = ACPI_APIC_GENERIC_DISTRIBUTOR;
     gicd->length = sizeof(*gicd);
     gicd->base_address = memmap[VIRT_GIC_DIST].base;
+    gicd->version = guest_info->gic_version;
 
     for (i = 0; i < guest_info->smp_cpus; i++) {
         AcpiMadtGenericInterrupt *gicc = acpi_data_push(table_data,
diff --git a/include/hw/acpi/acpi-defs.h b/include/hw/acpi/acpi-defs.h
index 850a962..ea9be0b 100644
--- a/include/hw/acpi/acpi-defs.h
+++ b/include/hw/acpi/acpi-defs.h
@@ -367,7 +367,9 @@  struct AcpiMadtGenericDistributor {
     uint32_t gic_id;
     uint64_t base_address;
     uint32_t global_irq_base;
-    uint32_t reserved2;
+    /* ACPI 5.1 Errata 1228 Present GIC version in MADT table */
+    uint8_t version;
+    uint8_t reserved2[3];
 } QEMU_PACKED;
 
 typedef struct AcpiMadtGenericDistributor AcpiMadtGenericDistributor;