xref: /qemu/include/hw/acpi/acpi-defs.h (revision a703b4f6c1ee25090384fe75074f2571d7b69e02)
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