xref: /openbmc/linux/include/acpi/actbl.h (revision defba1d8f233c0d5cf3e1ea6aeb898eca7231860)
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 /*
48*defba1d8SBob Moore  * Note about bitfields: The u8 type is used for bitfields in ACPI tables.
49*defba1d8SBob Moore  * This is the only type that is even remotely portable. Anything else is not
50*defba1d8SBob Moore  * portable, so do not use any other bitfield types.
51*defba1d8SBob Moore  */
52*defba1d8SBob Moore 
53*defba1d8SBob Moore /*
541da177e4SLinus Torvalds  *  Values for description table header signatures
551da177e4SLinus Torvalds  */
561da177e4SLinus Torvalds #define RSDP_NAME               "RSDP"
571da177e4SLinus Torvalds #define RSDP_SIG                "RSD PTR "	/* RSDT Pointer signature */
581da177e4SLinus Torvalds #define APIC_SIG                "APIC"	/* Multiple APIC Description Table */
591da177e4SLinus Torvalds #define DSDT_SIG                "DSDT"	/* Differentiated System Description Table */
601da177e4SLinus Torvalds #define FADT_SIG                "FACP"	/* Fixed ACPI Description Table */
611da177e4SLinus Torvalds #define FACS_SIG                "FACS"	/* Firmware ACPI Control Structure */
621da177e4SLinus Torvalds #define PSDT_SIG                "PSDT"	/* Persistent System Description Table */
631da177e4SLinus Torvalds #define RSDT_SIG                "RSDT"	/* Root System Description Table */
641da177e4SLinus Torvalds #define XSDT_SIG                "XSDT"	/* Extended  System Description Table */
651da177e4SLinus Torvalds #define SSDT_SIG                "SSDT"	/* Secondary System Description Table */
661da177e4SLinus Torvalds #define SBST_SIG                "SBST"	/* Smart Battery Specification Table */
671da177e4SLinus Torvalds #define SPIC_SIG                "SPIC"	/* IOSAPIC table */
681da177e4SLinus Torvalds #define BOOT_SIG                "BOOT"	/* Boot table */
691da177e4SLinus Torvalds 
701da177e4SLinus Torvalds #define GL_OWNED                0x02	/* Ownership of global lock is bit 1 */
711da177e4SLinus Torvalds 
721da177e4SLinus Torvalds /*
731da177e4SLinus Torvalds  * Common table types.  The base code can remain
741da177e4SLinus Torvalds  * constant if the underlying tables are changed
751da177e4SLinus Torvalds  */
761da177e4SLinus Torvalds #define RSDT_DESCRIPTOR         struct rsdt_descriptor_rev2
771da177e4SLinus Torvalds #define XSDT_DESCRIPTOR         struct xsdt_descriptor_rev2
781da177e4SLinus Torvalds #define FACS_DESCRIPTOR         struct facs_descriptor_rev2
791da177e4SLinus Torvalds #define FADT_DESCRIPTOR         struct fadt_descriptor_rev2
801da177e4SLinus Torvalds 
811da177e4SLinus Torvalds #pragma pack(1)
821da177e4SLinus Torvalds 
831da177e4SLinus Torvalds /*
841da177e4SLinus Torvalds  * ACPI Version-independent tables
851da177e4SLinus Torvalds  *
861da177e4SLinus Torvalds  * NOTE: The tables that are specific to ACPI versions (1.0, 2.0, etc.)
871da177e4SLinus Torvalds  * are in separate files.
881da177e4SLinus Torvalds  */
894be44fcdSLen Brown struct rsdp_descriptor {	/* Root System Descriptor Pointer */
901da177e4SLinus Torvalds 	char signature[8];	/* ACPI signature, contains "RSD PTR " */
91f9f4601fSRobert Moore 	u8 checksum;		/* ACPI 1.0 checksum */
921da177e4SLinus Torvalds 	char oem_id[6];		/* OEM identification */
93f9f4601fSRobert Moore 	u8 revision;		/* Must be (0) for ACPI 1.0 or (2) for ACPI 2.0+ */
94f9f4601fSRobert Moore 	u32 rsdt_physical_address;	/* 32-bit physical address of the RSDT */
95f9f4601fSRobert Moore 	u32 length;		/* XSDT Length in bytes, including header */
96f9f4601fSRobert Moore 	u64 xsdt_physical_address;	/* 64-bit physical address of the XSDT */
97f9f4601fSRobert Moore 	u8 extended_checksum;	/* Checksum of entire table (ACPI 2.0) */
98f9f4601fSRobert Moore 	char reserved[3];	/* Reserved, must be zero */
991da177e4SLinus Torvalds };
1001da177e4SLinus Torvalds 
1014be44fcdSLen Brown struct acpi_common_facs {	/* Common FACS for internal use */
1021da177e4SLinus Torvalds 	u32 *global_lock;
1031da177e4SLinus Torvalds 	u64 *firmware_waking_vector;
1041da177e4SLinus Torvalds 	u8 vector_width;
1051da177e4SLinus Torvalds };
1061da177e4SLinus Torvalds 
1071da177e4SLinus Torvalds #define ACPI_TABLE_HEADER_DEF   /* ACPI common table header */ \
108f9f4601fSRobert Moore 	char                            signature[4];           /* ASCII table signature */\
109f9f4601fSRobert Moore 	u32                             length;                 /* Length of table in bytes, including this header */\
1101da177e4SLinus Torvalds 	u8                              revision;               /* ACPI Specification minor version # */\
1111da177e4SLinus Torvalds 	u8                              checksum;               /* To make sum of entire table == 0 */\
112f9f4601fSRobert Moore 	char                            oem_id[6];              /* ASCII OEM identification */\
113f9f4601fSRobert Moore 	char                            oem_table_id[8];        /* ASCII OEM table identification */\
1141da177e4SLinus Torvalds 	u32                             oem_revision;           /* OEM revision number */\
115f9f4601fSRobert Moore 	char                            asl_compiler_id [4];    /* ASCII ASL compiler vendor ID */\
116f9f4601fSRobert Moore 	u32                             asl_compiler_revision;	/* ASL compiler version */
1171da177e4SLinus Torvalds 
1184be44fcdSLen Brown struct acpi_table_header {	/* ACPI common table header */
1194be44fcdSLen Brown ACPI_TABLE_HEADER_DEF};
1201da177e4SLinus Torvalds 
1211da177e4SLinus Torvalds /*
1221da177e4SLinus Torvalds  * MADT values and structures
1231da177e4SLinus Torvalds  */
1241da177e4SLinus Torvalds 
1251da177e4SLinus Torvalds /* Values for MADT PCATCompat */
1261da177e4SLinus Torvalds 
1271da177e4SLinus Torvalds #define DUAL_PIC                0
1281da177e4SLinus Torvalds #define MULTIPLE_APIC           1
1291da177e4SLinus Torvalds 
1301da177e4SLinus Torvalds /* Master MADT */
1311da177e4SLinus Torvalds 
1324be44fcdSLen Brown struct multiple_apic_table {
1331da177e4SLinus Torvalds 	ACPI_TABLE_HEADER_DEF	/* ACPI common table header */
1341da177e4SLinus Torvalds 	u32 local_apic_address;	/* Physical address of local APIC */
135f9f4601fSRobert Moore 
136f9f4601fSRobert Moore 	/* Flags (32 bits) */
137f9f4601fSRobert Moore 
138f9f4601fSRobert Moore 	u8 PCATcompat:1;	/* 00:    System also has dual 8259s */
139f9f4601fSRobert Moore 	 u8:7;			/* 01-07: Reserved, must be zero */
140f9f4601fSRobert Moore 	u8 reserved1[3];	/* 08-31: Reserved, must be zero */
1411da177e4SLinus Torvalds };
1421da177e4SLinus Torvalds 
1431da177e4SLinus Torvalds /* Values for Type in APIC_HEADER_DEF */
1441da177e4SLinus Torvalds 
1451da177e4SLinus Torvalds #define APIC_PROCESSOR          0
1461da177e4SLinus Torvalds #define APIC_IO                 1
1471da177e4SLinus Torvalds #define APIC_XRUPT_OVERRIDE     2
1481da177e4SLinus Torvalds #define APIC_NMI                3
1491da177e4SLinus Torvalds #define APIC_LOCAL_NMI          4
1501da177e4SLinus Torvalds #define APIC_ADDRESS_OVERRIDE   5
1511da177e4SLinus Torvalds #define APIC_IO_SAPIC           6
1521da177e4SLinus Torvalds #define APIC_LOCAL_SAPIC        7
1531da177e4SLinus Torvalds #define APIC_XRUPT_SOURCE       8
1541da177e4SLinus Torvalds #define APIC_RESERVED           9	/* 9 and greater are reserved */
1551da177e4SLinus Torvalds 
1561da177e4SLinus Torvalds /*
1571da177e4SLinus Torvalds  * MADT sub-structures (Follow MULTIPLE_APIC_DESCRIPTION_TABLE)
1581da177e4SLinus Torvalds  */
1591da177e4SLinus Torvalds #define APIC_HEADER_DEF                     /* Common APIC sub-structure header */\
1601da177e4SLinus Torvalds 	u8                              type; \
1611da177e4SLinus Torvalds 	u8                              length;
1621da177e4SLinus Torvalds 
1634be44fcdSLen Brown struct apic_header {
1644be44fcdSLen Brown APIC_HEADER_DEF};
1651da177e4SLinus Torvalds 
1661da177e4SLinus Torvalds /* Values for MPS INTI flags */
1671da177e4SLinus Torvalds 
1681da177e4SLinus Torvalds #define POLARITY_CONFORMS       0
1691da177e4SLinus Torvalds #define POLARITY_ACTIVE_HIGH    1
1701da177e4SLinus Torvalds #define POLARITY_RESERVED       2
1711da177e4SLinus Torvalds #define POLARITY_ACTIVE_LOW     3
1721da177e4SLinus Torvalds 
1731da177e4SLinus Torvalds #define TRIGGER_CONFORMS        0
1741da177e4SLinus Torvalds #define TRIGGER_EDGE            1
1751da177e4SLinus Torvalds #define TRIGGER_RESERVED        2
1761da177e4SLinus Torvalds #define TRIGGER_LEVEL           3
1771da177e4SLinus Torvalds 
178f9f4601fSRobert Moore /* Common flag definitions (16 bits each) */
1791da177e4SLinus Torvalds 
1801da177e4SLinus Torvalds #define MPS_INTI_FLAGS \
181f9f4601fSRobert Moore 	u8                              polarity        : 2;    /* 00-01: Polarity of APIC I/O input signals */\
182f9f4601fSRobert Moore 	u8                              trigger_mode    : 2;    /* 02-03: Trigger mode of APIC input signals */\
183f9f4601fSRobert Moore 	u8                                              : 4;    /* 04-07: Reserved, must be zero */\
184f9f4601fSRobert Moore 	u8                              reserved1;	/* 08-15: Reserved, must be zero */
1851da177e4SLinus Torvalds 
1861da177e4SLinus Torvalds #define LOCAL_APIC_FLAGS \
187f9f4601fSRobert Moore 	u8                              processor_enabled: 1;   /* 00:    Processor is usable if set */\
188f9f4601fSRobert Moore 	u8                                              : 7;    /* 01-07: Reserved, must be zero */\
189f9f4601fSRobert Moore 	u8                              reserved2;	/* 08-15: Reserved, must be zero */
1901da177e4SLinus Torvalds 
1911da177e4SLinus Torvalds /* Sub-structures for MADT */
1921da177e4SLinus Torvalds 
1934be44fcdSLen Brown struct madt_processor_apic {
1944be44fcdSLen Brown 	APIC_HEADER_DEF u8 processor_id;	/* ACPI processor id */
1951da177e4SLinus Torvalds 	u8 local_apic_id;	/* Processor's local APIC id */
1964be44fcdSLen Brown  LOCAL_APIC_FLAGS};
1971da177e4SLinus Torvalds 
1984be44fcdSLen Brown struct madt_io_apic {
1994be44fcdSLen Brown 	APIC_HEADER_DEF u8 io_apic_id;	/* I/O APIC ID */
2001da177e4SLinus Torvalds 	u8 reserved;		/* Reserved - must be zero */
2011da177e4SLinus Torvalds 	u32 address;		/* APIC physical address */
2021da177e4SLinus Torvalds 	u32 interrupt;		/* Global system interrupt where INTI
2031da177e4SLinus Torvalds 				 * lines start */
2041da177e4SLinus Torvalds };
2051da177e4SLinus Torvalds 
2064be44fcdSLen Brown struct madt_interrupt_override {
2074be44fcdSLen Brown 	APIC_HEADER_DEF u8 bus;	/* 0 - ISA */
2081da177e4SLinus Torvalds 	u8 source;		/* Interrupt source (IRQ) */
2091da177e4SLinus Torvalds 	u32 interrupt;		/* Global system interrupt */
2104be44fcdSLen Brown  MPS_INTI_FLAGS};
2114be44fcdSLen Brown 
2124be44fcdSLen Brown struct madt_nmi_source {
2134be44fcdSLen Brown 	APIC_HEADER_DEF MPS_INTI_FLAGS u32 interrupt;	/* Global system interrupt */
2141da177e4SLinus Torvalds };
2151da177e4SLinus Torvalds 
2164be44fcdSLen Brown struct madt_local_apic_nmi {
2174be44fcdSLen Brown 	APIC_HEADER_DEF u8 processor_id;	/* ACPI processor id */
2184be44fcdSLen Brown 	MPS_INTI_FLAGS u8 lint;	/* LINTn to which NMI is connected */
2191da177e4SLinus Torvalds };
2201da177e4SLinus Torvalds 
2214be44fcdSLen Brown struct madt_address_override {
2224be44fcdSLen Brown 	APIC_HEADER_DEF u16 reserved;	/* Reserved, must be zero */
2231da177e4SLinus Torvalds 	u64 address;		/* APIC physical address */
2241da177e4SLinus Torvalds };
2251da177e4SLinus Torvalds 
2264be44fcdSLen Brown struct madt_io_sapic {
2274be44fcdSLen Brown 	APIC_HEADER_DEF u8 io_sapic_id;	/* I/O SAPIC ID */
228f9f4601fSRobert Moore 	u8 reserved;		/* Reserved, must be zero */
2291da177e4SLinus Torvalds 	u32 interrupt_base;	/* Glocal interrupt for SAPIC start */
2301da177e4SLinus Torvalds 	u64 address;		/* SAPIC physical address */
2311da177e4SLinus Torvalds };
2321da177e4SLinus Torvalds 
2334be44fcdSLen Brown struct madt_local_sapic {
2344be44fcdSLen Brown 	APIC_HEADER_DEF u8 processor_id;	/* ACPI processor id */
2351da177e4SLinus Torvalds 	u8 local_sapic_id;	/* SAPIC ID */
2361da177e4SLinus Torvalds 	u8 local_sapic_eid;	/* SAPIC EID */
237f9f4601fSRobert Moore 	u8 reserved[3];		/* Reserved, must be zero */
2384be44fcdSLen Brown 	 LOCAL_APIC_FLAGS u32 processor_uID;	/* Numeric UID - ACPI 3.0 */
2391da177e4SLinus Torvalds 	char processor_uIDstring[1];	/* String UID  - ACPI 3.0 */
2401da177e4SLinus Torvalds };
2411da177e4SLinus Torvalds 
2424be44fcdSLen Brown struct madt_interrupt_source {
2434be44fcdSLen Brown 	APIC_HEADER_DEF MPS_INTI_FLAGS u8 interrupt_type;	/* 1=PMI, 2=INIT, 3=corrected */
2441da177e4SLinus Torvalds 	u8 processor_id;	/* Processor ID */
2451da177e4SLinus Torvalds 	u8 processor_eid;	/* Processor EID */
2461da177e4SLinus Torvalds 	u8 io_sapic_vector;	/* Vector value for PMI interrupts */
2471da177e4SLinus Torvalds 	u32 interrupt;		/* Global system interrupt */
2481da177e4SLinus Torvalds 	u32 flags;		/* Interrupt Source Flags */
2491da177e4SLinus Torvalds };
2501da177e4SLinus Torvalds 
2511da177e4SLinus Torvalds /*
2521da177e4SLinus Torvalds  * Smart Battery
2531da177e4SLinus Torvalds  */
2544be44fcdSLen Brown struct smart_battery_table {
2554be44fcdSLen Brown 	ACPI_TABLE_HEADER_DEF u32 warning_level;
2561da177e4SLinus Torvalds 	u32 low_level;
2571da177e4SLinus Torvalds 	u32 critical_level;
2581da177e4SLinus Torvalds };
2591da177e4SLinus Torvalds 
2601da177e4SLinus Torvalds #pragma pack()
2611da177e4SLinus Torvalds 
2621da177e4SLinus Torvalds /*
2631da177e4SLinus Torvalds  * ACPI Table information.  We save the table address, length,
2641da177e4SLinus Torvalds  * and type of memory allocation (mapped or allocated) for each
2651da177e4SLinus Torvalds  * table for 1) when we exit, and 2) if a new table is installed
2661da177e4SLinus Torvalds  */
2671da177e4SLinus Torvalds #define ACPI_MEM_NOT_ALLOCATED  0
2681da177e4SLinus Torvalds #define ACPI_MEM_ALLOCATED      1
2691da177e4SLinus Torvalds #define ACPI_MEM_MAPPED         2
2701da177e4SLinus Torvalds 
2711da177e4SLinus Torvalds /* Definitions for the Flags bitfield member of struct acpi_table_support */
2721da177e4SLinus Torvalds 
2731da177e4SLinus Torvalds #define ACPI_TABLE_SINGLE       0x00
2741da177e4SLinus Torvalds #define ACPI_TABLE_MULTIPLE     0x01
2751da177e4SLinus Torvalds #define ACPI_TABLE_EXECUTABLE   0x02
2761da177e4SLinus Torvalds 
2771da177e4SLinus Torvalds #define ACPI_TABLE_ROOT         0x00
2781da177e4SLinus Torvalds #define ACPI_TABLE_PRIMARY      0x10
2791da177e4SLinus Torvalds #define ACPI_TABLE_SECONDARY    0x20
2801da177e4SLinus Torvalds #define ACPI_TABLE_ALL          0x30
2811da177e4SLinus Torvalds #define ACPI_TABLE_TYPE_MASK    0x30
2821da177e4SLinus Torvalds 
2831da177e4SLinus Torvalds /* Data about each known table type */
2841da177e4SLinus Torvalds 
2854be44fcdSLen Brown struct acpi_table_support {
2861da177e4SLinus Torvalds 	char *name;
2871da177e4SLinus Torvalds 	char *signature;
2881da177e4SLinus Torvalds 	void **global_ptr;
2891da177e4SLinus Torvalds 	u8 sig_length;
2901da177e4SLinus Torvalds 	u8 flags;
2911da177e4SLinus Torvalds };
2921da177e4SLinus Torvalds 
2931da177e4SLinus Torvalds /*
2941da177e4SLinus Torvalds  * Get the ACPI version-specific tables
2951da177e4SLinus Torvalds  */
2961da177e4SLinus Torvalds #include "actbl1.h"		/* Acpi 1.0 table definitions */
2971da177e4SLinus Torvalds #include "actbl2.h"		/* Acpi 2.0 table definitions */
2981da177e4SLinus Torvalds 
2991da177e4SLinus Torvalds extern u8 acpi_fadt_is_v1;	/* is set to 1 if FADT is revision 1,
3001da177e4SLinus Torvalds 				 * needed for certain workarounds */
3011da177e4SLinus Torvalds 
3021da177e4SLinus Torvalds #pragma pack(1)
3031da177e4SLinus Torvalds /*
3041da177e4SLinus Torvalds  * High performance timer
3051da177e4SLinus Torvalds  */
3064be44fcdSLen Brown struct hpet_table {
3074be44fcdSLen Brown 	ACPI_TABLE_HEADER_DEF u32 hardware_id;
3081da177e4SLinus Torvalds 	struct acpi_generic_address base_address;
3091da177e4SLinus Torvalds 	u8 hpet_number;
3101da177e4SLinus Torvalds 	u16 clock_tick;
3111da177e4SLinus Torvalds 	u8 attributes;
3121da177e4SLinus Torvalds };
3131da177e4SLinus Torvalds 
3141da177e4SLinus Torvalds #pragma pack()
3151da177e4SLinus Torvalds 
3161da177e4SLinus Torvalds #endif				/* __ACTBL_H__ */
317