actbl.h 20.7 KB
Newer Older
L
Linus Torvalds 已提交
1 2
/******************************************************************************
 *
B
Bob Moore 已提交
3
 * Name: actbl.h - Basic ACPI Table Definitions
L
Linus Torvalds 已提交
4 5 6 7
 *
 *****************************************************************************/

/*
8
 * Copyright (C) 2000 - 2016, Intel Corp.
L
Linus Torvalds 已提交
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions, and the following disclaimer,
 *    without modification.
 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
 *    substantially similar to the "NO WARRANTY" disclaimer below
 *    ("Disclaimer") and any redistribution must be conditioned upon
 *    including a substantially similar Disclaimer requirement for further
 *    binary redistribution.
 * 3. Neither the names of the above-listed copyright holders nor the names
 *    of any contributors may be used to endorse or promote products derived
 *    from this software without specific prior written permission.
 *
 * Alternatively, this software may be distributed under the terms of the
 * GNU General Public License ("GPL") version 2 as published by the Free
 * Software Foundation.
 *
 * NO WARRANTY
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGES.
 */

#ifndef __ACTBL_H__
#define __ACTBL_H__

47 48 49 50 51 52 53 54 55 56 57 58 59
/*******************************************************************************
 *
 * Fundamental ACPI tables
 *
 * This file contains definitions for the ACPI tables that are directly consumed
 * by ACPICA. All other tables are consumed by the OS-dependent ACPI-related
 * device drivers and other OS support code.
 *
 * The RSDP and FACS do not use the common ACPI table header. All other ACPI
 * tables use the header.
 *
 ******************************************************************************/

B
Bob Moore 已提交
60
/*
61 62 63
 * Values for description table header signatures for tables defined in this
 * file. Useful because they make it more difficult to inadvertently type in
 * the wrong signature.
L
Linus Torvalds 已提交
64
 */
65 66 67
#define ACPI_SIG_DSDT           "DSDT"	/* Differentiated System Description Table */
#define ACPI_SIG_FADT           "FACP"	/* Fixed ACPI Description Table */
#define ACPI_SIG_FACS           "FACS"	/* Firmware ACPI Control Structure */
68
#define ACPI_SIG_OSDT           "OSDT"	/* Override System Description Table */
69 70 71 72 73
#define ACPI_SIG_PSDT           "PSDT"	/* Persistent System Description Table */
#define ACPI_SIG_RSDP           "RSD PTR "	/* Root System Description Pointer */
#define ACPI_SIG_RSDT           "RSDT"	/* Root System Description Table */
#define ACPI_SIG_XSDT           "XSDT"	/* Extended  System Description Table */
#define ACPI_SIG_SSDT           "SSDT"	/* Secondary System Description Table */
74
#define ACPI_RSDP_NAME          "RSDP"	/* Short name for RSDP, not signature */
L
Linus Torvalds 已提交
75 76

/*
B
Bob Moore 已提交
77 78
 * All tables and structures must be byte-packed to match the ACPI
 * specification, since the tables are provided by the system BIOS
L
Linus Torvalds 已提交
79 80 81 82
 */
#pragma pack(1)

/*
83 84 85 86 87 88 89 90 91
 * Note: C bitfields are not used for this reason:
 *
 * "Bitfields are great and easy to read, but unfortunately the C language
 * does not specify the layout of bitfields in memory, which means they are
 * essentially useless for dealing with packed data in on-disk formats or
 * binary wire protocols." (Or ACPI tables and buffers.) "If you ask me,
 * this decision was a design error in C. Ritchie could have picked an order
 * and stuck with it." Norman Ramsey.
 * See http://stackoverflow.com/a/1053662/41661
L
Linus Torvalds 已提交
92 93
 */

B
Bob Moore 已提交
94 95
/*******************************************************************************
 *
96 97
 * Master ACPI Table Header. This common header is used by all ACPI tables
 * except the RSDP and FACS.
B
Bob Moore 已提交
98 99
 *
 ******************************************************************************/
