Commit 1f6239ca authored by Michał Żygowski's avatar Michał Żygowski Committed by Rafael J. Wysocki

ACPICA: Implement IVRS IVHD type 11h parsing

ACPICA commit 6ddc19419896e4149ced1b5f35f0dc12516c0399

The AMD IVRS table parsing supported only IVHD type 10h structures.
Parsing an IVHD type 11h caused the iasl to report unknown subtable type.
Add necessary structure definition for IVHD type 11h and apply correct
parsing method based on subtable type.

Link: https://github.com/acpica/acpica/commit/6ddc1941Signed-off-by: default avatarMichał Żygowski <michal.zygowski@3mdeb.com>
Signed-off-by: default avatarBob Moore <robert.moore@intel.com>
Signed-off-by: default avatarErik Kaneda <erik.kaneda@intel.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 1c040f3a
...@@ -274,7 +274,8 @@ struct acpi_ivrs_header { ...@@ -274,7 +274,8 @@ struct acpi_ivrs_header {
/* Values for subtable Type above */ /* Values for subtable Type above */
enum acpi_ivrs_type { enum acpi_ivrs_type {
ACPI_IVRS_TYPE_HARDWARE = 0x10, ACPI_IVRS_TYPE_HARDWARE1 = 0x10,
ACPI_IVRS_TYPE_HARDWARE2 = 0x11,
ACPI_IVRS_TYPE_MEMORY1 = 0x20, ACPI_IVRS_TYPE_MEMORY1 = 0x20,
ACPI_IVRS_TYPE_MEMORY2 = 0x21, ACPI_IVRS_TYPE_MEMORY2 = 0x21,
ACPI_IVRS_TYPE_MEMORY3 = 0x22 ACPI_IVRS_TYPE_MEMORY3 = 0x22
...@@ -301,7 +302,7 @@ enum acpi_ivrs_type { ...@@ -301,7 +302,7 @@ enum acpi_ivrs_type {
/* 0x10: I/O Virtualization Hardware Definition Block (IVHD) */ /* 0x10: I/O Virtualization Hardware Definition Block (IVHD) */
struct acpi_ivrs_hardware { struct acpi_ivrs_hardware_10 {
struct acpi_ivrs_header header; struct acpi_ivrs_header header;
u16 capability_offset; /* Offset for IOMMU control fields */ u16 capability_offset; /* Offset for IOMMU control fields */
u64 base_address; /* IOMMU control registers */ u64 base_address; /* IOMMU control registers */
...@@ -310,6 +311,19 @@ struct acpi_ivrs_hardware { ...@@ -310,6 +311,19 @@ struct acpi_ivrs_hardware {
u32 reserved; u32 reserved;
}; };
/* 0x11: I/O Virtualization Hardware Definition Block (IVHD) */
struct acpi_ivrs_hardware_11 {
struct acpi_ivrs_header header;
u16 capability_offset; /* Offset for IOMMU control fields */
u64 base_address; /* IOMMU control registers */
u16 pci_segment_group;
u16 info; /* MSI number and unit ID */
u32 attributes;
u64 efr_register_image;
u64 reserved;
};
/* Masks for Info field above */ /* Masks for Info field above */
#define ACPI_IVHD_MSI_NUMBER_MASK 0x001F /* 5 bits, MSI message number */ #define ACPI_IVHD_MSI_NUMBER_MASK 0x001F /* 5 bits, MSI message number */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment