xref: /qemu/include/hw/acpi/acpi-defs.h (revision 937d1b58714b4002dd0fb7c3573c42b1c017e61b)
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 
7872c194f7SMichael S. Tsirkin /*
79c2f7c0c3SShannon Zhao  * ACPI Fixed ACPI Description Table (FADT)
8072c194f7SMichael S. Tsirkin  */
81c2f7c0c3SShannon Zhao #define ACPI_FADT_COMMON_DEF /* FADT common definition */ \
82c2f7c0c3SShannon Zhao     ACPI_TABLE_HEADER_DEF    /* ACPI common table header */ \
83c2f7c0c3SShannon Zhao     uint32_t firmware_ctrl;  /* Physical address of FACS */ \
84c2f7c0c3SShannon Zhao     uint32_t dsdt;         /* Physical address of DSDT */ \
85c2f7c0c3SShannon Zhao     uint8_t  model;        /* System Interrupt Model */ \
86c2f7c0c3SShannon Zhao     uint8_t  reserved1;    /* Reserved */ \
87c2f7c0c3SShannon Zhao     uint16_t sci_int;      /* System vector of SCI interrupt */ \
88c2f7c0c3SShannon Zhao     uint32_t smi_cmd;      /* Port address of SMI command port */ \
89c2f7c0c3SShannon Zhao     uint8_t  acpi_enable;  /* Value to write to smi_cmd to enable ACPI */ \
90c2f7c0c3SShannon Zhao     uint8_t  acpi_disable; /* Value to write to smi_cmd to disable ACPI */ \
91c2f7c0c3SShannon Zhao     /* Value to write to SMI CMD to enter S4BIOS state */ \
92c2f7c0c3SShannon Zhao     uint8_t  S4bios_req; \
93c2f7c0c3SShannon Zhao     uint8_t  reserved2;    /* Reserved - must be zero */ \
94c2f7c0c3SShannon Zhao     /* Port address of Power Mgt 1a acpi_event Reg Blk */ \
95c2f7c0c3SShannon Zhao     uint32_t pm1a_evt_blk; \
96c2f7c0c3SShannon Zhao     /* Port address of Power Mgt 1b acpi_event Reg Blk */ \
97c2f7c0c3SShannon Zhao     uint32_t pm1b_evt_blk; \
98c2f7c0c3SShannon Zhao     uint32_t pm1a_cnt_blk; /* Port address of Power Mgt 1a Control Reg Blk */ \
99c2f7c0c3SShannon Zhao     uint32_t pm1b_cnt_blk; /* Port address of Power Mgt 1b Control Reg Blk */ \
100c2f7c0c3SShannon Zhao     uint32_t pm2_cnt_blk;  /* Port address of Power Mgt 2 Control Reg Blk */ \
101c2f7c0c3SShannon Zhao     uint32_t pm_tmr_blk;   /* Port address of Power Mgt Timer Ctrl Reg Blk */ \
102c2f7c0c3SShannon Zhao     /* Port addr of General Purpose acpi_event 0 Reg Blk */ \
103c2f7c0c3SShannon Zhao     uint32_t gpe0_blk; \
104c2f7c0c3SShannon Zhao     /* Port addr of General Purpose acpi_event 1 Reg Blk */ \
105c2f7c0c3SShannon Zhao     uint32_t gpe1_blk; \
106c2f7c0c3SShannon Zhao     uint8_t  pm1_evt_len;  /* Byte length of ports at pm1_x_evt_blk */ \
107c2f7c0c3SShannon Zhao     uint8_t  pm1_cnt_len;  /* Byte length of ports at pm1_x_cnt_blk */ \
108c2f7c0c3SShannon Zhao     uint8_t  pm2_cnt_len;  /* Byte Length of ports at pm2_cnt_blk */ \
109c2f7c0c3SShannon Zhao     uint8_t  pm_tmr_len;   /* Byte Length of ports at pm_tm_blk */ \
110c2f7c0c3SShannon Zhao     uint8_t  gpe0_blk_len; /* Byte Length of ports at gpe0_blk */ \
111c2f7c0c3SShannon Zhao     uint8_t  gpe1_blk_len; /* Byte Length of ports at gpe1_blk */ \
112c2f7c0c3SShannon Zhao     uint8_t  gpe1_base;    /* Offset in gpe model where gpe1 events start */ \
113c2f7c0c3SShannon Zhao     uint8_t  reserved3;    /* Reserved */ \
114c2f7c0c3SShannon Zhao     uint16_t plvl2_lat;    /* Worst case HW latency to enter/exit C2 state */ \
115c2f7c0c3SShannon Zhao     uint16_t plvl3_lat;    /* Worst case HW latency to enter/exit C3 state */ \
116c2f7c0c3SShannon Zhao     uint16_t flush_size;   /* Size of area read to flush caches */ \
117c2f7c0c3SShannon Zhao     uint16_t flush_stride; /* Stride used in flushing caches */ \
118c2f7c0c3SShannon Zhao     uint8_t  duty_offset;  /* Bit location of duty cycle field in p_cnt reg */ \
119c2f7c0c3SShannon Zhao     uint8_t  duty_width;   /* Bit width of duty cycle field in p_cnt reg */ \
120c2f7c0c3SShannon Zhao     uint8_t  day_alrm;     /* Index to day-of-month alarm in RTC CMOS RAM */ \
121c2f7c0c3SShannon Zhao     uint8_t  mon_alrm;     /* Index to month-of-year alarm in RTC CMOS RAM */ \
12277af8a2bSPhil Dennis-Jordan     uint8_t  century;      /* Index to century in RTC CMOS RAM */ \
12377af8a2bSPhil Dennis-Jordan     /* IA-PC Boot Architecture Flags (see below for individual flags) */ \
12477af8a2bSPhil Dennis-Jordan     uint16_t boot_flags; \
12577af8a2bSPhil Dennis-Jordan     uint8_t reserved;    /* Reserved, must be zero */ \
12677af8a2bSPhil Dennis-Jordan     /* Miscellaneous flag bits (see below for individual flags) */ \
12777af8a2bSPhil Dennis-Jordan     uint32_t flags; \
12877af8a2bSPhil Dennis-Jordan     /* 64-bit address of the Reset register */ \
12977af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress reset_register; \
13077af8a2bSPhil Dennis-Jordan     /* Value to write to the reset_register port to reset the system */ \
13177af8a2bSPhil Dennis-Jordan     uint8_t reset_value; \
13277af8a2bSPhil Dennis-Jordan     /* ARM-Specific Boot Flags (see below for individual flags) (ACPI 5.1) */ \
13377af8a2bSPhil Dennis-Jordan     uint16_t arm_boot_flags; \
13477af8a2bSPhil Dennis-Jordan     uint8_t minor_revision;  /* FADT Minor Revision (ACPI 5.1) */ \
1355ee85347SArd Biesheuvel     uint64_t x_facs;          /* 64-bit physical address of FACS */ \
1365ee85347SArd Biesheuvel     uint64_t x_dsdt;          /* 64-bit physical address of DSDT */ \
13777af8a2bSPhil Dennis-Jordan     /* 64-bit Extended Power Mgt 1a Event Reg Blk address */ \
13877af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xpm1a_event_block; \
13977af8a2bSPhil Dennis-Jordan     /* 64-bit Extended Power Mgt 1b Event Reg Blk address */ \
14077af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xpm1b_event_block; \
14177af8a2bSPhil Dennis-Jordan     /* 64-bit Extended Power Mgt 1a Control Reg Blk address */ \
14277af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xpm1a_control_block; \
14377af8a2bSPhil Dennis-Jordan     /* 64-bit Extended Power Mgt 1b Control Reg Blk address */ \
14477af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xpm1b_control_block; \
14577af8a2bSPhil Dennis-Jordan     /* 64-bit Extended Power Mgt 2 Control Reg Blk address */ \
14677af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xpm2_control_block; \
14777af8a2bSPhil Dennis-Jordan     /* 64-bit Extended Power Mgt Timer Ctrl Reg Blk address */ \
14877af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xpm_timer_block; \
14977af8a2bSPhil Dennis-Jordan     /* 64-bit Extended General Purpose Event 0 Reg Blk address */ \
15077af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xgpe0_block; \
15177af8a2bSPhil Dennis-Jordan     /* 64-bit Extended General Purpose Event 1 Reg Blk address */ \
15277af8a2bSPhil Dennis-Jordan     struct AcpiGenericAddress xgpe1_block; \
15372c194f7SMichael S. Tsirkin 
154c2f7c0c3SShannon Zhao struct AcpiGenericAddress {
155c2f7c0c3SShannon Zhao     uint8_t space_id;        /* Address space where struct or register exists */
156c2f7c0c3SShannon Zhao     uint8_t bit_width;       /* Size in bits of given register */
157c2f7c0c3SShannon Zhao     uint8_t bit_offset;      /* Bit offset within the register */
158b8e0f589SIgor Mammedov     uint8_t access_width;    /* ACPI 3.0: Minimum Access size (ACPI 3.0),
159b8e0f589SIgor Mammedov                                 ACPI 2.0: Reserved, Table 5-1 */
160c2f7c0c3SShannon Zhao     uint64_t address;        /* 64-bit address of struct or register */
161c2f7c0c3SShannon Zhao } QEMU_PACKED;
162c2f7c0c3SShannon Zhao 
16377af8a2bSPhil Dennis-Jordan struct AcpiFadtDescriptorRev3 {
16477af8a2bSPhil Dennis-Jordan     ACPI_FADT_COMMON_DEF
16577af8a2bSPhil Dennis-Jordan } QEMU_PACKED;
16677af8a2bSPhil Dennis-Jordan typedef struct AcpiFadtDescriptorRev3 AcpiFadtDescriptorRev3;
16777af8a2bSPhil Dennis-Jordan 
168c2f7c0c3SShannon Zhao struct AcpiFadtDescriptorRev5_1 {
169c2f7c0c3SShannon Zhao     ACPI_FADT_COMMON_DEF
170c2f7c0c3SShannon Zhao     /* 64-bit Sleep Control register (ACPI 5.0) */
171c2f7c0c3SShannon Zhao     struct AcpiGenericAddress sleep_control;
172c2f7c0c3SShannon Zhao     /* 64-bit Sleep Status register (ACPI 5.0) */
173c2f7c0c3SShannon Zhao     struct AcpiGenericAddress sleep_status;
174c2f7c0c3SShannon Zhao } QEMU_PACKED;
175c2f7c0c3SShannon Zhao 
176c2f7c0c3SShannon Zhao typedef struct AcpiFadtDescriptorRev5_1 AcpiFadtDescriptorRev5_1;
177c2f7c0c3SShannon Zhao 
178*937d1b58SIgor Mammedov typedef struct AcpiFadtData {
179*937d1b58SIgor Mammedov     struct AcpiGenericAddress pm1a_cnt;   /* PM1a_CNT_BLK */
180*937d1b58SIgor Mammedov     struct AcpiGenericAddress pm1a_evt;   /* PM1a_EVT_BLK */
181*937d1b58SIgor Mammedov     struct AcpiGenericAddress pm_tmr;    /* PM_TMR_BLK */
182*937d1b58SIgor Mammedov     struct AcpiGenericAddress gpe0_blk;  /* GPE0_BLK */
183*937d1b58SIgor Mammedov     struct AcpiGenericAddress reset_reg; /* RESET_REG */
184*937d1b58SIgor Mammedov     uint8_t reset_val;         /* RESET_VALUE */
185*937d1b58SIgor Mammedov     uint8_t  rev;              /* Revision */
186*937d1b58SIgor Mammedov     uint32_t flags;            /* Flags */
187*937d1b58SIgor Mammedov     uint32_t smi_cmd;          /* SMI_CMD */
188*937d1b58SIgor Mammedov     uint16_t sci_int;          /* SCI_INT */
189*937d1b58SIgor Mammedov     uint8_t  int_model;        /* INT_MODEL */
190*937d1b58SIgor Mammedov     uint8_t  acpi_enable_cmd;  /* ACPI_ENABLE */
191*937d1b58SIgor Mammedov     uint8_t  acpi_disable_cmd; /* ACPI_DISABLE */
192*937d1b58SIgor Mammedov     uint8_t  rtc_century;      /* CENTURY */
193*937d1b58SIgor Mammedov     uint16_t plvl2_lat;        /* P_LVL2_LAT */
194*937d1b58SIgor Mammedov     uint16_t plvl3_lat;        /* P_LVL3_LAT */
195*937d1b58SIgor Mammedov 
196*937d1b58SIgor Mammedov     /*
197*937d1b58SIgor Mammedov      * respective tables offsets within ACPI_BUILD_TABLE_FILE,
198*937d1b58SIgor Mammedov      * NULL if table doesn't exist (in that case field's value
199*937d1b58SIgor Mammedov      * won't be patched by linker and will be kept set to 0)
200*937d1b58SIgor Mammedov      */
201*937d1b58SIgor Mammedov     unsigned *facs_tbl_offset; /* FACS offset in */
202*937d1b58SIgor Mammedov     unsigned *dsdt_tbl_offset;
203*937d1b58SIgor Mammedov     unsigned *xdsdt_tbl_offset;
204*937d1b58SIgor Mammedov } AcpiFadtData;
205*937d1b58SIgor Mammedov 
2068c92c6a4SAndrew Jones #define ACPI_FADT_ARM_PSCI_COMPLIANT  (1 << 0)
2078c92c6a4SAndrew Jones #define ACPI_FADT_ARM_PSCI_USE_HVC    (1 << 1)
208c2f7c0c3SShannon Zhao 
20972c194f7SMichael S. Tsirkin /*
210b8a0d75eSAndrew Jones  * Serial Port Console Redirection Table (SPCR), Rev. 1.02
211b8a0d75eSAndrew Jones  *
212b8a0d75eSAndrew Jones  * For .interface_type see Debug Port Table 2 (DBG2) serial port
213b8a0d75eSAndrew Jones  * subtypes in Table 3, Rev. May 22, 2012
214b8a0d75eSAndrew Jones  */
215b8a0d75eSAndrew Jones struct AcpiSerialPortConsoleRedirection {
216b8a0d75eSAndrew Jones     ACPI_TABLE_HEADER_DEF
217b8a0d75eSAndrew Jones     uint8_t  interface_type;
218b8a0d75eSAndrew Jones     uint8_t  reserved1[3];
219b8a0d75eSAndrew Jones     struct AcpiGenericAddress base_address;
220b8a0d75eSAndrew Jones     uint8_t  interrupt_types;
221b8a0d75eSAndrew Jones     uint8_t  irq;
222b8a0d75eSAndrew Jones     uint32_t gsi;
223b8a0d75eSAndrew Jones     uint8_t  baud;
224b8a0d75eSAndrew Jones     uint8_t  parity;
225b8a0d75eSAndrew Jones     uint8_t  stopbits;
226b8a0d75eSAndrew Jones     uint8_t  flowctrl;
227b8a0d75eSAndrew Jones     uint8_t  term_type;
228b8a0d75eSAndrew Jones     uint8_t  reserved2;
229b8a0d75eSAndrew Jones     uint16_t pci_device_id;
230b8a0d75eSAndrew Jones     uint16_t pci_vendor_id;
231b8a0d75eSAndrew Jones     uint8_t  pci_bus;
232b8a0d75eSAndrew Jones     uint8_t  pci_slot;
233b8a0d75eSAndrew Jones     uint8_t  pci_func;
234b8a0d75eSAndrew Jones     uint32_t pci_flags;
235b8a0d75eSAndrew Jones     uint8_t  pci_seg;
236b8a0d75eSAndrew Jones     uint32_t reserved3;
237b8a0d75eSAndrew Jones } QEMU_PACKED;
238b8a0d75eSAndrew Jones typedef struct AcpiSerialPortConsoleRedirection
239b8a0d75eSAndrew Jones                AcpiSerialPortConsoleRedirection;
240b8a0d75eSAndrew Jones 
241b8a0d75eSAndrew Jones /*
24272c194f7SMichael S. Tsirkin  * ACPI 1.0 Root System Description Table (RSDT)
24372c194f7SMichael S. Tsirkin  */
2448b12e489SMichael S. Tsirkin struct AcpiRsdtDescriptorRev1 {
24572c194f7SMichael S. Tsirkin     ACPI_TABLE_HEADER_DEF       /* ACPI common table header */
24672c194f7SMichael S. Tsirkin     uint32_t table_offset_entry[0];  /* Array of pointers to other */
24772c194f7SMichael S. Tsirkin     /* ACPI tables */
24872c194f7SMichael S. Tsirkin } QEMU_PACKED;
24972c194f7SMichael S. Tsirkin typedef struct AcpiRsdtDescriptorRev1 AcpiRsdtDescriptorRev1;
25072c194f7SMichael S. Tsirkin 
25172c194f7SMichael S. Tsirkin /*
252cb51ac2fSArd Biesheuvel  * ACPI 2.0 eXtended System Description Table (XSDT)
253cb51ac2fSArd Biesheuvel  */
2548b12e489SMichael S. Tsirkin struct AcpiXsdtDescriptorRev2 {
255cb51ac2fSArd Biesheuvel     ACPI_TABLE_HEADER_DEF       /* ACPI common table header */
256cb51ac2fSArd Biesheuvel     uint64_t table_offset_entry[0];  /* Array of pointers to other */
257cb51ac2fSArd Biesheuvel     /* ACPI tables */
258cb51ac2fSArd Biesheuvel } QEMU_PACKED;
259cb51ac2fSArd Biesheuvel typedef struct AcpiXsdtDescriptorRev2 AcpiXsdtDescriptorRev2;
260cb51ac2fSArd Biesheuvel 
261cb51ac2fSArd Biesheuvel /*
26272c194f7SMichael S. Tsirkin  * ACPI 1.0 Firmware ACPI Control Structure (FACS)
26372c194f7SMichael S. Tsirkin  */
2648b12e489SMichael S. Tsirkin struct AcpiFacsDescriptorRev1 {
26572c194f7SMichael S. Tsirkin     uint32_t signature;           /* ACPI Signature */
26672c194f7SMichael S. Tsirkin     uint32_t length;                 /* Length of structure, in bytes */
26772c194f7SMichael S. Tsirkin     uint32_t hardware_signature;     /* Hardware configuration signature */
26872c194f7SMichael S. Tsirkin     uint32_t firmware_waking_vector; /* ACPI OS waking vector */
26972c194f7SMichael S. Tsirkin     uint32_t global_lock;            /* Global Lock */
27072c194f7SMichael S. Tsirkin     uint32_t flags;
27172c194f7SMichael S. Tsirkin     uint8_t  resverved3 [40];        /* Reserved - must be zero */
27272c194f7SMichael S. Tsirkin } QEMU_PACKED;
27372c194f7SMichael S. Tsirkin typedef struct AcpiFacsDescriptorRev1 AcpiFacsDescriptorRev1;
27472c194f7SMichael S. Tsirkin 
27572c194f7SMichael S. Tsirkin /*
27672c194f7SMichael S. Tsirkin  * Differentiated System Description Table (DSDT)
27772c194f7SMichael S. Tsirkin  */
27872c194f7SMichael S. Tsirkin 
27972c194f7SMichael S. Tsirkin /*
28072c194f7SMichael S. Tsirkin  * MADT values and structures
28172c194f7SMichael S. Tsirkin  */
28272c194f7SMichael S. Tsirkin 
28372c194f7SMichael S. Tsirkin /* Values for MADT PCATCompat */
28472c194f7SMichael S. Tsirkin 
28572c194f7SMichael S. Tsirkin #define ACPI_DUAL_PIC                0
28672c194f7SMichael S. Tsirkin #define ACPI_MULTIPLE_APIC           1
28772c194f7SMichael S. Tsirkin 
28872c194f7SMichael S. Tsirkin /* Master MADT */
28972c194f7SMichael S. Tsirkin 
2908b12e489SMichael S. Tsirkin struct AcpiMultipleApicTable {
29172c194f7SMichael S. Tsirkin     ACPI_TABLE_HEADER_DEF     /* ACPI common table header */
29272c194f7SMichael S. Tsirkin     uint32_t local_apic_address;     /* Physical address of local APIC */
29372c194f7SMichael S. Tsirkin     uint32_t flags;
29472c194f7SMichael S. Tsirkin } QEMU_PACKED;
29572c194f7SMichael S. Tsirkin typedef struct AcpiMultipleApicTable AcpiMultipleApicTable;
29672c194f7SMichael S. Tsirkin 
29772c194f7SMichael S. Tsirkin /* Values for Type in APIC sub-headers */
29872c194f7SMichael S. Tsirkin 
29972c194f7SMichael S. Tsirkin #define ACPI_APIC_PROCESSOR          0
30072c194f7SMichael S. Tsirkin #define ACPI_APIC_IO                 1
30172c194f7SMichael S. Tsirkin #define ACPI_APIC_XRUPT_OVERRIDE     2
30272c194f7SMichael S. Tsirkin #define ACPI_APIC_NMI                3
30372c194f7SMichael S. Tsirkin #define ACPI_APIC_LOCAL_NMI          4
30472c194f7SMichael S. Tsirkin #define ACPI_APIC_ADDRESS_OVERRIDE   5
30572c194f7SMichael S. Tsirkin #define ACPI_APIC_IO_SAPIC           6
30672c194f7SMichael S. Tsirkin #define ACPI_APIC_LOCAL_SAPIC        7
30772c194f7SMichael S. Tsirkin #define ACPI_APIC_XRUPT_SOURCE       8
308982d06c5SShannon Zhao #define ACPI_APIC_LOCAL_X2APIC       9
309982d06c5SShannon Zhao #define ACPI_APIC_LOCAL_X2APIC_NMI      10
3106e2ed65fSAndrew Jones #define ACPI_APIC_GENERIC_CPU_INTERFACE 11
311982d06c5SShannon Zhao #define ACPI_APIC_GENERIC_DISTRIBUTOR   12
312982d06c5SShannon Zhao #define ACPI_APIC_GENERIC_MSI_FRAME     13
313982d06c5SShannon Zhao #define ACPI_APIC_GENERIC_REDISTRIBUTOR 14
3141c2e4ea7SShannon Zhao #define ACPI_APIC_GENERIC_TRANSLATOR    15
3151c2e4ea7SShannon Zhao #define ACPI_APIC_RESERVED              16   /* 16 and greater are reserved */
31672c194f7SMichael S. Tsirkin 
31772c194f7SMichael S. Tsirkin /*
31872c194f7SMichael S. Tsirkin  * MADT sub-structures (Follow MULTIPLE_APIC_DESCRIPTION_TABLE)
31972c194f7SMichael S. Tsirkin  */
32072c194f7SMichael S. Tsirkin #define ACPI_SUB_HEADER_DEF   /* Common ACPI sub-structure header */\
32172c194f7SMichael S. Tsirkin     uint8_t  type;                               \
32272c194f7SMichael S. Tsirkin     uint8_t  length;
32372c194f7SMichael S. Tsirkin 
32472c194f7SMichael S. Tsirkin /* Sub-structures for MADT */
32572c194f7SMichael S. Tsirkin 
3268b12e489SMichael S. Tsirkin struct AcpiMadtProcessorApic {
32772c194f7SMichael S. Tsirkin     ACPI_SUB_HEADER_DEF
32872c194f7SMichael S. Tsirkin     uint8_t  processor_id;           /* ACPI processor id */
32972c194f7SMichael S. Tsirkin     uint8_t  local_apic_id;          /* Processor's local APIC id */
33072c194f7SMichael S. Tsirkin     uint32_t flags;
33172c194f7SMichael S. Tsirkin } QEMU_PACKED;
33272c194f7SMichael S. Tsirkin typedef struct AcpiMadtProcessorApic AcpiMadtProcessorApic;
33372c194f7SMichael S. Tsirkin 
3348b12e489SMichael S. Tsirkin struct AcpiMadtIoApic {
33572c194f7SMichael S. Tsirkin     ACPI_SUB_HEADER_DEF
33672c194f7SMichael S. Tsirkin     uint8_t  io_apic_id;             /* I/O APIC ID */
33772c194f7SMichael S. Tsirkin     uint8_t  reserved;               /* Reserved - must be zero */
33872c194f7SMichael S. Tsirkin     uint32_t address;                /* APIC physical address */
33972c194f7SMichael S. Tsirkin     uint32_t interrupt;              /* Global system interrupt where INTI
34072c194f7SMichael S. Tsirkin                                  * lines start */
34172c194f7SMichael S. Tsirkin } QEMU_PACKED;
34272c194f7SMichael S. Tsirkin typedef struct AcpiMadtIoApic AcpiMadtIoApic;
34372c194f7SMichael S. Tsirkin 
34472c194f7SMichael S. Tsirkin struct AcpiMadtIntsrcovr {
34572c194f7SMichael S. Tsirkin     ACPI_SUB_HEADER_DEF
34672c194f7SMichael S. Tsirkin     uint8_t  bus;
34772c194f7SMichael S. Tsirkin     uint8_t  source;
34872c194f7SMichael S. Tsirkin     uint32_t gsi;
34972c194f7SMichael S. Tsirkin     uint16_t flags;
35072c194f7SMichael S. Tsirkin } QEMU_PACKED;
35172c194f7SMichael S. Tsirkin typedef struct AcpiMadtIntsrcovr AcpiMadtIntsrcovr;
35272c194f7SMichael S. Tsirkin 
35372c194f7SMichael S. Tsirkin struct AcpiMadtLocalNmi {
35472c194f7SMichael S. Tsirkin     ACPI_SUB_HEADER_DEF
35572c194f7SMichael S. Tsirkin     uint8_t  processor_id;           /* ACPI processor id */
35672c194f7SMichael S. Tsirkin     uint16_t flags;                  /* MPS INTI flags */
35772c194f7SMichael S. Tsirkin     uint8_t  lint;                   /* Local APIC LINT# */
35872c194f7SMichael S. Tsirkin } QEMU_PACKED;
35972c194f7SMichael S. Tsirkin typedef struct AcpiMadtLocalNmi AcpiMadtLocalNmi;
36072c194f7SMichael S. Tsirkin 
361e2c95939SIgor Mammedov struct AcpiMadtProcessorX2Apic {
362e2c95939SIgor Mammedov     ACPI_SUB_HEADER_DEF
363e2c95939SIgor Mammedov     uint16_t reserved;
364e2c95939SIgor Mammedov     uint32_t x2apic_id;              /* Processor's local x2APIC ID */
365e2c95939SIgor Mammedov     uint32_t flags;
366e2c95939SIgor Mammedov     uint32_t uid;                    /* Processor object _UID */
367e2c95939SIgor Mammedov } QEMU_PACKED;
368e2c95939SIgor Mammedov typedef struct AcpiMadtProcessorX2Apic AcpiMadtProcessorX2Apic;
369e2c95939SIgor Mammedov 
370e2c95939SIgor Mammedov struct AcpiMadtLocalX2ApicNmi {
371e2c95939SIgor Mammedov     ACPI_SUB_HEADER_DEF
372e2c95939SIgor Mammedov     uint16_t flags;                  /* MPS INTI flags */
373e2c95939SIgor Mammedov     uint32_t uid;                    /* Processor object _UID */
374e2c95939SIgor Mammedov     uint8_t  lint;                   /* Local APIC LINT# */
375e2c95939SIgor Mammedov     uint8_t  reserved[3];            /* Local APIC LINT# */
376e2c95939SIgor Mammedov } QEMU_PACKED;
377e2c95939SIgor Mammedov typedef struct AcpiMadtLocalX2ApicNmi AcpiMadtLocalX2ApicNmi;
378e2c95939SIgor Mammedov 
3796e2ed65fSAndrew Jones struct AcpiMadtGenericCpuInterface {
380982d06c5SShannon Zhao     ACPI_SUB_HEADER_DEF
381982d06c5SShannon Zhao     uint16_t reserved;
382982d06c5SShannon Zhao     uint32_t cpu_interface_number;
383982d06c5SShannon Zhao     uint32_t uid;
384982d06c5SShannon Zhao     uint32_t flags;
385982d06c5SShannon Zhao     uint32_t parking_version;
386982d06c5SShannon Zhao     uint32_t performance_interrupt;
387982d06c5SShannon Zhao     uint64_t parked_address;
388982d06c5SShannon Zhao     uint64_t base_address;
389982d06c5SShannon Zhao     uint64_t gicv_base_address;
390982d06c5SShannon Zhao     uint64_t gich_base_address;
391982d06c5SShannon Zhao     uint32_t vgic_interrupt;
392982d06c5SShannon Zhao     uint64_t gicr_base_address;
393982d06c5SShannon Zhao     uint64_t arm_mpidr;
394982d06c5SShannon Zhao } QEMU_PACKED;
395982d06c5SShannon Zhao 
3966e2ed65fSAndrew Jones typedef struct AcpiMadtGenericCpuInterface AcpiMadtGenericCpuInterface;
3976e2ed65fSAndrew Jones 
3986e2ed65fSAndrew Jones /* GICC CPU Interface Flags */
3996e2ed65fSAndrew Jones #define ACPI_MADT_GICC_ENABLED 1
400982d06c5SShannon Zhao 
401982d06c5SShannon Zhao struct AcpiMadtGenericDistributor {
402982d06c5SShannon Zhao     ACPI_SUB_HEADER_DEF
403982d06c5SShannon Zhao     uint16_t reserved;
404982d06c5SShannon Zhao     uint32_t gic_id;
405982d06c5SShannon Zhao     uint64_t base_address;
406982d06c5SShannon Zhao     uint32_t global_irq_base;
407f06765a9SShannon Zhao     /* ACPI 5.1 Errata 1228 Present GIC version in MADT table */
408f06765a9SShannon Zhao     uint8_t version;
409f06765a9SShannon Zhao     uint8_t reserved2[3];
410982d06c5SShannon Zhao } QEMU_PACKED;
411982d06c5SShannon Zhao 
412982d06c5SShannon Zhao typedef struct AcpiMadtGenericDistributor AcpiMadtGenericDistributor;
413982d06c5SShannon Zhao 
414ca793736SShannon Zhao struct AcpiMadtGenericMsiFrame {
415ca793736SShannon Zhao     ACPI_SUB_HEADER_DEF
416ca793736SShannon Zhao     uint16_t reserved;
417ca793736SShannon Zhao     uint32_t gic_msi_frame_id;
418ca793736SShannon Zhao     uint64_t base_address;
419ca793736SShannon Zhao     uint32_t flags;
420ca793736SShannon Zhao     uint16_t spi_count;
421ca793736SShannon Zhao     uint16_t spi_base;
422ca793736SShannon Zhao } QEMU_PACKED;
423ca793736SShannon Zhao 
424ca793736SShannon Zhao typedef struct AcpiMadtGenericMsiFrame AcpiMadtGenericMsiFrame;
425ca793736SShannon Zhao 
426b92ad394SPavel Fedin struct AcpiMadtGenericRedistributor {
427b92ad394SPavel Fedin     ACPI_SUB_HEADER_DEF
428b92ad394SPavel Fedin     uint16_t reserved;
429b92ad394SPavel Fedin     uint64_t base_address;
430b92ad394SPavel Fedin     uint32_t range_length;
431b92ad394SPavel Fedin } QEMU_PACKED;
432b92ad394SPavel Fedin 
433b92ad394SPavel Fedin typedef struct AcpiMadtGenericRedistributor AcpiMadtGenericRedistributor;
434b92ad394SPavel Fedin 
4351c2e4ea7SShannon Zhao struct AcpiMadtGenericTranslator {
4361c2e4ea7SShannon Zhao     ACPI_SUB_HEADER_DEF
4371c2e4ea7SShannon Zhao     uint16_t reserved;
4381c2e4ea7SShannon Zhao     uint32_t translation_id;
4391c2e4ea7SShannon Zhao     uint64_t base_address;
4401c2e4ea7SShannon Zhao     uint32_t reserved2;
4411c2e4ea7SShannon Zhao } QEMU_PACKED;
4421c2e4ea7SShannon Zhao 
4431c2e4ea7SShannon Zhao typedef struct AcpiMadtGenericTranslator AcpiMadtGenericTranslator;
4441c2e4ea7SShannon Zhao 
44572c194f7SMichael S. Tsirkin /*
446ee246400SShannon Zhao  * Generic Timer Description Table (GTDT)
447ee246400SShannon Zhao  */
4488dd845d3SAndrew Jones #define ACPI_GTDT_INTERRUPT_MODE_LEVEL    (0 << 0)
449aca4bbf4SAndrew Jones #define ACPI_GTDT_INTERRUPT_MODE_EDGE     (1 << 0)
450aca4bbf4SAndrew Jones #define ACPI_GTDT_CAP_ALWAYS_ON           (1 << 2)
451ee246400SShannon Zhao 
452ee246400SShannon Zhao struct AcpiGenericTimerTable {
453ee246400SShannon Zhao     ACPI_TABLE_HEADER_DEF
454ee246400SShannon Zhao     uint64_t counter_block_addresss;
455ee246400SShannon Zhao     uint32_t reserved;
456ee246400SShannon Zhao     uint32_t secure_el1_interrupt;
457ee246400SShannon Zhao     uint32_t secure_el1_flags;
458ee246400SShannon Zhao     uint32_t non_secure_el1_interrupt;
459ee246400SShannon Zhao     uint32_t non_secure_el1_flags;
460ee246400SShannon Zhao     uint32_t virtual_timer_interrupt;
461ee246400SShannon Zhao     uint32_t virtual_timer_flags;
462ee246400SShannon Zhao     uint32_t non_secure_el2_interrupt;
463ee246400SShannon Zhao     uint32_t non_secure_el2_flags;
464ee246400SShannon Zhao     uint64_t counter_read_block_address;
465ee246400SShannon Zhao     uint32_t platform_timer_count;
466ee246400SShannon Zhao     uint32_t platform_timer_offset;
467ee246400SShannon Zhao } QEMU_PACKED;
468ee246400SShannon Zhao typedef struct AcpiGenericTimerTable AcpiGenericTimerTable;
469ee246400SShannon Zhao 
470ee246400SShannon Zhao /*
47172c194f7SMichael S. Tsirkin  * HPET Description Table
47272c194f7SMichael S. Tsirkin  */
47372c194f7SMichael S. Tsirkin struct Acpi20Hpet {
47472c194f7SMichael S. Tsirkin     ACPI_TABLE_HEADER_DEF                    /* ACPI common table header */
47572c194f7SMichael S. Tsirkin     uint32_t           timer_block_id;
476b8e0f589SIgor Mammedov     struct AcpiGenericAddress addr;
47772c194f7SMichael S. Tsirkin     uint8_t            hpet_number;
47872c194f7SMichael S. Tsirkin     uint16_t           min_tick;
47972c194f7SMichael S. Tsirkin     uint8_t            page_protect;
48072c194f7SMichael S. Tsirkin } QEMU_PACKED;
48172c194f7SMichael S. Tsirkin typedef struct Acpi20Hpet Acpi20Hpet;
48272c194f7SMichael S. Tsirkin 
48372c194f7SMichael S. Tsirkin /*
48472c194f7SMichael S. Tsirkin  * SRAT (NUMA topology description) table
48572c194f7SMichael S. Tsirkin  */
48672c194f7SMichael S. Tsirkin 
4878b12e489SMichael S. Tsirkin struct AcpiSystemResourceAffinityTable {
48872c194f7SMichael S. Tsirkin     ACPI_TABLE_HEADER_DEF
48972c194f7SMichael S. Tsirkin     uint32_t    reserved1;
49072c194f7SMichael S. Tsirkin     uint32_t    reserved2[2];
49172c194f7SMichael S. Tsirkin } QEMU_PACKED;
49272c194f7SMichael S. Tsirkin typedef struct AcpiSystemResourceAffinityTable AcpiSystemResourceAffinityTable;
49372c194f7SMichael S. Tsirkin 
494e6e400d5SShannon Zhao #define ACPI_SRAT_PROCESSOR_APIC     0
49572c194f7SMichael S. Tsirkin #define ACPI_SRAT_MEMORY             1
496e6e400d5SShannon Zhao #define ACPI_SRAT_PROCESSOR_x2APIC   2
497e6e400d5SShannon Zhao #define ACPI_SRAT_PROCESSOR_GICC     3
49872c194f7SMichael S. Tsirkin 
4998b12e489SMichael S. Tsirkin struct AcpiSratProcessorAffinity {
50072c194f7SMichael S. Tsirkin     ACPI_SUB_HEADER_DEF
50172c194f7SMichael S. Tsirkin     uint8_t     proximity_lo;
50272c194f7SMichael S. Tsirkin     uint8_t     local_apic_id;
50372c194f7SMichael S. Tsirkin     uint32_t    flags;
50472c194f7SMichael S. Tsirkin     uint8_t     local_sapic_eid;
50572c194f7SMichael S. Tsirkin     uint8_t     proximity_hi[3];
50672c194f7SMichael S. Tsirkin     uint32_t    reserved;
50772c194f7SMichael S. Tsirkin } QEMU_PACKED;
50872c194f7SMichael S. Tsirkin typedef struct AcpiSratProcessorAffinity AcpiSratProcessorAffinity;
50972c194f7SMichael S. Tsirkin 
5105eff33a2SIgor Mammedov struct AcpiSratProcessorX2ApicAffinity {
5115eff33a2SIgor Mammedov     ACPI_SUB_HEADER_DEF
5125eff33a2SIgor Mammedov     uint16_t    reserved;
5135eff33a2SIgor Mammedov     uint32_t    proximity_domain;
5145eff33a2SIgor Mammedov     uint32_t    x2apic_id;
5155eff33a2SIgor Mammedov     uint32_t    flags;
5165eff33a2SIgor Mammedov     uint32_t    clk_domain;
5175eff33a2SIgor Mammedov     uint32_t    reserved2;
5185eff33a2SIgor Mammedov } QEMU_PACKED;
5195eff33a2SIgor Mammedov typedef struct AcpiSratProcessorX2ApicAffinity AcpiSratProcessorX2ApicAffinity;
5205eff33a2SIgor Mammedov 
5218b12e489SMichael S. Tsirkin struct AcpiSratMemoryAffinity {
52272c194f7SMichael S. Tsirkin     ACPI_SUB_HEADER_DEF
523ea9fcbd7SShannon Zhao     uint32_t    proximity;
52472c194f7SMichael S. Tsirkin     uint16_t    reserved1;
52572c194f7SMichael S. Tsirkin     uint64_t    base_addr;
52672c194f7SMichael S. Tsirkin     uint64_t    range_length;
52772c194f7SMichael S. Tsirkin     uint32_t    reserved2;
52872c194f7SMichael S. Tsirkin     uint32_t    flags;
52972c194f7SMichael S. Tsirkin     uint32_t    reserved3[2];
53072c194f7SMichael S. Tsirkin } QEMU_PACKED;
53172c194f7SMichael S. Tsirkin typedef struct AcpiSratMemoryAffinity AcpiSratMemoryAffinity;
53272c194f7SMichael S. Tsirkin 
5338b12e489SMichael S. Tsirkin struct AcpiSratProcessorGiccAffinity {
534e6e400d5SShannon Zhao     ACPI_SUB_HEADER_DEF
535e6e400d5SShannon Zhao     uint32_t    proximity;
536e6e400d5SShannon Zhao     uint32_t    acpi_processor_uid;
537e6e400d5SShannon Zhao     uint32_t    flags;
538e6e400d5SShannon Zhao     uint32_t    clock_domain;
539e6e400d5SShannon Zhao } QEMU_PACKED;
540e6e400d5SShannon Zhao 
541e6e400d5SShannon Zhao typedef struct AcpiSratProcessorGiccAffinity AcpiSratProcessorGiccAffinity;
542e6e400d5SShannon Zhao 
54372c194f7SMichael S. Tsirkin /* PCI fw r3.0 MCFG table. */
54472c194f7SMichael S. Tsirkin /* Subtable */
54572c194f7SMichael S. Tsirkin struct AcpiMcfgAllocation {
54672c194f7SMichael S. Tsirkin     uint64_t address;                /* Base address, processor-relative */
54772c194f7SMichael S. Tsirkin     uint16_t pci_segment;            /* PCI segment group number */
54872c194f7SMichael S. Tsirkin     uint8_t start_bus_number;       /* Starting PCI Bus number */
54972c194f7SMichael S. Tsirkin     uint8_t end_bus_number;         /* Final PCI Bus number */
55072c194f7SMichael S. Tsirkin     uint32_t reserved;
55172c194f7SMichael S. Tsirkin } QEMU_PACKED;
55272c194f7SMichael S. Tsirkin typedef struct AcpiMcfgAllocation AcpiMcfgAllocation;
55372c194f7SMichael S. Tsirkin 
55472c194f7SMichael S. Tsirkin struct AcpiTableMcfg {
55572c194f7SMichael S. Tsirkin     ACPI_TABLE_HEADER_DEF;
55672c194f7SMichael S. Tsirkin     uint8_t reserved[8];
55772c194f7SMichael S. Tsirkin     AcpiMcfgAllocation allocation[0];
55872c194f7SMichael S. Tsirkin } QEMU_PACKED;
55972c194f7SMichael S. Tsirkin typedef struct AcpiTableMcfg AcpiTableMcfg;
56072c194f7SMichael S. Tsirkin 
561711b20b4SStefan Berger /*
562711b20b4SStefan Berger  * TCPA Description Table
5635cb18b3dSStefan Berger  *
5645cb18b3dSStefan Berger  * Following Level 00, Rev 00.37 of specs:
5655cb18b3dSStefan Berger  * http://www.trustedcomputinggroup.org/resources/tcg_acpi_specification
566711b20b4SStefan Berger  */
567711b20b4SStefan Berger struct Acpi20Tcpa {
568711b20b4SStefan Berger     ACPI_TABLE_HEADER_DEF                    /* ACPI common table header */
569711b20b4SStefan Berger     uint16_t platform_class;
570711b20b4SStefan Berger     uint32_t log_area_minimum_length;
571711b20b4SStefan Berger     uint64_t log_area_start_address;
572711b20b4SStefan Berger } QEMU_PACKED;
573711b20b4SStefan Berger typedef struct Acpi20Tcpa Acpi20Tcpa;
574711b20b4SStefan Berger 
5755cb18b3dSStefan Berger /*
5765cb18b3dSStefan Berger  * TPM2
5775cb18b3dSStefan Berger  *
5784a42fa0eSStefan Berger  * Following Version 1.2, Revision 8 of specs:
5794a42fa0eSStefan Berger  * https://trustedcomputinggroup.org/tcg-acpi-specification/
5805cb18b3dSStefan Berger  */
5815cb18b3dSStefan Berger struct Acpi20TPM2 {
5825cb18b3dSStefan Berger     ACPI_TABLE_HEADER_DEF
5835cb18b3dSStefan Berger     uint16_t platform_class;
5845cb18b3dSStefan Berger     uint16_t reserved;
5855cb18b3dSStefan Berger     uint64_t control_area_address;
5865cb18b3dSStefan Berger     uint32_t start_method;
5874a42fa0eSStefan Berger     uint8_t start_method_params[12];
5884a42fa0eSStefan Berger     uint32_t log_area_minimum_length;
5894a42fa0eSStefan Berger     uint64_t log_area_start_address;
5905cb18b3dSStefan Berger } QEMU_PACKED;
5915cb18b3dSStefan Berger typedef struct Acpi20TPM2 Acpi20TPM2;
5925cb18b3dSStefan Berger 
593d4eb9119SLe Tan /* DMAR - DMA Remapping table r2.2 */
594d4eb9119SLe Tan struct AcpiTableDmar {
595d4eb9119SLe Tan     ACPI_TABLE_HEADER_DEF
596d4eb9119SLe Tan     uint8_t host_address_width; /* Maximum DMA physical addressability */
597d4eb9119SLe Tan     uint8_t flags;
598d4eb9119SLe Tan     uint8_t reserved[10];
599d4eb9119SLe Tan } QEMU_PACKED;
600d4eb9119SLe Tan typedef struct AcpiTableDmar AcpiTableDmar;
601d4eb9119SLe Tan 
602d4eb9119SLe Tan /* Masks for Flags field above */
603d4eb9119SLe Tan #define ACPI_DMAR_INTR_REMAP        1
604d4eb9119SLe Tan #define ACPI_DMAR_X2APIC_OPT_OUT    (1 << 1)
605d4eb9119SLe Tan 
606d4eb9119SLe Tan /* Values for sub-structure type for DMAR */
607d4eb9119SLe Tan enum {
608d4eb9119SLe Tan     ACPI_DMAR_TYPE_HARDWARE_UNIT = 0,       /* DRHD */
609d4eb9119SLe Tan     ACPI_DMAR_TYPE_RESERVED_MEMORY = 1,     /* RMRR */
610d4eb9119SLe Tan     ACPI_DMAR_TYPE_ATSR = 2,                /* ATSR */
611d4eb9119SLe Tan     ACPI_DMAR_TYPE_HARDWARE_AFFINITY = 3,   /* RHSR */
612d4eb9119SLe Tan     ACPI_DMAR_TYPE_ANDD = 4,                /* ANDD */
613d4eb9119SLe Tan     ACPI_DMAR_TYPE_RESERVED = 5             /* Reserved for furture use */
614d4eb9119SLe Tan };
615d4eb9119SLe Tan 
616d4eb9119SLe Tan /*
617d4eb9119SLe Tan  * Sub-structures for DMAR
618d4eb9119SLe Tan  */
619cfc13df4SPeter Xu 
620cfc13df4SPeter Xu /* Device scope structure for DRHD. */
621cfc13df4SPeter Xu struct AcpiDmarDeviceScope {
622cfc13df4SPeter Xu     uint8_t entry_type;
623cfc13df4SPeter Xu     uint8_t length;
624cfc13df4SPeter Xu     uint16_t reserved;
625cfc13df4SPeter Xu     uint8_t enumeration_id;
626cfc13df4SPeter Xu     uint8_t bus;
6271b39bc1cSPeter Xu     struct {
6281b39bc1cSPeter Xu         uint8_t device;
6291b39bc1cSPeter Xu         uint8_t function;
6301b39bc1cSPeter Xu     } path[0];
631cfc13df4SPeter Xu } QEMU_PACKED;
632cfc13df4SPeter Xu typedef struct AcpiDmarDeviceScope AcpiDmarDeviceScope;
633cfc13df4SPeter Xu 
634d4eb9119SLe Tan /* Type 0: Hardware Unit Definition */
635d4eb9119SLe Tan struct AcpiDmarHardwareUnit {
636d4eb9119SLe Tan     uint16_t type;
637d4eb9119SLe Tan     uint16_t length;
638d4eb9119SLe Tan     uint8_t flags;
639d4eb9119SLe Tan     uint8_t reserved;
640d4eb9119SLe Tan     uint16_t pci_segment;   /* The PCI Segment associated with this unit */
641d4eb9119SLe Tan     uint64_t address;   /* Base address of remapping hardware register-set */
642cfc13df4SPeter Xu     AcpiDmarDeviceScope scope[0];
643d4eb9119SLe Tan } QEMU_PACKED;
644d4eb9119SLe Tan typedef struct AcpiDmarHardwareUnit AcpiDmarHardwareUnit;
645d4eb9119SLe Tan 
646bd2baaccSJason Wang /* Type 2: Root Port ATS Capability Reporting Structure */
647bd2baaccSJason Wang struct AcpiDmarRootPortATS {
648bd2baaccSJason Wang     uint16_t type;
649bd2baaccSJason Wang     uint16_t length;
650bd2baaccSJason Wang     uint8_t flags;
651bd2baaccSJason Wang     uint8_t reserved;
652bd2baaccSJason Wang     uint16_t pci_segment;
653bd2baaccSJason Wang     AcpiDmarDeviceScope scope[0];
654bd2baaccSJason Wang } QEMU_PACKED;
655bd2baaccSJason Wang typedef struct AcpiDmarRootPortATS AcpiDmarRootPortATS;
656bd2baaccSJason Wang 
657d4eb9119SLe Tan /* Masks for Flags field above */
658d4eb9119SLe Tan #define ACPI_DMAR_INCLUDE_PCI_ALL   1
659bd2baaccSJason Wang #define ACPI_DMAR_ATSR_ALL_PORTS    1
660d4eb9119SLe Tan 
66116fc326aSPrem Mallappa /*
66216fc326aSPrem Mallappa  * Input Output Remapping Table (IORT)
66316fc326aSPrem Mallappa  * Conforms to "IO Remapping Table System Software on ARM Platforms",
66416fc326aSPrem Mallappa  * Document number: ARM DEN 0049B, October 2015
66516fc326aSPrem Mallappa  */
66616fc326aSPrem Mallappa 
66716fc326aSPrem Mallappa struct AcpiIortTable {
66816fc326aSPrem Mallappa     ACPI_TABLE_HEADER_DEF     /* ACPI common table header */
66916fc326aSPrem Mallappa     uint32_t node_count;
67016fc326aSPrem Mallappa     uint32_t node_offset;
67116fc326aSPrem Mallappa     uint32_t reserved;
67216fc326aSPrem Mallappa } QEMU_PACKED;
67316fc326aSPrem Mallappa typedef struct AcpiIortTable AcpiIortTable;
67416fc326aSPrem Mallappa 
67516fc326aSPrem Mallappa /*
67616fc326aSPrem Mallappa  * IORT node types
67716fc326aSPrem Mallappa  */
67816fc326aSPrem Mallappa 
67916fc326aSPrem Mallappa #define ACPI_IORT_NODE_HEADER_DEF   /* Node format common fields */ \
68016fc326aSPrem Mallappa     uint8_t  type;          \
68116fc326aSPrem Mallappa     uint16_t length;        \
68216fc326aSPrem Mallappa     uint8_t  revision;      \
68316fc326aSPrem Mallappa     uint32_t reserved;      \
68416fc326aSPrem Mallappa     uint32_t mapping_count; \
68516fc326aSPrem Mallappa     uint32_t mapping_offset;
68616fc326aSPrem Mallappa 
68716fc326aSPrem Mallappa /* Values for node Type above */
68816fc326aSPrem Mallappa enum {
68916fc326aSPrem Mallappa         ACPI_IORT_NODE_ITS_GROUP = 0x00,
69016fc326aSPrem Mallappa         ACPI_IORT_NODE_NAMED_COMPONENT = 0x01,
69116fc326aSPrem Mallappa         ACPI_IORT_NODE_PCI_ROOT_COMPLEX = 0x02,
69216fc326aSPrem Mallappa         ACPI_IORT_NODE_SMMU = 0x03,
69316fc326aSPrem Mallappa         ACPI_IORT_NODE_SMMU_V3 = 0x04
69416fc326aSPrem Mallappa };
69516fc326aSPrem Mallappa 
69616fc326aSPrem Mallappa struct AcpiIortIdMapping {
69716fc326aSPrem Mallappa     uint32_t input_base;
69816fc326aSPrem Mallappa     uint32_t id_count;
69916fc326aSPrem Mallappa     uint32_t output_base;
70016fc326aSPrem Mallappa     uint32_t output_reference;
70116fc326aSPrem Mallappa     uint32_t flags;
70216fc326aSPrem Mallappa } QEMU_PACKED;
70316fc326aSPrem Mallappa typedef struct AcpiIortIdMapping AcpiIortIdMapping;
70416fc326aSPrem Mallappa 
70516fc326aSPrem Mallappa struct AcpiIortMemoryAccess {
70616fc326aSPrem Mallappa     uint32_t cache_coherency;
70716fc326aSPrem Mallappa     uint8_t  hints;
70816fc326aSPrem Mallappa     uint16_t reserved;
70916fc326aSPrem Mallappa     uint8_t  memory_flags;
71016fc326aSPrem Mallappa } QEMU_PACKED;
71116fc326aSPrem Mallappa typedef struct AcpiIortMemoryAccess AcpiIortMemoryAccess;
71216fc326aSPrem Mallappa 
71316fc326aSPrem Mallappa struct AcpiIortItsGroup {
71416fc326aSPrem Mallappa     ACPI_IORT_NODE_HEADER_DEF
71516fc326aSPrem Mallappa     uint32_t its_count;
71616fc326aSPrem Mallappa     uint32_t identifiers[0];
71716fc326aSPrem Mallappa } QEMU_PACKED;
71816fc326aSPrem Mallappa typedef struct AcpiIortItsGroup AcpiIortItsGroup;
71916fc326aSPrem Mallappa 
72016fc326aSPrem Mallappa struct AcpiIortRC {
72116fc326aSPrem Mallappa     ACPI_IORT_NODE_HEADER_DEF
72216fc326aSPrem Mallappa     AcpiIortMemoryAccess memory_properties;
72316fc326aSPrem Mallappa     uint32_t ats_attribute;
72416fc326aSPrem Mallappa     uint32_t pci_segment_number;
72516fc326aSPrem Mallappa     AcpiIortIdMapping id_mapping_array[0];
72616fc326aSPrem Mallappa } QEMU_PACKED;
72716fc326aSPrem Mallappa typedef struct AcpiIortRC AcpiIortRC;
72816fc326aSPrem Mallappa 
72972c194f7SMichael S. Tsirkin #endif
730