L
Linus Torvalds 已提交
100

B
Bob Moore 已提交
101
struct acpi_table_header {
102 103
	char signature[ACPI_NAME_SIZE];	/* ASCII table signature */
	u32 length;		/* Length of table in bytes, including this header */
104
	u8 revision;		/* ACPI Specification minor version number */
105 106 107 108 109 110 111
	u8 checksum;		/* To make sum of entire table == 0 */
	char oem_id[ACPI_OEM_ID_SIZE];	/* ASCII OEM identification */
	char oem_table_id[ACPI_OEM_TABLE_ID_SIZE];	/* ASCII OEM table identification */
	u32 oem_revision;	/* OEM revision number */
	char asl_compiler_id[ACPI_NAME_SIZE];	/* ASCII ASL compiler vendor ID */
	u32 asl_compiler_revision;	/* ASL compiler version */
};
L
Linus Torvalds 已提交
112

113 114
/*******************************************************************************
 *
B
Bob Moore 已提交
115
 * GAS - Generic Address Structure (ACPI 2.0+)
116 117
 *
 * Note: Since this structure is used in the ACPI tables, it is byte aligned.
118
 * If misaligned access is not supported by the hardware, accesses to the
119 120 121 122
 * 64-bit Address field must be performed with care.
 *
 ******************************************************************************/

B
Bob Moore 已提交
123
struct acpi_generic_address {
124 125 126
	u8 space_id;		/* Address space where struct or register exists */
	u8 bit_width;		/* Size in bits of given register */
	u8 bit_offset;		/* Bit offset within the register */
B
Bob Moore 已提交
127 128 129
	u8 access_width;	/* Minimum Access size (ACPI 3.0) */
	u64 address;		/* 64-bit address of struct or register */
};
L
Linus Torvalds 已提交
130

B
Bob Moore 已提交
131 132 133
/*******************************************************************************
 *
 * RSDP - Root System Description Pointer (Signature is "RSD PTR ")
134
 *        Version 2
B
Bob Moore 已提交
135 136 137
 *
 ******************************************************************************/

138
struct acpi_table_rsdp {
B
Bob Moore 已提交
139 140
	char signature[8];	/* ACPI signature, contains "RSD PTR " */
	u8 checksum;		/* ACPI 1.0 checksum */
141
	char oem_id[ACPI_OEM_ID_SIZE];	/* OEM identification */
B
Bob Moore 已提交
142 143 144 145 146 147 148
	u8 revision;		/* Must be (0) for ACPI 1.0 or (2) for ACPI 2.0+ */
	u32 rsdt_physical_address;	/* 32-bit physical address of the RSDT */
	u32 length;		/* Table length in bytes, including header (ACPI 2.0+) */
	u64 xsdt_physical_address;	/* 64-bit physical address of the XSDT (ACPI 2.0+) */
	u8 extended_checksum;	/* Checksum of entire table (ACPI 2.0+) */
	u8 reserved[3];		/* Reserved, must be zero */
};
L
Linus Torvalds 已提交
149

L
Lv Zheng 已提交
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
/* Standalone struct for the ACPI 1.0 RSDP */

struct acpi_rsdp_common {
	char signature[8];
	u8 checksum;
	char oem_id[ACPI_OEM_ID_SIZE];
	u8 revision;
	u32 rsdt_physical_address;
};

/* Standalone struct for the extended part of the RSDP (ACPI 2.0+) */

struct acpi_rsdp_extension {
	u32 length;
	u64 xsdt_physical_address;
	u8 extended_checksum;
	u8 reserved[3];
};
L
Linus Torvalds 已提交
168

B
Bob Moore 已提交
169 170 171
/*******************************************************************************
 *
 * RSDT/XSDT - Root System Description Tables
172
 *             Version 1 (both)
B
Bob Moore 已提交
173 174
 *
 ******************************************************************************/
