172c194f7SMichael S. Tsirkin /* 272c194f7SMichael S. Tsirkin * This program is free software; you can redistribute it and/or modify 372c194f7SMichael S. Tsirkin * it under the terms of the GNU General Public License as published by 472c194f7SMichael S. Tsirkin * the Free Software Foundation; either version 2 of the License, or 572c194f7SMichael S. Tsirkin * (at your option) any later version. 672c194f7SMichael S. Tsirkin 772c194f7SMichael S. Tsirkin * This program is distributed in the hope that it will be useful, 872c194f7SMichael S. Tsirkin * but WITHOUT ANY WARRANTY; without even the implied warranty of 972c194f7SMichael S. Tsirkin * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1072c194f7SMichael S. Tsirkin * GNU General Public License for more details. 1172c194f7SMichael S. Tsirkin 1272c194f7SMichael S. Tsirkin * You should have received a copy of the GNU General Public License along 1372c194f7SMichael S. Tsirkin * with this program; if not, see <http://www.gnu.org/licenses/>. 1472c194f7SMichael S. Tsirkin */ 1572c194f7SMichael S. Tsirkin #ifndef QEMU_ACPI_DEFS_H 1672c194f7SMichael S. Tsirkin #define QEMU_ACPI_DEFS_H 1772c194f7SMichael S. Tsirkin 1872c194f7SMichael S. Tsirkin enum { 1972c194f7SMichael S. Tsirkin ACPI_FADT_F_WBINVD, 2072c194f7SMichael S. Tsirkin ACPI_FADT_F_WBINVD_FLUSH, 2172c194f7SMichael S. Tsirkin ACPI_FADT_F_PROC_C1, 2272c194f7SMichael S. Tsirkin ACPI_FADT_F_P_LVL2_UP, 2372c194f7SMichael S. Tsirkin ACPI_FADT_F_PWR_BUTTON, 2472c194f7SMichael S. Tsirkin ACPI_FADT_F_SLP_BUTTON, 2572c194f7SMichael S. Tsirkin ACPI_FADT_F_FIX_RTC, 2672c194f7SMichael S. Tsirkin ACPI_FADT_F_RTC_S4, 2772c194f7SMichael S. Tsirkin ACPI_FADT_F_TMR_VAL_EXT, 2872c194f7SMichael S. Tsirkin ACPI_FADT_F_DCK_CAP, 2972c194f7SMichael S. Tsirkin ACPI_FADT_F_RESET_REG_SUP, 3072c194f7SMichael S. Tsirkin ACPI_FADT_F_SEALED_CASE, 3172c194f7SMichael S. Tsirkin ACPI_FADT_F_HEADLESS, 3272c194f7SMichael S. Tsirkin ACPI_FADT_F_CPU_SW_SLP, 3372c194f7SMichael S. Tsirkin ACPI_FADT_F_PCI_EXP_WAK, 3472c194f7SMichael S. Tsirkin ACPI_FADT_F_USE_PLATFORM_CLOCK, 3572c194f7SMichael S. Tsirkin ACPI_FADT_F_S4_RTC_STS_VALID, 3672c194f7SMichael S. Tsirkin ACPI_FADT_F_REMOTE_POWER_ON_CAPABLE, 3772c194f7SMichael S. Tsirkin ACPI_FADT_F_FORCE_APIC_CLUSTER_MODEL, 3872c194f7SMichael S. Tsirkin ACPI_FADT_F_FORCE_APIC_PHYSICAL_DESTINATION_MODE, 3972c194f7SMichael S. Tsirkin ACPI_FADT_F_HW_REDUCED_ACPI, 4072c194f7SMichael S. Tsirkin ACPI_FADT_F_LOW_POWER_S0_IDLE_CAPABLE, 4172c194f7SMichael S. Tsirkin }; 4272c194f7SMichael S. Tsirkin 4372c194f7SMichael S. Tsirkin struct AcpiRsdpDescriptor { /* Root System Descriptor Pointer */ 4472c194f7SMichael S. Tsirkin uint64_t signature; /* ACPI signature, contains "RSD PTR " */ 4572c194f7SMichael S. Tsirkin uint8_t checksum; /* To make sum of struct == 0 */ 4672c194f7SMichael S. Tsirkin uint8_t oem_id [6]; /* OEM identification */ 4772c194f7SMichael S. Tsirkin uint8_t revision; /* Must be 0 for 1.0, 2 for 2.0 */ 4872c194f7SMichael S. Tsirkin uint32_t rsdt_physical_address; /* 32-bit physical address of RSDT */ 4972c194f7SMichael S. Tsirkin uint32_t length; /* XSDT Length in bytes including hdr */ 5072c194f7SMichael S. Tsirkin uint64_t xsdt_physical_address; /* 64-bit physical address of XSDT */ 5172c194f7SMichael S. Tsirkin uint8_t extended_checksum; /* Checksum of entire table */ 5272c194f7SMichael S. Tsirkin uint8_t reserved [3]; /* Reserved field must be 0 */ 5372c194f7SMichael S. Tsirkin } QEMU_PACKED; 5472c194f7SMichael S. Tsirkin typedef struct AcpiRsdpDescriptor AcpiRsdpDescriptor; 5572c194f7SMichael S. Tsirkin 5672c194f7SMichael S. Tsirkin /* Table structure from Linux kernel (the ACPI tables are under the 5772c194f7SMichael S. Tsirkin BSD license) */ 5872c194f7SMichael S. Tsirkin 5972c194f7SMichael S. Tsirkin 6072c194f7SMichael S. Tsirkin #define ACPI_TABLE_HEADER_DEF /* ACPI common table header */ \ 6172c194f7SMichael S. Tsirkin uint32_t signature; /* ACPI signature (4 ASCII characters) */ \ 6272c194f7SMichael S. Tsirkin uint32_t length; /* Length of table, in bytes, including header */ \ 6372c194f7SMichael S. Tsirkin uint8_t revision; /* ACPI Specification minor version # */ \ 6472c194f7SMichael S. Tsirkin uint8_t checksum; /* To make sum of entire table == 0 */ \ 6572c194f7SMichael S. Tsirkin uint8_t oem_id [6]; /* OEM identification */ \ 6672c194f7SMichael S. Tsirkin uint8_t oem_table_id [8]; /* OEM table identification */ \ 6772c194f7SMichael S. Tsirkin uint32_t oem_revision; /* OEM revision number */ \ 6872c194f7SMichael S. Tsirkin uint8_t asl_compiler_id [4]; /* ASL compiler vendor ID */ \ 6972c194f7SMichael S. Tsirkin uint32_t asl_compiler_revision; /* ASL compiler revision number */ 7072c194f7SMichael S. Tsirkin 7172c194f7SMichael S. Tsirkin 728b12e489SMichael S. Tsirkin /* ACPI common table header */ 738b12e489SMichael S. Tsirkin struct AcpiTableHeader { 7472c194f7SMichael S. Tsirkin ACPI_TABLE_HEADER_DEF 7572c194f7SMichael S. Tsirkin } QEMU_PACKED; 7672c194f7SMichael S. Tsirkin typedef struct AcpiTableHeader AcpiTableHeader; 7772c194f7SMichael S. Tsirkin 78c2f7c0c3SShannon Zhao struct AcpiGenericAddress { 79c2f7c0c3SShannon Zhao uint8_t space_id; /* Address space where struct or register exists */ 80c2f7c0c3SShannon Zhao uint8_t bit_width; /* Size in bits of given register */ 81c2f7c0c3SShannon Zhao uint8_t bit_offset; /* Bit offset within the register */ 82b8e0f589SIgor Mammedov uint8_t access_width; /* ACPI 3.0: Minimum Access size (ACPI 3.0), 83b8e0f589SIgor Mammedov ACPI 2.0: Reserved, Table 5-1 */ 84c2f7c0c3SShannon Zhao uint64_t address; /* 64-bit address of struct or register */ 85c2f7c0c3SShannon Zhao } QEMU_PACKED; 86c2f7c0c3SShannon Zhao 87937d1b58SIgor Mammedov typedef struct AcpiFadtData { 88937d1b58SIgor Mammedov struct AcpiGenericAddress pm1a_cnt; /* PM1a_CNT_BLK */ 89937d1b58SIgor Mammedov struct AcpiGenericAddress pm1a_evt; /* PM1a_EVT_BLK */ 90937d1b58SIgor Mammedov struct AcpiGenericAddress pm_tmr; /* PM_TMR_BLK */ 91937d1b58SIgor Mammedov struct AcpiGenericAddress gpe0_blk; /* GPE0_BLK */ 92937d1b58SIgor Mammedov struct AcpiGenericAddress reset_reg; /* RESET_REG */ 93937d1b58SIgor Mammedov uint8_t reset_val; /* RESET_VALUE */ 94937d1b58SIgor Mammedov uint8_t rev; /* Revision */ 95937d1b58SIgor Mammedov uint32_t flags; /* Flags */ 96937d1b58SIgor Mammedov uint32_t smi_cmd; /* SMI_CMD */ 97937d1b58SIgor Mammedov uint16_t sci_int; /* SCI_INT */ 98937d1b58SIgor Mammedov uint8_t int_model; /* INT_MODEL */ 99937d1b58SIgor Mammedov uint8_t acpi_enable_cmd; /* ACPI_ENABLE */ 100937d1b58SIgor Mammedov uint8_t acpi_disable_cmd; /* ACPI_DISABLE */ 101937d1b58SIgor Mammedov uint8_t rtc_century; /* CENTURY */ 102937d1b58SIgor Mammedov uint16_t plvl2_lat; /* P_LVL2_LAT */ 103937d1b58SIgor Mammedov uint16_t plvl3_lat; /* P_LVL3_LAT */ 104dd1b2037SIgor Mammedov uint16_t arm_boot_arch; /* ARM_BOOT_ARCH */ 105dd1b2037SIgor Mammedov uint8_t minor_ver; /* FADT Minor Version */ 106937d1b58SIgor Mammedov 107937d1b58SIgor Mammedov /* 108937d1b58SIgor Mammedov * respective tables offsets within ACPI_BUILD_TABLE_FILE, 109937d1b58SIgor Mammedov * NULL if table doesn't exist (in that case field's value 110937d1b58SIgor Mammedov * won't be patched by linker and will be kept set to 0) 111937d1b58SIgor Mammedov */ 112937d1b58SIgor Mammedov unsigned *facs_tbl_offset; /* FACS offset in */ 113937d1b58SIgor Mammedov unsigned *dsdt_tbl_offset; 114937d1b58SIgor Mammedov unsigned *xdsdt_tbl_offset; 115937d1b58SIgor Mammedov } AcpiFadtData; 116937d1b58SIgor Mammedov 1178c92c6a4SAndrew Jones #define ACPI_FADT_ARM_PSCI_COMPLIANT (1 << 0) 1188c92c6a4SAndrew Jones #define ACPI_FADT_ARM_PSCI_USE_HVC (1 << 1) 119c2f7c0c3SShannon Zhao 12072c194f7SMichael S. Tsirkin /* 121b8a0d75eSAndrew Jones * Serial Port Console Redirection Table (SPCR), Rev. 1.02 122b8a0d75eSAndrew Jones * 123b8a0d75eSAndrew Jones * For .interface_type see Debug Port Table 2 (DBG2) serial port 124b8a0d75eSAndrew Jones * subtypes in Table 3, Rev. May 22, 2012 125b8a0d75eSAndrew Jones */ 126b8a0d75eSAndrew Jones struct AcpiSerialPortConsoleRedirection { 127b8a0d75eSAndrew Jones ACPI_TABLE_HEADER_DEF 128b8a0d75eSAndrew Jones uint8_t interface_type; 129b8a0d75eSAndrew Jones uint8_t reserved1[3]; 130b8a0d75eSAndrew Jones struct AcpiGenericAddress base_address; 131b8a0d75eSAndrew Jones uint8_t interrupt_types; 132b8a0d75eSAndrew Jones uint8_t irq; 133b8a0d75eSAndrew Jones uint32_t gsi; 134b8a0d75eSAndrew Jones uint8_t baud; 135b8a0d75eSAndrew Jones uint8_t parity; 136b8a0d75eSAndrew Jones uint8_t stopbits; 137b8a0d75eSAndrew Jones uint8_t flowctrl; 138b8a0d75eSAndrew Jones uint8_t term_type; 139b8a0d75eSAndrew Jones uint8_t reserved2; 140b8a0d75eSAndrew Jones uint16_t pci_device_id; 141b8a0d75eSAndrew Jones uint16_t pci_vendor_id; 142b8a0d75eSAndrew Jones uint8_t pci_bus; 143b8a0d75eSAndrew Jones uint8_t pci_slot; 144b8a0d75eSAndrew Jones uint8_t pci_func; 145b8a0d75eSAndrew Jones uint32_t pci_flags; 146b8a0d75eSAndrew Jones uint8_t pci_seg; 147b8a0d75eSAndrew Jones uint32_t reserved3; 148b8a0d75eSAndrew Jones } QEMU_PACKED; 149b8a0d75eSAndrew Jones typedef struct AcpiSerialPortConsoleRedirection 150b8a0d75eSAndrew Jones AcpiSerialPortConsoleRedirection; 151b8a0d75eSAndrew Jones 152b8a0d75eSAndrew Jones /* 15372c194f7SMichael S. Tsirkin * ACPI 1.0 Root System Description Table (RSDT) 15472c194f7SMichael S. Tsirkin */ 1558b12e489SMichael S. Tsirkin struct AcpiRsdtDescriptorRev1 { 15672c194f7SMichael S. Tsirkin ACPI_TABLE_HEADER_DEF /* ACPI common table header */ 15772c194f7SMichael S. Tsirkin uint32_t table_offset_entry[0]; /* Array of pointers to other */ 15872c194f7SMichael S. Tsirkin /* ACPI tables */ 15972c194f7SMichael S. Tsirkin } QEMU_PACKED; 16072c194f7SMichael S. Tsirkin typedef struct AcpiRsdtDescriptorRev1 AcpiRsdtDescriptorRev1; 16172c194f7SMichael S. Tsirkin 16272c194f7SMichael S. Tsirkin /* 163cb51ac2fSArd Biesheuvel * ACPI 2.0 eXtended System Description Table (XSDT) 164cb51ac2fSArd Biesheuvel */ 1658b12e489SMichael S. Tsirkin struct AcpiXsdtDescriptorRev2 { 166cb51ac2fSArd Biesheuvel ACPI_TABLE_HEADER_DEF /* ACPI common table header */ 167cb51ac2fSArd Biesheuvel uint64_t table_offset_entry[0]; /* Array of pointers to other */ 168cb51ac2fSArd Biesheuvel /* ACPI tables */ 169cb51ac2fSArd Biesheuvel } QEMU_PACKED; 170cb51ac2fSArd Biesheuvel typedef struct AcpiXsdtDescriptorRev2 AcpiXsdtDescriptorRev2; 171cb51ac2fSArd Biesheuvel 172cb51ac2fSArd Biesheuvel /* 17372c194f7SMichael S. Tsirkin * ACPI 1.0 Firmware ACPI Control Structure (FACS) 17472c194f7SMichael S. Tsirkin */ 1758b12e489SMichael S. Tsirkin struct AcpiFacsDescriptorRev1 { 17672c194f7SMichael S. Tsirkin uint32_t signature; /* ACPI Signature */ 17772c194f7SMichael S. Tsirkin uint32_t length; /* Length of structure, in bytes */ 17872c194f7SMichael S. Tsirkin uint32_t hardware_signature; /* Hardware configuration signature */ 17972c194f7SMichael S. Tsirkin uint32_t firmware_waking_vector; /* ACPI OS waking vector */ 18072c194f7SMichael S. Tsirkin uint32_t global_lock; /* Global Lock */ 18172c194f7SMichael S. Tsirkin uint32_t flags; 18272c194f7SMichael S. Tsirkin uint8_t resverved3 [40]; /* Reserved - must be zero */ 18372c194f7SMichael S. Tsirkin } QEMU_PACKED; 18472c194f7SMichael S. Tsirkin typedef struct AcpiFacsDescriptorRev1 AcpiFacsDescriptorRev1; 18572c194f7SMichael S. Tsirkin 18672c194f7SMichael S. Tsirkin /* 18772c194f7SMichael S. Tsirkin * Differentiated System Description Table (DSDT) 18872c194f7SMichael S. Tsirkin */ 18972c194f7SMichael S. Tsirkin 19072c194f7SMichael S. Tsirkin /* 19172c194f7SMichael S. Tsirkin * MADT values and structures 19272c194f7SMichael S. Tsirkin */ 19372c194f7SMichael S. Tsirkin 19472c194f7SMichael S. Tsirkin /* Values for MADT PCATCompat */ 19572c194f7SMichael S. Tsirkin 19672c194f7SMichael S. Tsirkin #define ACPI_DUAL_PIC 0 19772c194f7SMichael S. Tsirkin #define ACPI_MULTIPLE_APIC 1 19872c194f7SMichael S. Tsirkin 19972c194f7SMichael S. Tsirkin /* Master MADT */ 20072c194f7SMichael S. Tsirkin 2018b12e489SMichael S. Tsirkin struct AcpiMultipleApicTable { 20272c194f7SMichael S. Tsirkin ACPI_TABLE_HEADER_DEF /* ACPI common table header */ 20372c194f7SMichael S. Tsirkin uint32_t local_apic_address; /* Physical address of local APIC */ 20472c194f7SMichael S. Tsirkin uint32_t flags; 20572c194f7SMichael S. Tsirkin } QEMU_PACKED; 20672c194f7SMichael S. Tsirkin typedef struct AcpiMultipleApicTable AcpiMultipleApicTable; 20772c194f7SMichael S. Tsirkin 20872c194f7SMichael S. Tsirkin /* Values for Type in APIC sub-headers */ 20972c194f7SMichael S. Tsirkin 21072c194f7SMichael S. Tsirkin #define ACPI_APIC_PROCESSOR 0 21172c194f7SMichael S. Tsirkin #define ACPI_APIC_IO 1 21272c194f7SMichael S. Tsirkin #define ACPI_APIC_XRUPT_OVERRIDE 2 21372c194f7SMichael S. Tsirkin #define ACPI_APIC_NMI 3 21472c194f7SMichael S. Tsirkin #define ACPI_APIC_LOCAL_NMI 4 21572c194f7SMichael S. Tsirkin #define ACPI_APIC_ADDRESS_OVERRIDE 5 21672c194f7SMichael S. Tsirkin #define ACPI_APIC_IO_SAPIC 6 21772c194f7SMichael S. Tsirkin #define ACPI_APIC_LOCAL_SAPIC 7 21872c194f7SMichael S. Tsirkin #define ACPI_APIC_XRUPT_SOURCE 8 219982d06c5SShannon Zhao #define ACPI_APIC_LOCAL_X2APIC 9 220982d06c5SShannon Zhao #define ACPI_APIC_LOCAL_X2APIC_NMI 10 2216e2ed65fSAndrew Jones #define ACPI_APIC_GENERIC_CPU_INTERFACE 11 222982d06c5SShannon Zhao #define ACPI_APIC_GENERIC_DISTRIBUTOR 12 223982d06c5SShannon Zhao #define ACPI_APIC_GENERIC_MSI_FRAME 13 224982d06c5SShannon Zhao #define ACPI_APIC_GENERIC_REDISTRIBUTOR 14 2251c2e4ea7SShannon Zhao #define ACPI_APIC_GENERIC_TRANSLATOR 15 2261c2e4ea7SShannon Zhao #define ACPI_APIC_RESERVED 16 /* 16 and greater are reserved */ 22772c194f7SMichael S. Tsirkin 22872c194f7SMichael S. Tsirkin /* 22972c194f7SMichael S. Tsirkin * MADT sub-structures (Follow MULTIPLE_APIC_DESCRIPTION_TABLE) 23072c194f7SMichael S. Tsirkin */ 23172c194f7SMichael S. Tsirkin #define ACPI_SUB_HEADER_DEF /* Common ACPI sub-structure header */\ 23272c194f7SMichael S. Tsirkin uint8_t type; \ 23372c194f7SMichael S. Tsirkin uint8_t length; 23472c194f7SMichael S. Tsirkin 23572c194f7SMichael S. Tsirkin /* Sub-structures for MADT */ 23672c194f7SMichael S. Tsirkin 2378b12e489SMichael S. Tsirkin struct AcpiMadtProcessorApic { 23872c194f7SMichael S. Tsirkin ACPI_SUB_HEADER_DEF 23972c194f7SMichael S. Tsirkin uint8_t processor_id; /* ACPI processor id */ 24072c194f7SMichael S. Tsirkin uint8_t local_apic_id; /* Processor's local APIC id */ 24172c194f7SMichael S. Tsirkin uint32_t flags; 24272c194f7SMichael S. Tsirkin } QEMU_PACKED; 24372c194f7SMichael S. Tsirkin typedef struct AcpiMadtProcessorApic AcpiMadtProcessorApic; 24472c194f7SMichael S. Tsirkin 2458b12e489SMichael S. Tsirkin struct AcpiMadtIoApic { 24672c194f7SMichael S. Tsirkin ACPI_SUB_HEADER_DEF 24772c194f7SMichael S. Tsirkin uint8_t io_apic_id; /* I/O APIC ID */ 24872c194f7SMichael S. Tsirkin uint8_t reserved; /* Reserved - must be zero */ 24972c194f7SMichael S. Tsirkin uint32_t address; /* APIC physical address */ 25072c194f7SMichael S. Tsirkin uint32_t interrupt; /* Global system interrupt where INTI 25172c194f7SMichael S. Tsirkin * lines start */ 25272c194f7SMichael S. Tsirkin } QEMU_PACKED; 25372c194f7SMichael S. Tsirkin typedef struct AcpiMadtIoApic AcpiMadtIoApic; 25472c194f7SMichael S. Tsirkin 25572c194f7SMichael S. Tsirkin struct AcpiMadtIntsrcovr { 25672c194f7SMichael S. Tsirkin ACPI_SUB_HEADER_DEF 25772c194f7SMichael S. Tsirkin uint8_t bus; 25872c194f7SMichael S. Tsirkin uint8_t source; 25972c194f7SMichael S. Tsirkin uint32_t gsi; 26072c194f7SMichael S. Tsirkin uint16_t flags; 26172c194f7SMichael S. Tsirkin } QEMU_PACKED; 26272c194f7SMichael S. Tsirkin typedef struct AcpiMadtIntsrcovr AcpiMadtIntsrcovr; 26372c194f7SMichael S. Tsirkin 26472c194f7SMichael S. Tsirkin struct AcpiMadtLocalNmi { 26572c194f7SMichael S. Tsirkin ACPI_SUB_HEADER_DEF 26672c194f7SMichael S. Tsirkin uint8_t processor_id; /* ACPI processor id */ 26772c194f7SMichael S. Tsirkin uint16_t flags; /* MPS INTI flags */ 26872c194f7SMichael S. Tsirkin uint8_t lint; /* Local APIC LINT# */ 26972c194f7SMichael S. Tsirkin } QEMU_PACKED; 27072c194f7SMichael S. Tsirkin typedef struct AcpiMadtLocalNmi AcpiMadtLocalNmi; 27172c194f7SMichael S. Tsirkin 272e2c95939SIgor Mammedov struct AcpiMadtProcessorX2Apic { 273e2c95939SIgor Mammedov ACPI_SUB_HEADER_DEF 274e2c95939SIgor Mammedov uint16_t reserved; 275e2c95939SIgor Mammedov uint32_t x2apic_id; /* Processor's local x2APIC ID */ 276e2c95939SIgor Mammedov uint32_t flags; 277e2c95939SIgor Mammedov uint32_t uid; /* Processor object _UID */ 278e2c95939SIgor Mammedov } QEMU_PACKED; 279e2c95939SIgor Mammedov typedef struct AcpiMadtProcessorX2Apic AcpiMadtProcessorX2Apic; 280e2c95939SIgor Mammedov 281e2c95939SIgor Mammedov struct AcpiMadtLocalX2ApicNmi { 282e2c95939SIgor Mammedov ACPI_SUB_HEADER_DEF 283e2c95939SIgor Mammedov uint16_t flags; /* MPS INTI flags */ 284e2c95939SIgor Mammedov uint32_t uid; /* Processor object _UID */ 285e2c95939SIgor Mammedov uint8_t lint; /* Local APIC LINT# */ 286e2c95939SIgor Mammedov uint8_t reserved[3]; /* Local APIC LINT# */ 287e2c95939SIgor Mammedov } QEMU_PACKED; 288e2c95939SIgor Mammedov typedef struct AcpiMadtLocalX2ApicNmi AcpiMadtLocalX2ApicNmi; 289e2c95939SIgor Mammedov 2906e2ed65fSAndrew Jones struct AcpiMadtGenericCpuInterface { 291982d06c5SShannon Zhao ACPI_SUB_HEADER_DEF 292982d06c5SShannon Zhao uint16_t reserved; 293982d06c5SShannon Zhao uint32_t cpu_interface_number; 294982d06c5SShannon Zhao uint32_t uid; 295982d06c5SShannon Zhao uint32_t flags; 296982d06c5SShannon Zhao uint32_t parking_version; 297982d06c5SShannon Zhao uint32_t performance_interrupt; 298982d06c5SShannon Zhao uint64_t parked_address; 299982d06c5SShannon Zhao uint64_t base_address; 300982d06c5SShannon Zhao uint64_t gicv_base_address; 301982d06c5SShannon Zhao uint64_t gich_base_address; 302982d06c5SShannon Zhao uint32_t vgic_interrupt; 303982d06c5SShannon Zhao uint64_t gicr_base_address; 304982d06c5SShannon Zhao uint64_t arm_mpidr; 305982d06c5SShannon Zhao } QEMU_PACKED; 306982d06c5SShannon Zhao 3076e2ed65fSAndrew Jones typedef struct AcpiMadtGenericCpuInterface AcpiMadtGenericCpuInterface; 3086e2ed65fSAndrew Jones 3096e2ed65fSAndrew Jones /* GICC CPU Interface Flags */ 3106e2ed65fSAndrew Jones #define ACPI_MADT_GICC_ENABLED 1 311982d06c5SShannon Zhao 312982d06c5SShannon Zhao struct AcpiMadtGenericDistributor { 313982d06c5SShannon Zhao ACPI_SUB_HEADER_DEF 314982d06c5SShannon Zhao uint16_t reserved; 315982d06c5SShannon Zhao uint32_t gic_id; 316982d06c5SShannon Zhao uint64_t base_address; 317982d06c5SShannon Zhao uint32_t global_irq_base; 318f06765a9SShannon Zhao /* ACPI 5.1 Errata 1228 Present GIC version in MADT table */ 319f06765a9SShannon Zhao uint8_t version; 320f06765a9SShannon Zhao uint8_t reserved2[3]; 321982d06c5SShannon Zhao } QEMU_PACKED; 322982d06c5SShannon Zhao 323982d06c5SShannon Zhao typedef struct AcpiMadtGenericDistributor AcpiMadtGenericDistributor; 324982d06c5SShannon Zhao 325ca793736SShannon Zhao struct AcpiMadtGenericMsiFrame { 326ca793736SShannon Zhao ACPI_SUB_HEADER_DEF 327ca793736SShannon Zhao uint16_t reserved; 328ca793736SShannon Zhao uint32_t gic_msi_frame_id; 329ca793736SShannon Zhao uint64_t base_address; 330ca793736SShannon Zhao uint32_t flags; 331ca793736SShannon Zhao uint16_t spi_count; 332ca793736SShannon Zhao uint16_t spi_base; 333ca793736SShannon Zhao } QEMU_PACKED; 334ca793736SShannon Zhao 335ca793736SShannon Zhao typedef struct AcpiMadtGenericMsiFrame AcpiMadtGenericMsiFrame; 336ca793736SShannon Zhao 337b92ad394SPavel Fedin struct AcpiMadtGenericRedistributor { 338b92ad394SPavel Fedin ACPI_SUB_HEADER_DEF 339b92ad394SPavel Fedin uint16_t reserved; 340b92ad394SPavel Fedin uint64_t base_address; 341b92ad394SPavel Fedin uint32_t range_length; 342b92ad394SPavel Fedin } QEMU_PACKED; 343b92ad394SPavel Fedin 344b92ad394SPavel Fedin typedef struct AcpiMadtGenericRedistributor AcpiMadtGenericRedistributor; 345b92ad394SPavel Fedin 3461c2e4ea7SShannon Zhao struct AcpiMadtGenericTranslator { 3471c2e4ea7SShannon Zhao ACPI_SUB_HEADER_DEF 3481c2e4ea7SShannon Zhao uint16_t reserved; 3491c2e4ea7SShannon Zhao uint32_t translation_id; 3501c2e4ea7SShannon Zhao uint64_t base_address; 3511c2e4ea7SShannon Zhao uint32_t reserved2; 3521c2e4ea7SShannon Zhao } QEMU_PACKED; 3531c2e4ea7SShannon Zhao 3541c2e4ea7SShannon Zhao typedef struct AcpiMadtGenericTranslator AcpiMadtGenericTranslator; 3551c2e4ea7SShannon Zhao 35672c194f7SMichael S. Tsirkin /* 357ee246400SShannon Zhao * Generic Timer Description Table (GTDT) 358ee246400SShannon Zhao */ 3598dd845d3SAndrew Jones #define ACPI_GTDT_INTERRUPT_MODE_LEVEL (0 << 0) 360aca4bbf4SAndrew Jones #define ACPI_GTDT_INTERRUPT_MODE_EDGE (1 << 0) 361aca4bbf4SAndrew Jones #define ACPI_GTDT_CAP_ALWAYS_ON (1 << 2) 362ee246400SShannon Zhao 363ee246400SShannon Zhao struct AcpiGenericTimerTable { 364ee246400SShannon Zhao ACPI_TABLE_HEADER_DEF 365ee246400SShannon Zhao uint64_t counter_block_addresss; 366ee246400SShannon Zhao uint32_t reserved; 367ee246400SShannon Zhao uint32_t secure_el1_interrupt; 368ee246400SShannon Zhao uint32_t secure_el1_flags; 369ee246400SShannon Zhao uint32_t non_secure_el1_interrupt; 370ee246400SShannon Zhao uint32_t non_secure_el1_flags; 371ee246400SShannon Zhao uint32_t virtual_timer_interrupt; 372ee246400SShannon Zhao uint32_t virtual_timer_flags; 373ee246400SShannon Zhao uint32_t non_secure_el2_interrupt; 374ee246400SShannon Zhao uint32_t non_secure_el2_flags; 375ee246400SShannon Zhao uint64_t counter_read_block_address; 376ee246400SShannon Zhao uint32_t platform_timer_count; 377ee246400SShannon Zhao uint32_t platform_timer_offset; 378ee246400SShannon Zhao } QEMU_PACKED; 379ee246400SShannon Zhao typedef struct AcpiGenericTimerTable AcpiGenericTimerTable; 380ee246400SShannon Zhao 381ee246400SShannon Zhao /* 38272c194f7SMichael S. Tsirkin * HPET Description Table 38372c194f7SMichael S. Tsirkin */ 38472c194f7SMichael S. Tsirkin struct Acpi20Hpet { 38572c194f7SMichael S. Tsirkin ACPI_TABLE_HEADER_DEF /* ACPI common table header */ 38672c194f7SMichael S. Tsirkin uint32_t timer_block_id; 387b8e0f589SIgor Mammedov struct AcpiGenericAddress addr; 38872c194f7SMichael S. Tsirkin uint8_t hpet_number; 38972c194f7SMichael S. Tsirkin uint16_t min_tick; 39072c194f7SMichael S. Tsirkin uint8_t page_protect; 39172c194f7SMichael S. Tsirkin } QEMU_PACKED; 39272c194f7SMichael S. Tsirkin typedef struct Acpi20Hpet Acpi20Hpet; 39372c194f7SMichael S. Tsirkin 39472c194f7SMichael S. Tsirkin /* 39572c194f7SMichael S. Tsirkin * SRAT (NUMA topology description) table 39672c194f7SMichael S. Tsirkin */ 39772c194f7SMichael S. Tsirkin 3988b12e489SMichael S. Tsirkin struct AcpiSystemResourceAffinityTable { 39972c194f7SMichael S. Tsirkin ACPI_TABLE_HEADER_DEF 40072c194f7SMichael S. Tsirkin uint32_t reserved1; 40172c194f7SMichael S. Tsirkin uint32_t reserved2[2]; 40272c194f7SMichael S. Tsirkin } QEMU_PACKED; 40372c194f7SMichael S. Tsirkin typedef struct AcpiSystemResourceAffinityTable AcpiSystemResourceAffinityTable; 40472c194f7SMichael S. Tsirkin 405e6e400d5SShannon Zhao #define ACPI_SRAT_PROCESSOR_APIC 0 40672c194f7SMichael S. Tsirkin #define ACPI_SRAT_MEMORY 1 407e6e400d5SShannon Zhao #define ACPI_SRAT_PROCESSOR_x2APIC 2 408e6e400d5SShannon Zhao #define ACPI_SRAT_PROCESSOR_GICC 3 40972c194f7SMichael S. Tsirkin 4108b12e489SMichael S. Tsirkin struct AcpiSratProcessorAffinity { 41172c194f7SMichael S. Tsirkin ACPI_SUB_HEADER_DEF 41272c194f7SMichael S. Tsirkin uint8_t proximity_lo; 41372c194f7SMichael S. Tsirkin uint8_t local_apic_id; 41472c194f7SMichael S. Tsirkin uint32_t flags; 41572c194f7SMichael S. Tsirkin uint8_t local_sapic_eid; 41672c194f7SMichael S. Tsirkin uint8_t proximity_hi[3]; 41772c194f7SMichael S. Tsirkin uint32_t reserved; 41872c194f7SMichael S. Tsirkin } QEMU_PACKED; 41972c194f7SMichael S. Tsirkin typedef struct AcpiSratProcessorAffinity AcpiSratProcessorAffinity; 42072c194f7SMichael S. Tsirkin 4215eff33a2SIgor Mammedov struct AcpiSratProcessorX2ApicAffinity { 4225eff33a2SIgor Mammedov ACPI_SUB_HEADER_DEF 4235eff33a2SIgor Mammedov uint16_t reserved; 4245eff33a2SIgor Mammedov uint32_t proximity_domain; 4255eff33a2SIgor Mammedov uint32_t x2apic_id; 4265eff33a2SIgor Mammedov uint32_t flags; 4275eff33a2SIgor Mammedov uint32_t clk_domain; 4285eff33a2SIgor Mammedov uint32_t reserved2; 4295eff33a2SIgor Mammedov } QEMU_PACKED; 4305eff33a2SIgor Mammedov typedef struct AcpiSratProcessorX2ApicAffinity AcpiSratProcessorX2ApicAffinity; 4315eff33a2SIgor Mammedov 4328b12e489SMichael S. Tsirkin struct AcpiSratMemoryAffinity { 43372c194f7SMichael S. Tsirkin ACPI_SUB_HEADER_DEF 434ea9fcbd7SShannon Zhao uint32_t proximity; 43572c194f7SMichael S. Tsirkin uint16_t reserved1; 43672c194f7SMichael S. Tsirkin uint64_t base_addr; 43772c194f7SMichael S. Tsirkin uint64_t range_length; 43872c194f7SMichael S. Tsirkin uint32_t reserved2; 43972c194f7SMichael S. Tsirkin uint32_t flags; 44072c194f7SMichael S. Tsirkin uint32_t reserved3[2]; 44172c194f7SMichael S. Tsirkin } QEMU_PACKED; 44272c194f7SMichael S. Tsirkin typedef struct AcpiSratMemoryAffinity AcpiSratMemoryAffinity; 44372c194f7SMichael S. Tsirkin 4448b12e489SMichael S. Tsirkin struct AcpiSratProcessorGiccAffinity { 445e6e400d5SShannon Zhao ACPI_SUB_HEADER_DEF 446e6e400d5SShannon Zhao uint32_t proximity; 447e6e400d5SShannon Zhao uint32_t acpi_processor_uid; 448e6e400d5SShannon Zhao uint32_t flags; 449e6e400d5SShannon Zhao uint32_t clock_domain; 450e6e400d5SShannon Zhao } QEMU_PACKED; 451e6e400d5SShannon Zhao 452e6e400d5SShannon Zhao typedef struct AcpiSratProcessorGiccAffinity AcpiSratProcessorGiccAffinity; 453e6e400d5SShannon Zhao 45472c194f7SMichael S. Tsirkin /* PCI fw r3.0 MCFG table. */ 45572c194f7SMichael S. Tsirkin /* Subtable */ 45672c194f7SMichael S. Tsirkin struct AcpiMcfgAllocation { 45772c194f7SMichael S. Tsirkin uint64_t address; /* Base address, processor-relative */ 45872c194f7SMichael S. Tsirkin uint16_t pci_segment; /* PCI segment group number */ 45972c194f7SMichael S. Tsirkin uint8_t start_bus_number; /* Starting PCI Bus number */ 46072c194f7SMichael S. Tsirkin uint8_t end_bus_number; /* Final PCI Bus number */ 46172c194f7SMichael S. Tsirkin uint32_t reserved; 46272c194f7SMichael S. Tsirkin } QEMU_PACKED; 46372c194f7SMichael S. Tsirkin typedef struct AcpiMcfgAllocation AcpiMcfgAllocation; 46472c194f7SMichael S. Tsirkin 46572c194f7SMichael S. Tsirkin struct AcpiTableMcfg { 46672c194f7SMichael S. Tsirkin ACPI_TABLE_HEADER_DEF; 46772c194f7SMichael S. Tsirkin uint8_t reserved[8]; 46872c194f7SMichael S. Tsirkin AcpiMcfgAllocation allocation[0]; 46972c194f7SMichael S. Tsirkin } QEMU_PACKED; 47072c194f7SMichael S. Tsirkin typedef struct AcpiTableMcfg AcpiTableMcfg; 47172c194f7SMichael S. Tsirkin 472711b20b4SStefan Berger /* 473711b20b4SStefan Berger * TCPA Description Table 4745cb18b3dSStefan Berger * 4755cb18b3dSStefan Berger * Following Level 00, Rev 00.37 of specs: 4765cb18b3dSStefan Berger * http://www.trustedcomputinggroup.org/resources/tcg_acpi_specification 477711b20b4SStefan Berger */ 478711b20b4SStefan Berger struct Acpi20Tcpa { 479711b20b4SStefan Berger ACPI_TABLE_HEADER_DEF /* ACPI common table header */ 480711b20b4SStefan Berger uint16_t platform_class; 481711b20b4SStefan Berger uint32_t log_area_minimum_length; 482711b20b4SStefan Berger uint64_t log_area_start_address; 483711b20b4SStefan Berger } QEMU_PACKED; 484711b20b4SStefan Berger typedef struct Acpi20Tcpa Acpi20Tcpa; 485711b20b4SStefan Berger 4865cb18b3dSStefan Berger /* 4875cb18b3dSStefan Berger * TPM2 4885cb18b3dSStefan Berger * 4894a42fa0eSStefan Berger * Following Version 1.2, Revision 8 of specs: 4904a42fa0eSStefan Berger * https://trustedcomputinggroup.org/tcg-acpi-specification/ 4915cb18b3dSStefan Berger */ 4925cb18b3dSStefan Berger struct Acpi20TPM2 { 4935cb18b3dSStefan Berger ACPI_TABLE_HEADER_DEF 4945cb18b3dSStefan Berger uint16_t platform_class; 4955cb18b3dSStefan Berger uint16_t reserved; 4965cb18b3dSStefan Berger uint64_t control_area_address; 4975cb18b3dSStefan Berger uint32_t start_method; 4984a42fa0eSStefan Berger uint8_t start_method_params[12]; 4994a42fa0eSStefan Berger uint32_t log_area_minimum_length; 5004a42fa0eSStefan Berger uint64_t log_area_start_address; 5015cb18b3dSStefan Berger } QEMU_PACKED; 5025cb18b3dSStefan Berger typedef struct Acpi20TPM2 Acpi20TPM2; 5035cb18b3dSStefan Berger 504d4eb9119SLe Tan /* DMAR - DMA Remapping table r2.2 */ 505d4eb9119SLe Tan struct AcpiTableDmar { 506d4eb9119SLe Tan ACPI_TABLE_HEADER_DEF 507d4eb9119SLe Tan uint8_t host_address_width; /* Maximum DMA physical addressability */ 508d4eb9119SLe Tan uint8_t flags; 509d4eb9119SLe Tan uint8_t reserved[10]; 510d4eb9119SLe Tan } QEMU_PACKED; 511d4eb9119SLe Tan typedef struct AcpiTableDmar AcpiTableDmar; 512d4eb9119SLe Tan 513d4eb9119SLe Tan /* Masks for Flags field above */ 514d4eb9119SLe Tan #define ACPI_DMAR_INTR_REMAP 1 515d4eb9119SLe Tan #define ACPI_DMAR_X2APIC_OPT_OUT (1 << 1) 516d4eb9119SLe Tan 517d4eb9119SLe Tan /* Values for sub-structure type for DMAR */ 518d4eb9119SLe Tan enum { 519d4eb9119SLe Tan ACPI_DMAR_TYPE_HARDWARE_UNIT = 0, /* DRHD */ 520d4eb9119SLe Tan ACPI_DMAR_TYPE_RESERVED_MEMORY = 1, /* RMRR */ 521d4eb9119SLe Tan ACPI_DMAR_TYPE_ATSR = 2, /* ATSR */ 522d4eb9119SLe Tan ACPI_DMAR_TYPE_HARDWARE_AFFINITY = 3, /* RHSR */ 523d4eb9119SLe Tan ACPI_DMAR_TYPE_ANDD = 4, /* ANDD */ 524d4eb9119SLe Tan ACPI_DMAR_TYPE_RESERVED = 5 /* Reserved for furture use */ 525d4eb9119SLe Tan }; 526d4eb9119SLe Tan 527d4eb9119SLe Tan /* 528d4eb9119SLe Tan * Sub-structures for DMAR 529d4eb9119SLe Tan */ 530cfc13df4SPeter Xu 531cfc13df4SPeter Xu /* Device scope structure for DRHD. */ 532cfc13df4SPeter Xu struct AcpiDmarDeviceScope { 533cfc13df4SPeter Xu uint8_t entry_type; 534cfc13df4SPeter Xu uint8_t length; 535cfc13df4SPeter Xu uint16_t reserved; 536cfc13df4SPeter Xu uint8_t enumeration_id; 537cfc13df4SPeter Xu uint8_t bus; 5381b39bc1cSPeter Xu struct { 5391b39bc1cSPeter Xu uint8_t device; 5401b39bc1cSPeter Xu uint8_t function; 5411b39bc1cSPeter Xu } path[0]; 542cfc13df4SPeter Xu } QEMU_PACKED; 543cfc13df4SPeter Xu typedef struct AcpiDmarDeviceScope AcpiDmarDeviceScope; 544cfc13df4SPeter Xu 545d4eb9119SLe Tan /* Type 0: Hardware Unit Definition */ 546d4eb9119SLe Tan struct AcpiDmarHardwareUnit { 547d4eb9119SLe Tan uint16_t type; 548d4eb9119SLe Tan uint16_t length; 549d4eb9119SLe Tan uint8_t flags; 550d4eb9119SLe Tan uint8_t reserved; 551d4eb9119SLe Tan uint16_t pci_segment; /* The PCI Segment associated with this unit */ 552d4eb9119SLe Tan uint64_t address; /* Base address of remapping hardware register-set */ 553cfc13df4SPeter Xu AcpiDmarDeviceScope scope[0]; 554d4eb9119SLe Tan } QEMU_PACKED; 555d4eb9119SLe Tan typedef struct AcpiDmarHardwareUnit AcpiDmarHardwareUnit; 556d4eb9119SLe Tan 557bd2baaccSJason Wang /* Type 2: Root Port ATS Capability Reporting Structure */ 558bd2baaccSJason Wang struct AcpiDmarRootPortATS { 559bd2baaccSJason Wang uint16_t type; 560bd2baaccSJason Wang uint16_t length; 561bd2baaccSJason Wang uint8_t flags; 562bd2baaccSJason Wang uint8_t reserved; 563bd2baaccSJason Wang uint16_t pci_segment; 564bd2baaccSJason Wang AcpiDmarDeviceScope scope[0]; 565bd2baaccSJason Wang } QEMU_PACKED; 566bd2baaccSJason Wang typedef struct AcpiDmarRootPortATS AcpiDmarRootPortATS; 567bd2baaccSJason Wang 568d4eb9119SLe Tan /* Masks for Flags field above */ 569d4eb9119SLe Tan #define ACPI_DMAR_INCLUDE_PCI_ALL 1 570bd2baaccSJason Wang #define ACPI_DMAR_ATSR_ALL_PORTS 1 571d4eb9119SLe Tan 57216fc326aSPrem Mallappa /* 57316fc326aSPrem Mallappa * Input Output Remapping Table (IORT) 57416fc326aSPrem Mallappa * Conforms to "IO Remapping Table System Software on ARM Platforms", 57516fc326aSPrem Mallappa * Document number: ARM DEN 0049B, October 2015 57616fc326aSPrem Mallappa */ 57716fc326aSPrem Mallappa 57816fc326aSPrem Mallappa struct AcpiIortTable { 57916fc326aSPrem Mallappa ACPI_TABLE_HEADER_DEF /* ACPI common table header */ 58016fc326aSPrem Mallappa uint32_t node_count; 58116fc326aSPrem Mallappa uint32_t node_offset; 58216fc326aSPrem Mallappa uint32_t reserved; 58316fc326aSPrem Mallappa } QEMU_PACKED; 58416fc326aSPrem Mallappa typedef struct AcpiIortTable AcpiIortTable; 58516fc326aSPrem Mallappa 58616fc326aSPrem Mallappa /* 58716fc326aSPrem Mallappa * IORT node types 58816fc326aSPrem Mallappa */ 58916fc326aSPrem Mallappa 59016fc326aSPrem Mallappa #define ACPI_IORT_NODE_HEADER_DEF /* Node format common fields */ \ 59116fc326aSPrem Mallappa uint8_t type; \ 59216fc326aSPrem Mallappa uint16_t length; \ 59316fc326aSPrem Mallappa uint8_t revision; \ 59416fc326aSPrem Mallappa uint32_t reserved; \ 59516fc326aSPrem Mallappa uint32_t mapping_count; \ 59616fc326aSPrem Mallappa uint32_t mapping_offset; 59716fc326aSPrem Mallappa 59816fc326aSPrem Mallappa /* Values for node Type above */ 59916fc326aSPrem Mallappa enum { 60016fc326aSPrem Mallappa ACPI_IORT_NODE_ITS_GROUP = 0x00, 60116fc326aSPrem Mallappa ACPI_IORT_NODE_NAMED_COMPONENT = 0x01, 60216fc326aSPrem Mallappa ACPI_IORT_NODE_PCI_ROOT_COMPLEX = 0x02, 60316fc326aSPrem Mallappa ACPI_IORT_NODE_SMMU = 0x03, 60416fc326aSPrem Mallappa ACPI_IORT_NODE_SMMU_V3 = 0x04 60516fc326aSPrem Mallappa }; 60616fc326aSPrem Mallappa 60716fc326aSPrem Mallappa struct AcpiIortIdMapping { 60816fc326aSPrem Mallappa uint32_t input_base; 60916fc326aSPrem Mallappa uint32_t id_count; 61016fc326aSPrem Mallappa uint32_t output_base; 61116fc326aSPrem Mallappa uint32_t output_reference; 61216fc326aSPrem Mallappa uint32_t flags; 61316fc326aSPrem Mallappa } QEMU_PACKED; 61416fc326aSPrem Mallappa typedef struct AcpiIortIdMapping AcpiIortIdMapping; 61516fc326aSPrem Mallappa 61616fc326aSPrem Mallappa struct AcpiIortMemoryAccess { 61716fc326aSPrem Mallappa uint32_t cache_coherency; 61816fc326aSPrem Mallappa uint8_t hints; 61916fc326aSPrem Mallappa uint16_t reserved; 62016fc326aSPrem Mallappa uint8_t memory_flags; 62116fc326aSPrem Mallappa } QEMU_PACKED; 62216fc326aSPrem Mallappa typedef struct AcpiIortMemoryAccess AcpiIortMemoryAccess; 62316fc326aSPrem Mallappa 62416fc326aSPrem Mallappa struct AcpiIortItsGroup { 62516fc326aSPrem Mallappa ACPI_IORT_NODE_HEADER_DEF 62616fc326aSPrem Mallappa uint32_t its_count; 62716fc326aSPrem Mallappa uint32_t identifiers[0]; 62816fc326aSPrem Mallappa } QEMU_PACKED; 62916fc326aSPrem Mallappa typedef struct AcpiIortItsGroup AcpiIortItsGroup; 63016fc326aSPrem Mallappa 631*a703b4f6SPrem Mallappa struct AcpiIortSmmu3 { 632*a703b4f6SPrem Mallappa ACPI_IORT_NODE_HEADER_DEF 633*a703b4f6SPrem Mallappa uint64_t base_address; 634*a703b4f6SPrem Mallappa uint32_t flags; 635*a703b4f6SPrem Mallappa uint32_t reserved2; 636*a703b4f6SPrem Mallappa uint64_t vatos_address; 637*a703b4f6SPrem Mallappa uint32_t model; 638*a703b4f6SPrem Mallappa uint32_t event_gsiv; 639*a703b4f6SPrem Mallappa uint32_t pri_gsiv; 640*a703b4f6SPrem Mallappa uint32_t gerr_gsiv; 641*a703b4f6SPrem Mallappa uint32_t sync_gsiv; 642*a703b4f6SPrem Mallappa AcpiIortIdMapping id_mapping_array[0]; 643*a703b4f6SPrem Mallappa } QEMU_PACKED; 644*a703b4f6SPrem Mallappa typedef struct AcpiIortSmmu3 AcpiIortSmmu3; 645*a703b4f6SPrem Mallappa 64616fc326aSPrem Mallappa struct AcpiIortRC { 64716fc326aSPrem Mallappa ACPI_IORT_NODE_HEADER_DEF 64816fc326aSPrem Mallappa AcpiIortMemoryAccess memory_properties; 64916fc326aSPrem Mallappa uint32_t ats_attribute; 65016fc326aSPrem Mallappa uint32_t pci_segment_number; 65116fc326aSPrem Mallappa AcpiIortIdMapping id_mapping_array[0]; 65216fc326aSPrem Mallappa } QEMU_PACKED; 65316fc326aSPrem Mallappa typedef struct AcpiIortRC AcpiIortRC; 65416fc326aSPrem Mallappa 65572c194f7SMichael S. Tsirkin #endif 656