xref: /openbmc/linux/include/acpi/actbl.h (revision 4be44fcd3bf648b782f4460fd06dfae6c42ded4b)
11da177e4SLinus Torvalds /******************************************************************************
21da177e4SLinus Torvalds  *
31da177e4SLinus Torvalds  * Name: actbl.h - Table data structures defined in ACPI specification
41da177e4SLinus Torvalds  *
51da177e4SLinus Torvalds  *****************************************************************************/
61da177e4SLinus Torvalds 
71da177e4SLinus Torvalds /*
81da177e4SLinus Torvalds  * Copyright (C) 2000 - 2005, R. Byron Moore
91da177e4SLinus Torvalds  * All rights reserved.
101da177e4SLinus Torvalds  *
111da177e4SLinus Torvalds  * Redistribution and use in source and binary forms, with or without
121da177e4SLinus Torvalds  * modification, are permitted provided that the following conditions
131da177e4SLinus Torvalds  * are met:
141da177e4SLinus Torvalds  * 1. Redistributions of source code must retain the above copyright
151da177e4SLinus Torvalds  *    notice, this list of conditions, and the following disclaimer,
161da177e4SLinus Torvalds  *    without modification.
171da177e4SLinus Torvalds  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
181da177e4SLinus Torvalds  *    substantially similar to the "NO WARRANTY" disclaimer below
191da177e4SLinus Torvalds  *    ("Disclaimer") and any redistribution must be conditioned upon
201da177e4SLinus Torvalds  *    including a substantially similar Disclaimer requirement for further
211da177e4SLinus Torvalds  *    binary redistribution.
221da177e4SLinus Torvalds  * 3. Neither the names of the above-listed copyright holders nor the names
231da177e4SLinus Torvalds  *    of any contributors may be used to endorse or promote products derived
241da177e4SLinus Torvalds  *    from this software without specific prior written permission.
251da177e4SLinus Torvalds  *
261da177e4SLinus Torvalds  * Alternatively, this software may be distributed under the terms of the
271da177e4SLinus Torvalds  * GNU General Public License ("GPL") version 2 as published by the Free
281da177e4SLinus Torvalds  * Software Foundation.
291da177e4SLinus Torvalds  *
301da177e4SLinus Torvalds  * NO WARRANTY
311da177e4SLinus Torvalds  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
321da177e4SLinus Torvalds  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
331da177e4SLinus Torvalds  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
341da177e4SLinus Torvalds  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
351da177e4SLinus Torvalds  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
361da177e4SLinus Torvalds  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
371da177e4SLinus Torvalds  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
381da177e4SLinus Torvalds  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
391da177e4SLinus Torvalds  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
401da177e4SLinus Torvalds  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
411da177e4SLinus Torvalds  * POSSIBILITY OF SUCH DAMAGES.
421da177e4SLinus Torvalds  */
431da177e4SLinus Torvalds 
441da177e4SLinus Torvalds #ifndef __ACTBL_H__
451da177e4SLinus Torvalds #define __ACTBL_H__
461da177e4SLinus Torvalds 
471da177e4SLinus Torvalds /*
481da177e4SLinus Torvalds  *  Values for description table header signatures
491da177e4SLinus Torvalds  */
501da177e4SLinus Torvalds #define RSDP_NAME               "RSDP"
511da177e4SLinus Torvalds #define RSDP_SIG                "RSD PTR "	/* RSDT Pointer signature */
521da177e4SLinus Torvalds #define APIC_SIG                "APIC"	/* Multiple APIC Description Table */
531da177e4SLinus Torvalds #define DSDT_SIG                "DSDT"	/* Differentiated System Description Table */
541da177e4SLinus Torvalds #define FADT_SIG                "FACP"	/* Fixed ACPI Description Table */
551da177e4SLinus Torvalds #define FACS_SIG                "FACS"	/* Firmware ACPI Control Structure */
561da177e4SLinus Torvalds #define PSDT_SIG                "PSDT"	/* Persistent System Description Table */
571da177e4SLinus Torvalds #define RSDT_SIG                "RSDT"	/* Root System Description Table */
581da177e4SLinus Torvalds #define XSDT_SIG                "XSDT"	/* Extended  System Description Table */
591da177e4SLinus Torvalds #define SSDT_SIG                "SSDT"	/* Secondary System Description Table */
601da177e4SLinus Torvalds #define SBST_SIG                "SBST"	/* Smart Battery Specification Table */
611da177e4SLinus Torvalds #define SPIC_SIG                "SPIC"	/* IOSAPIC table */
621da177e4SLinus Torvalds #define BOOT_SIG                "BOOT"	/* Boot table */
631da177e4SLinus Torvalds 
641da177e4SLinus Torvalds #define GL_OWNED                0x02	/* Ownership of global lock is bit 1 */
651da177e4SLinus Torvalds 
661da177e4SLinus Torvalds /*
671da177e4SLinus Torvalds  * Common table types.  The base code can remain
681da177e4SLinus Torvalds  * constant if the underlying tables are changed
691da177e4SLinus Torvalds  */
701da177e4SLinus Torvalds #define RSDT_DESCRIPTOR         struct rsdt_descriptor_rev2
711da177e4SLinus Torvalds #define XSDT_DESCRIPTOR         struct xsdt_descriptor_rev2
721da177e4SLinus Torvalds #define FACS_DESCRIPTOR         struct facs_descriptor_rev2
731da177e4SLinus Torvalds #define FADT_DESCRIPTOR         struct fadt_descriptor_rev2
741da177e4SLinus Torvalds 
751da177e4SLinus Torvalds #pragma pack(1)
761da177e4SLinus Torvalds 
771da177e4SLinus Torvalds /*
781da177e4SLinus Torvalds  * ACPI Version-independent tables
791da177e4SLinus Torvalds  *
801da177e4SLinus Torvalds  * NOTE: The tables that are specific to ACPI versions (1.0, 2.0, etc.)
811da177e4SLinus Torvalds  * are in separate files.
821da177e4SLinus Torvalds  */
83*4be44fcdSLen Brown struct rsdp_descriptor {	/* Root System Descriptor Pointer */
841da177e4SLinus Torvalds 	char signature[8];	/* ACPI signature, contains "RSD PTR " */
85f9f4601fSRobert Moore 	u8 checksum;		/* ACPI 1.0 checksum */
861da177e4SLinus Torvalds 	char oem_id[6];		/* OEM identification */
87f9f4601fSRobert Moore 	u8 revision;		/* Must be (0) for ACPI 1.0 or (2) for ACPI 2.0+ */
88f9f4601fSRobert Moore 	u32 rsdt_physical_address;	/* 32-bit physical address of the RSDT */
89f9f4601fSRobert Moore 	u32 length;		/* XSDT Length in bytes, including header */
90f9f4601fSRobert Moore 	u64 xsdt_physical_address;	/* 64-bit physical address of the XSDT */
91f9f4601fSRobert Moore 	u8 extended_checksum;	/* Checksum of entire table (ACPI 2.0) */
92f9f4601fSRobert Moore 	char reserved[3];	/* Reserved, must be zero */
931da177e4SLinus Torvalds };
941da177e4SLinus Torvalds 
95*4be44fcdSLen Brown struct acpi_common_facs {	/* Common FACS for internal use */
961da177e4SLinus Torvalds 	u32 *global_lock;
971da177e4SLinus Torvalds 	u64 *firmware_waking_vector;
981da177e4SLinus Torvalds 	u8 vector_width;
991da177e4SLinus Torvalds };
1001da177e4SLinus Torvalds 
1011da177e4SLinus Torvalds #define ACPI_TABLE_HEADER_DEF   /* ACPI common table header */ \
102f9f4601fSRobert Moore 	char                            signature[4];           /* ASCII table signature */\
103f9f4601fSRobert Moore 	u32                             length;                 /* Length of table in bytes, including this header */\
1041da177e4SLinus Torvalds 	u8                              revision;               /* ACPI Specification minor version # */\
1051da177e4SLinus Torvalds 	u8                              checksum;               /* To make sum of entire table == 0 */\
106f9f4601fSRobert Moore 	char                            oem_id[6];              /* ASCII OEM identification */\
107f9f4601fSRobert Moore 	char                            oem_table_id[8];        /* ASCII OEM table identification */\
1081da177e4SLinus Torvalds 	u32                             oem_revision;           /* OEM revision number */\
109f9f4601fSRobert Moore 	char                            asl_compiler_id [4];    /* ASCII ASL compiler vendor ID */\
110f9f4601fSRobert Moore 	u32                             asl_compiler_revision;	/* ASL compiler version */
1111da177e4SLinus Torvalds 
112*4be44fcdSLen Brown struct acpi_table_header {	/* ACPI common table header */
113*4be44fcdSLen Brown ACPI_TABLE_HEADER_DEF};
1141da177e4SLinus Torvalds 
1151da177e4SLinus Torvalds /*
1161da177e4SLinus Torvalds  * MADT values and structures
1171da177e4SLinus Torvalds  */
1181da177e4SLinus Torvalds 
1191da177e4SLinus Torvalds /* Values for MADT PCATCompat */
1201da177e4SLinus Torvalds 
1211da177e4SLinus Torvalds #define DUAL_PIC                0
1221da177e4SLinus Torvalds #define MULTIPLE_APIC           1
1231da177e4SLinus Torvalds 
1241da177e4SLinus Torvalds /* Master MADT */
1251da177e4SLinus Torvalds 
126*4be44fcdSLen Brown struct multiple_apic_table {
1271da177e4SLinus Torvalds 	ACPI_TABLE_HEADER_DEF	/* ACPI common table header */
1281da177e4SLinus Torvalds 	u32 local_apic_address;	/* Physical address of local APIC */
129f9f4601fSRobert Moore 
130f9f4601fSRobert Moore 	/* Flags (32 bits) */
131f9f4601fSRobert Moore 
132f9f4601fSRobert Moore 	u8 PCATcompat:1;	/* 00:    System also has dual 8259s */
133f9f4601fSRobert Moore 	 u8:7;			/* 01-07: Reserved, must be zero */
134f9f4601fSRobert Moore 	u8 reserved1[3];	/* 08-31: Reserved, must be zero */
1351da177e4SLinus Torvalds };
1361da177e4SLinus Torvalds 
1371da177e4SLinus Torvalds /* Values for Type in APIC_HEADER_DEF */
1381da177e4SLinus Torvalds 
1391da177e4SLinus Torvalds #define APIC_PROCESSOR          0
1401da177e4SLinus Torvalds #define APIC_IO                 1
1411da177e4SLinus Torvalds #define APIC_XRUPT_OVERRIDE     2
1421da177e4SLinus Torvalds #define APIC_NMI                3
1431da177e4SLinus Torvalds #define APIC_LOCAL_NMI          4
1441da177e4SLinus Torvalds #define APIC_ADDRESS_OVERRIDE   5
1451da177e4SLinus Torvalds #define APIC_IO_SAPIC           6
1461da177e4SLinus Torvalds #define APIC_LOCAL_SAPIC        7
1471da177e4SLinus Torvalds #define APIC_XRUPT_SOURCE       8
1481da177e4SLinus Torvalds #define APIC_RESERVED           9	/* 9 and greater are reserved */
1491da177e4SLinus Torvalds 
1501da177e4SLinus Torvalds /*
1511da177e4SLinus Torvalds  * MADT sub-structures (Follow MULTIPLE_APIC_DESCRIPTION_TABLE)
1521da177e4SLinus Torvalds  */
1531da177e4SLinus Torvalds #define APIC_HEADER_DEF                     /* Common APIC sub-structure header */\
1541da177e4SLinus Torvalds 	u8                              type; \
1551da177e4SLinus Torvalds 	u8                              length;
1561da177e4SLinus Torvalds 
157*4be44fcdSLen Brown struct apic_header {
158*4be44fcdSLen Brown APIC_HEADER_DEF};
1591da177e4SLinus Torvalds 
1601da177e4SLinus Torvalds /* Values for MPS INTI flags */
1611da177e4SLinus Torvalds 
1621da177e4SLinus Torvalds #define POLARITY_CONFORMS       0
1631da177e4SLinus Torvalds #define POLARITY_ACTIVE_HIGH    1
1641da177e4SLinus Torvalds #define POLARITY_RESERVED       2
1651da177e4SLinus Torvalds #define POLARITY_ACTIVE_LOW     3
1661da177e4SLinus Torvalds 
1671da177e4SLinus Torvalds #define TRIGGER_CONFORMS        0
1681da177e4SLinus Torvalds #define TRIGGER_EDGE            1
1691da177e4SLinus Torvalds #define TRIGGER_RESERVED        2
1701da177e4SLinus Torvalds #define TRIGGER_LEVEL           3
1711da177e4SLinus Torvalds 
172f9f4601fSRobert Moore /* Common flag definitions (16 bits each) */
1731da177e4SLinus Torvalds 
1741da177e4SLinus Torvalds #define MPS_INTI_FLAGS \
175f9f4601fSRobert Moore 	u8                              polarity        : 2;    /* 00-01: Polarity of APIC I/O input signals */\
176f9f4601fSRobert Moore 	u8                              trigger_mode    : 2;    /* 02-03: Trigger mode of APIC input signals */\
177f9f4601fSRobert Moore 	u8                                              : 4;    /* 04-07: Reserved, must be zero */\
178f9f4601fSRobert Moore 	u8                              reserved1;	/* 08-15: Reserved, must be zero */
1791da177e4SLinus Torvalds 
1801da177e4SLinus Torvalds #define LOCAL_APIC_FLAGS \
181f9f4601fSRobert Moore 	u8                              processor_enabled: 1;   /* 00:    Processor is usable if set */\
182f9f4601fSRobert Moore 	u8                                              : 7;    /* 01-07: Reserved, must be zero */\
183f9f4601fSRobert Moore 	u8                              reserved2;	/* 08-15: Reserved, must be zero */
1841da177e4SLinus Torvalds 
1851da177e4SLinus Torvalds /* Sub-structures for MADT */
1861da177e4SLinus Torvalds 
187*4be44fcdSLen Brown struct madt_processor_apic {
188*4be44fcdSLen Brown 	APIC_HEADER_DEF u8 processor_id;	/* ACPI processor id */
1891da177e4SLinus Torvalds 	u8 local_apic_id;	/* Processor's local APIC id */
190*4be44fcdSLen Brown  LOCAL_APIC_FLAGS};
1911da177e4SLinus Torvalds 
192*4be44fcdSLen Brown struct madt_io_apic {
193*4be44fcdSLen Brown 	APIC_HEADER_DEF u8 io_apic_id;	/* I/O APIC ID */
1941da177e4SLinus Torvalds 	u8 reserved;		/* Reserved - must be zero */
1951da177e4SLinus Torvalds 	u32 address;		/* APIC physical address */
1961da177e4SLinus Torvalds 	u32 interrupt;		/* Global system interrupt where INTI
1971da177e4SLinus Torvalds 				 * lines start */
1981da177e4SLinus Torvalds };
1991da177e4SLinus Torvalds 
200*4be44fcdSLen Brown struct madt_interrupt_override {
201*4be44fcdSLen Brown 	APIC_HEADER_DEF u8 bus;	/* 0 - ISA */
2021da177e4SLinus Torvalds 	u8 source;		/* Interrupt source (IRQ) */
2031da177e4SLinus Torvalds 	u32 interrupt;		/* Global system interrupt */
204*4be44fcdSLen Brown  MPS_INTI_FLAGS};
205*4be44fcdSLen Brown 
206*4be44fcdSLen Brown struct madt_nmi_source {
207*4be44fcdSLen Brown 	APIC_HEADER_DEF MPS_INTI_FLAGS u32 interrupt;	/* Global system interrupt */
2081da177e4SLinus Torvalds };
2091da177e4SLinus Torvalds 
210*4be44fcdSLen Brown struct madt_local_apic_nmi {
211*4be44fcdSLen Brown 	APIC_HEADER_DEF u8 processor_id;	/* ACPI processor id */
212*4be44fcdSLen Brown 	MPS_INTI_FLAGS u8 lint;	/* LINTn to which NMI is connected */
2131da177e4SLinus Torvalds };
2141da177e4SLinus Torvalds 
215*4be44fcdSLen Brown struct madt_address_override {
216*4be44fcdSLen Brown 	APIC_HEADER_DEF u16 reserved;	/* Reserved, must be zero */
2171da177e4SLinus Torvalds 	u64 address;		/* APIC physical address */
2181da177e4SLinus Torvalds };
2191da177e4SLinus Torvalds 
220*4be44fcdSLen Brown struct madt_io_sapic {
221*4be44fcdSLen Brown 	APIC_HEADER_DEF u8 io_sapic_id;	/* I/O SAPIC ID */
222f9f4601fSRobert Moore 	u8 reserved;		/* Reserved, must be zero */
2231da177e4SLinus Torvalds 	u32 interrupt_base;	/* Glocal interrupt for SAPIC start */
2241da177e4SLinus Torvalds 	u64 address;		/* SAPIC physical address */
2251da177e4SLinus Torvalds };
2261da177e4SLinus Torvalds 
227*4be44fcdSLen Brown struct madt_local_sapic {
228*4be44fcdSLen Brown 	APIC_HEADER_DEF u8 processor_id;	/* ACPI processor id */
2291da177e4SLinus Torvalds 	u8 local_sapic_id;	/* SAPIC ID */
2301da177e4SLinus Torvalds 	u8 local_sapic_eid;	/* SAPIC EID */
231f9f4601fSRobert Moore 	u8 reserved[3];		/* Reserved, must be zero */
232*4be44fcdSLen Brown 	 LOCAL_APIC_FLAGS u32 processor_uID;	/* Numeric UID - ACPI 3.0 */
2331da177e4SLinus Torvalds 	char processor_uIDstring[1];	/* String UID  - ACPI 3.0 */
2341da177e4SLinus Torvalds };
2351da177e4SLinus Torvalds 
236*4be44fcdSLen Brown struct madt_interrupt_source {
237*4be44fcdSLen Brown 	APIC_HEADER_DEF MPS_INTI_FLAGS u8 interrupt_type;	/* 1=PMI, 2=INIT, 3=corrected */
2381da177e4SLinus Torvalds 	u8 processor_id;	/* Processor ID */
2391da177e4SLinus Torvalds 	u8 processor_eid;	/* Processor EID */
2401da177e4SLinus Torvalds 	u8 io_sapic_vector;	/* Vector value for PMI interrupts */
2411da177e4SLinus Torvalds 	u32 interrupt;		/* Global system interrupt */
2421da177e4SLinus Torvalds 	u32 flags;		/* Interrupt Source Flags */
2431da177e4SLinus Torvalds };
2441da177e4SLinus Torvalds 
2451da177e4SLinus Torvalds /*
2461da177e4SLinus Torvalds  * Smart Battery
2471da177e4SLinus Torvalds  */
248*4be44fcdSLen Brown struct smart_battery_table {
249*4be44fcdSLen Brown 	ACPI_TABLE_HEADER_DEF u32 warning_level;
2501da177e4SLinus Torvalds 	u32 low_level;
2511da177e4SLinus Torvalds 	u32 critical_level;
2521da177e4SLinus Torvalds };
2531da177e4SLinus Torvalds 
2541da177e4SLinus Torvalds #pragma pack()
2551da177e4SLinus Torvalds 
2561da177e4SLinus Torvalds /*
2571da177e4SLinus Torvalds  * ACPI Table information.  We save the table address, length,
2581da177e4SLinus Torvalds  * and type of memory allocation (mapped or allocated) for each
2591da177e4SLinus Torvalds  * table for 1) when we exit, and 2) if a new table is installed
2601da177e4SLinus Torvalds  */
2611da177e4SLinus Torvalds #define ACPI_MEM_NOT_ALLOCATED  0
2621da177e4SLinus Torvalds #define ACPI_MEM_ALLOCATED      1
2631da177e4SLinus Torvalds #define ACPI_MEM_MAPPED         2
2641da177e4SLinus Torvalds 
2651da177e4SLinus Torvalds /* Definitions for the Flags bitfield member of struct acpi_table_support */
2661da177e4SLinus Torvalds 
2671da177e4SLinus Torvalds #define ACPI_TABLE_SINGLE       0x00
2681da177e4SLinus Torvalds #define ACPI_TABLE_MULTIPLE     0x01
2691da177e4SLinus Torvalds #define ACPI_TABLE_EXECUTABLE   0x02
2701da177e4SLinus Torvalds 
2711da177e4SLinus Torvalds #define ACPI_TABLE_ROOT         0x00
2721da177e4SLinus Torvalds #define ACPI_TABLE_PRIMARY      0x10
2731da177e4SLinus Torvalds #define ACPI_TABLE_SECONDARY    0x20
2741da177e4SLinus Torvalds #define ACPI_TABLE_ALL          0x30
2751da177e4SLinus Torvalds #define ACPI_TABLE_TYPE_MASK    0x30
2761da177e4SLinus Torvalds 
2771da177e4SLinus Torvalds /* Data about each known table type */
2781da177e4SLinus Torvalds 
279*4be44fcdSLen Brown struct acpi_table_support {
2801da177e4SLinus Torvalds 	char *name;
2811da177e4SLinus Torvalds 	char *signature;
2821da177e4SLinus Torvalds 	void **global_ptr;
2831da177e4SLinus Torvalds 	u8 sig_length;
2841da177e4SLinus Torvalds 	u8 flags;
2851da177e4SLinus Torvalds };
2861da177e4SLinus Torvalds 
2871da177e4SLinus Torvalds /*
2881da177e4SLinus Torvalds  * Get the ACPI version-specific tables
2891da177e4SLinus Torvalds  */
2901da177e4SLinus Torvalds #include "actbl1.h"		/* Acpi 1.0 table definitions */
2911da177e4SLinus Torvalds #include "actbl2.h"		/* Acpi 2.0 table definitions */
2921da177e4SLinus Torvalds 
2931da177e4SLinus Torvalds extern u8 acpi_fadt_is_v1;	/* is set to 1 if FADT is revision 1,
2941da177e4SLinus Torvalds 				 * needed for certain workarounds */
2951da177e4SLinus Torvalds 
2961da177e4SLinus Torvalds #pragma pack(1)
2971da177e4SLinus Torvalds /*
2981da177e4SLinus Torvalds  * High performance timer
2991da177e4SLinus Torvalds  */
300*4be44fcdSLen Brown struct hpet_table {
301*4be44fcdSLen Brown 	ACPI_TABLE_HEADER_DEF u32 hardware_id;
3021da177e4SLinus Torvalds 	struct acpi_generic_address base_address;
3031da177e4SLinus Torvalds 	u8 hpet_number;
3041da177e4SLinus Torvalds 	u16 clock_tick;
3051da177e4SLinus Torvalds 	u8 attributes;
3061da177e4SLinus Torvalds };
3071da177e4SLinus Torvalds 
3081da177e4SLinus Torvalds #pragma pack()
3091da177e4SLinus Torvalds 
3101da177e4SLinus Torvalds #endif				/* __ACTBL_H__ */
311