L
Linus Torvalds 已提交
175

176 177 178
struct acpi_table_rsdt {
	struct acpi_table_header header;	/* Common ACPI table header */
	u32 table_offset_entry[1];	/* Array of pointers to ACPI tables */
B
Bob Moore 已提交
179 180
};

181 182 183
struct acpi_table_xsdt {
	struct acpi_table_header header;	/* Common ACPI table header */
	u64 table_offset_entry[1];	/* Array of pointers to ACPI tables */
B
Bob Moore 已提交
184 185
};

186 187 188
#define ACPI_RSDT_ENTRY_SIZE        (sizeof (u32))
#define ACPI_XSDT_ENTRY_SIZE        (sizeof (u64))

B
Bob Moore 已提交
189 190 191 192 193 194
/*******************************************************************************
 *
 * FACS - Firmware ACPI Control Structure (FACS)
 *
 ******************************************************************************/

195
struct acpi_table_facs {
B
Bob Moore 已提交
196 197 198 199 200
	char signature[4];	/* ASCII table signature */
	u32 length;		/* Length of structure, in bytes */
	u32 hardware_signature;	/* Hardware configuration signature */
	u32 firmware_waking_vector;	/* 32-bit physical address of the Firmware Waking Vector */
	u32 global_lock;	/* Global Lock for shared hardware resources */
201
	u32 flags;
B
Bob Moore 已提交
202 203
	u64 xfirmware_waking_vector;	/* 64-bit version of the Firmware Waking Vector (ACPI 2.0+) */
	u8 version;		/* Version of this table (ACPI 2.0+) */
204 205 206
	u8 reserved[3];		/* Reserved, must be zero */
	u32 ospm_flags;		/* Flags to be set by OSPM (ACPI 4.0) */
	u8 reserved1[24];	/* Reserved, must be zero */
B
Bob Moore 已提交
207
};
L
Linus Torvalds 已提交
208

209
/* Masks for global_lock flag field above */
210 211 212 213

#define ACPI_GLOCK_PENDING          (1)	/* 00: Pending global lock ownership */
#define ACPI_GLOCK_OWNED            (1<<1)	/* 01: Global lock is owned */

214
/* Masks for Flags field above  */
215

216 217
#define ACPI_FACS_S4_BIOS_PRESENT   (1)	/* 00: S4BIOS support is present */
#define ACPI_FACS_64BIT_WAKE        (1<<1)	/* 01: 64-bit wake vector supported (ACPI 4.0) */
218

219
/* Masks for ospm_flags field above */
220

221
#define ACPI_FACS_64BIT_ENVIRONMENT (1)	/* 00: 64-bit wake environment is required (ACPI 4.0) */
L
Linus Torvalds 已提交
222

B
Bob Moore 已提交
223 224 225
/*******************************************************************************
 *
 * FADT - Fixed ACPI Description Table (Signature "FACP")
B
Bob Moore 已提交
226
 *        Version 6
B
Bob Moore 已提交
227 228 229 230 231
 *
 ******************************************************************************/

/* Fields common to all versions of the FADT */

232
struct acpi_table_fadt {
B
Bob Moore 已提交
233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298
	struct acpi_table_header header;	/* [V1] Common ACPI table header */
	u32 facs;		/* [V1] 32-bit physical address of FACS */
	u32 dsdt;		/* [V1] 32-bit physical address of DSDT */
	u8 model;		/* [V1] System Interrupt Model (ACPI 1.0) - not used in ACPI 2.0+ */
	u8 preferred_profile;	/* [V1] Conveys preferred power management profile to OSPM. */
	u16 sci_interrupt;	/* [V1] System vector of SCI interrupt */
	u32 smi_command;	/* [V1] 32-bit Port address of SMI command port */
	u8 acpi_enable;		/* [V1] Value to write to SMI_CMD to enable ACPI */
	u8 acpi_disable;	/* [V1] Value to write to SMI_CMD to disable ACPI */
	u8 s4_bios_request;	/* [V1] Value to write to SMI_CMD to enter S4BIOS state */
	u8 pstate_control;	/* [V1] Processor performance state control */
	u32 pm1a_event_block;	/* [V1] 32-bit port address of Power Mgt 1a Event Reg Blk */
	u32 pm1b_event_block;	/* [V1] 32-bit port address of Power Mgt 1b Event Reg Blk */
	u32 pm1a_control_block;	/* [V1] 32-bit port address of Power Mgt 1a Control Reg Blk */
	u32 pm1b_control_block;	/* [V1] 32-bit port address of Power Mgt 1b Control Reg Blk */
	u32 pm2_control_block;	/* [V1] 32-bit port address of Power Mgt 2 Control Reg Blk */
	u32 pm_timer_block;	/* [V1] 32-bit port address of Power Mgt Timer Ctrl Reg Blk */
	u32 gpe0_block;		/* [V1] 32-bit port address of General Purpose Event 0 Reg Blk */
	u32 gpe1_block;		/* [V1] 32-bit port address of General Purpose Event 1 Reg Blk */
	u8 pm1_event_length;	/* [V1] Byte Length of ports at pm1x_event_block */
	u8 pm1_control_length;	/* [V1] Byte Length of ports at pm1x_control_block */
	u8 pm2_control_length;	/* [V1] Byte Length of ports at pm2_control_block */
	u8 pm_timer_length;	/* [V1] Byte Length of ports at pm_timer_block */
	u8 gpe0_block_length;	/* [V1] Byte Length of ports at gpe0_block */
	u8 gpe1_block_length;	/* [V1] Byte Length of ports at gpe1_block */
	u8 gpe1_base;		/* [V1] Offset in GPE number space where GPE1 events start */
	u8 cst_control;		/* [V1] Support for the _CST object and C-States change notification */
	u16 c2_latency;		/* [V1] Worst case HW latency to enter/exit C2 state */
	u16 c3_latency;		/* [V1] Worst case HW latency to enter/exit C3 state */
	u16 flush_size;		/* [V1] Processor memory cache line width, in bytes */
	u16 flush_stride;	/* [V1] Number of flush strides that need to be read */
	u8 duty_offset;		/* [V1] Processor duty cycle index in processor P_CNT reg */
	u8 duty_width;		/* [V1] Processor duty cycle value bit width in P_CNT register */
	u8 day_alarm;		/* [V1] Index to day-of-month alarm in RTC CMOS RAM */
	u8 month_alarm;		/* [V1] Index to month-of-year alarm in RTC CMOS RAM */
	u8 century;		/* [V1] Index to century in RTC CMOS RAM */
	u16 boot_flags;		/* [V3] IA-PC Boot Architecture Flags (see below for individual flags) */
	u8 reserved;		/* [V1] Reserved, must be zero */
	u32 flags;		/* [V1] Miscellaneous flag bits (see below for individual flags) */
	/* End of Version 1 FADT fields (ACPI 1.0) */

	struct acpi_generic_address reset_register;	/* [V3] 64-bit address of the Reset register */
	u8 reset_value;		/* [V3] Value to write to the reset_register port to reset the system */
	u16 arm_boot_flags;	/* [V5] ARM-Specific Boot Flags (see below for individual flags) (ACPI 5.1) */
	u8 minor_revision;	/* [V5] FADT Minor Revision (ACPI 5.1) */
	u64 Xfacs;		/* [V3] 64-bit physical address of FACS */
	u64 Xdsdt;		/* [V3] 64-bit physical address of DSDT */
	struct acpi_generic_address xpm1a_event_block;	/* [V3] 64-bit Extended Power Mgt 1a Event Reg Blk address */
	struct acpi_generic_address xpm1b_event_block;	/* [V3] 64-bit Extended Power Mgt 1b Event Reg Blk address */
	struct acpi_generic_address xpm1a_control_block;	/* [V3] 64-bit Extended Power Mgt 1a Control Reg Blk address */
	struct acpi_generic_address xpm1b_control_block;	/* [V3] 64-bit Extended Power Mgt 1b Control Reg Blk address */
	struct acpi_generic_address xpm2_control_block;	/* [V3] 64-bit Extended Power Mgt 2 Control Reg Blk address */
	struct acpi_generic_address xpm_timer_block;	/* [V3] 64-bit Extended Power Mgt Timer Ctrl Reg Blk address */
	struct acpi_generic_address xgpe0_block;	/* [V3] 64-bit Extended General Purpose Event 0 Reg Blk address */
	struct acpi_generic_address xgpe1_block;	/* [V3] 64-bit Extended General Purpose Event 1 Reg Blk address */
	/* End of Version 3 FADT fields (ACPI 2.0) */

	struct acpi_generic_address sleep_control;	/* [V4] 64-bit Sleep Control register (ACPI 5.0) */
	/* End of Version 4 FADT fields (ACPI 3.0 and ACPI 4.0) (Field was originally reserved in ACPI 3.0) */

	struct acpi_generic_address sleep_status;	/* [V5] 64-bit Sleep Status register (ACPI 5.0) */
	/* End of Version 5 FADT fields (ACPI 5.0) */

	u64 hypervisor_id;	/* [V6] Hypervisor Vendor ID (ACPI 6.0) */
	/* End of Version 6 FADT fields (ACPI 6.0) */

L
Linus Torvalds 已提交
299 300
};

301
/* Masks for FADT IA-PC Boot Architecture Flags (boot_flags) [Vx]=Introduced in this FADT revision */
B
Bob Moore 已提交
302 303 304 305 306 307

#define ACPI_FADT_LEGACY_DEVICES    (1)  	/* 00: [V2] System has LPC or ISA bus devices */
#define ACPI_FADT_8042              (1<<1)	/* 01: [V3] System has an 8042 controller on port 60/64 */
#define ACPI_FADT_NO_VGA            (1<<2)	/* 02: [V4] It is not safe to probe for VGA hardware */
#define ACPI_FADT_NO_MSI            (1<<3)	/* 03: [V4] Message Signaled Interrupts (MSI) must not be enabled */
#define ACPI_FADT_NO_ASPM           (1<<4)	/* 04: [V4] PCIe ASPM control must not be enabled */
308
#define ACPI_FADT_NO_CMOS_RTC       (1<<5)	/* 05: [V5] No CMOS real-time clock present */
B
Bob Moore 已提交
309 310 311

#define FADT2_REVISION_ID               3

312 313
/* Masks for FADT ARM Boot Architecture Flags (arm_boot_flags) ACPI 5.1 */

B
Bob Moore 已提交
314 315
#define ACPI_FADT_PSCI_COMPLIANT    (1)	/* 00: [V5] PSCI 0.2+ is implemented */
#define ACPI_FADT_PSCI_USE_HVC      (1<<1)	/* 01: [V5] HVC must be used instead of SMC as the PSCI conduit */
316

317
/* Masks for FADT flags */
318

319 320
#define ACPI_FADT_WBINVD            (1)	/* 00: [V1] The WBINVD instruction works properly */
#define ACPI_FADT_WBINVD_FLUSH      (1<<1)	/* 01: [V1] WBINVD flushes but does not invalidate caches */
B
Bob Moore 已提交
321 322 323 324
#define ACPI_FADT_C1_SUPPORTED      (1<<2)	/* 02: [V1] All processors support C1 state */
#define ACPI_FADT_C2_MP_SUPPORTED   (1<<3)	/* 03: [V1] C2 state works on MP system */
#define ACPI_FADT_POWER_BUTTON      (1<<4)	/* 04: [V1] Power button is handled as a control method device */
#define ACPI_FADT_SLEEP_BUTTON      (1<<5)	/* 05: [V1] Sleep button is handled as a control method device */
325
#define ACPI_FADT_FIXED_RTC         (1<<6)	/* 06: [V1] RTC wakeup status is not in fixed register space */
B
Bob Moore 已提交
326 327 328 329 330 331 332 333 334 335 336 337
#define ACPI_FADT_S4_RTC_WAKE       (1<<7)	/* 07: [V1] RTC alarm can wake system from S4 */
#define ACPI_FADT_32BIT_TIMER       (1<<8)	/* 08: [V1] ACPI timer width is 32-bit (0=24-bit) */
#define ACPI_FADT_DOCKING_SUPPORTED (1<<9)	/* 09: [V1] Docking supported */
#define ACPI_FADT_RESET_REGISTER    (1<<10)	/* 10: [V2] System reset via the FADT RESET_REG supported */
#define ACPI_FADT_SEALED_CASE       (1<<11)	/* 11: [V3] No internal expansion capabilities and case is sealed */
#define ACPI_FADT_HEADLESS          (1<<12)	/* 12: [V3] No local video capabilities or local input devices */
#define ACPI_FADT_SLEEP_TYPE        (1<<13)	/* 13: [V3] Must execute native instruction after writing  SLP_TYPx register */
#define ACPI_FADT_PCI_EXPRESS_WAKE  (1<<14)	/* 14: [V4] System supports PCIEXP_WAKE (STS/EN) bits (ACPI 3.0) */
#define ACPI_FADT_PLATFORM_CLOCK    (1<<15)	/* 15: [V4] OSPM should use platform-provided timer (ACPI 3.0) */
#define ACPI_FADT_S4_RTC_VALID      (1<<16)	/* 16: [V4] Contents of RTC_STS valid after S4 wake (ACPI 3.0) */
#define ACPI_FADT_REMOTE_POWER_ON   (1<<17)	/* 17: [V4] System is compatible with remote power on (ACPI 3.0) */
#define ACPI_FADT_APIC_CLUSTER      (1<<18)	/* 18: [V4] All local APICs must use cluster model (ACPI 3.0) */
338
#define ACPI_FADT_APIC_PHYSICAL     (1<<19)	/* 19: [V4] All local xAPICs must use physical dest mode (ACPI 3.0) */
339 340
#define ACPI_FADT_HW_REDUCED        (1<<20)	/* 20: [V5] ACPI hardware is not implemented (ACPI 5.0) */
#define ACPI_FADT_LOW_POWER_S0      (1<<21)	/* 21: [V5] S0 power savings are equal or better than S3 (ACPI 5.0) */
B
Bob Moore 已提交
341

L
Lucas De Marchi 已提交
342
/* Values for preferred_profile (Preferred Power Management Profiles) */
L
Linus Torvalds 已提交
343

344
enum acpi_preferred_pm_profiles {
345 346 347 348 349 350
	PM_UNSPECIFIED = 0,
	PM_DESKTOP = 1,
	PM_MOBILE = 2,
	PM_WORKSTATION = 3,
	PM_ENTERPRISE_SERVER = 4,
	PM_SOHO_SERVER = 5,
351 352 353
	PM_APPLIANCE_PC = 6,
	PM_PERFORMANCE_SERVER = 7,
	PM_TABLET = 8
L
Linus Torvalds 已提交
354 355
};

356
/* Values for sleep_status and sleep_control registers (V5+ FADT) */
357 358 359 360 361 362

#define ACPI_X_WAKE_STATUS          0x80
#define ACPI_X_SLEEP_TYPE_MASK      0x1C
#define ACPI_X_SLEEP_TYPE_POSITION  0x02
#define ACPI_X_SLEEP_ENABLE         0x20

B
Bob Moore 已提交
363
/* Reset to default packing */
L
Linus Torvalds 已提交
364 365 366

#pragma pack()

367 368 369
/*
 * Internal table-related structures
 */
370 371 372 373 374
union acpi_name_union {
	u32 integer;
	char ascii[4];
};

375 376
/* Internal ACPI Table Descriptor. One per ACPI table. */

377 378 379
struct acpi_table_desc {
	acpi_physical_address address;
	struct acpi_table_header *pointer;
380
	u32 length;		/* Length fixed at 32 bits (fixed in table header) */
381 382 383 384 385
	union acpi_name_union signature;
	acpi_owner_id owner_id;
	u8 flags;
};

386
/* Masks for Flags field above */
387

388 389 390
#define ACPI_TABLE_ORIGIN_EXTERNAL_VIRTUAL  (0)	/* Virtual address, external maintained */
#define ACPI_TABLE_ORIGIN_INTERNAL_PHYSICAL (1)	/* Physical address, internally mapped */
#define ACPI_TABLE_ORIGIN_INTERNAL_VIRTUAL  (2)	/* Virtual address, internallly allocated */
391 392
#define ACPI_TABLE_ORIGIN_MASK              (3)
#define ACPI_TABLE_IS_LOADED                (8)
393

L
Linus Torvalds 已提交
394
/*
395
 * Get the remaining ACPI tables
L
Linus Torvalds 已提交
396
 */
397
#include <acpi/actbl1.h>
398
#include <acpi/actbl2.h>
399
#include <acpi/actbl3.h>
400

401 402 403 404
/* Macros used to generate offsets to specific table fields */

#define ACPI_FADT_OFFSET(f)             (u16) ACPI_OFFSET (struct acpi_table_fadt, f)

405 406 407 408 409 410 411
/*
 * Sizes of the various flavors of FADT. We need to look closely
 * at the FADT length because the version number essentially tells
 * us nothing because of many BIOS bugs where the version does not
 * match the expected length. In other words, the length of the
 * FADT is the bottom line as to what the version really is.
 *
B
Bob Moore 已提交
412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429
 * NOTE: There is no officialy released V2 of the FADT. This
 * version was used only for prototyping and testing during the
 * 32-bit to 64-bit transition. V3 was the first official 64-bit
 * version of the FADT.
 *
 * Update this list of defines when a new version of the FADT is
 * added to the ACPI specification. Note that the FADT version is
 * only incremented when new fields are appended to the existing
 * version. Therefore, the FADT version is competely independent
 * from the version of the ACPI specification where it is
 * defined.
 *
 * For reference, the various FADT lengths are as follows:
 *     FADT V1 size: 0x074      ACPI 1.0
 *     FADT V3 size: 0x0F4      ACPI 2.0
 *     FADT V4 size: 0x100      ACPI 3.0 and ACPI 4.0
 *     FADT V5 size: 0x10C      ACPI 5.0
 *     FADT V6 size: 0x114      ACPI 6.0
430
 */
B
Bob Moore 已提交
431 432 433 434 435 436 437
#define ACPI_FADT_V1_SIZE       (u32) (ACPI_FADT_OFFSET (flags) + 4)	/* ACPI 1.0 */
#define ACPI_FADT_V3_SIZE       (u32) (ACPI_FADT_OFFSET (sleep_control))	/* ACPI 2.0 */
#define ACPI_FADT_V4_SIZE       (u32) (ACPI_FADT_OFFSET (sleep_status))	/* ACPI 3.0 and ACPI 4.0 */
#define ACPI_FADT_V5_SIZE       (u32) (ACPI_FADT_OFFSET (hypervisor_id))	/* ACPI 5.0 */
#define ACPI_FADT_V6_SIZE       (u32) (sizeof (struct acpi_table_fadt))	/* ACPI 6.0 */

/* Update these when new FADT versions are added */
438

B
Bob Moore 已提交
439
#define ACPI_FADT_MAX_VERSION   6
B
Bob Moore 已提交
440 441
#define ACPI_FADT_CONFORMANCE   "ACPI 6.1 (FADT version 6)"

L
Len Brown 已提交
442
#endif				/* __ACTBL_H__ */