1 /******************************************************************************
3 * Name: actbl3.h - ACPI Table Definitions
5 *****************************************************************************/
8 * Copyright (C) 2000 - 2012, Intel Corp.
11 * Redistribution and use in source and binary forms, with or without
12 * modification, are permitted provided that the following conditions
14 * 1. Redistributions of source code must retain the above copyright
15 * notice, this list of conditions, and the following disclaimer,
16 * without modification.
17 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18 * substantially similar to the "NO WARRANTY" disclaimer below
19 * ("Disclaimer") and any redistribution must be conditioned upon
20 * including a substantially similar Disclaimer requirement for further
21 * binary redistribution.
22 * 3. Neither the names of the above-listed copyright holders nor the names
23 * of any contributors may be used to endorse or promote products derived
24 * from this software without specific prior written permission.
26 * Alternatively, this software may be distributed under the terms of the
27 * GNU General Public License ("GPL") version 2 as published by the Free
28 * Software Foundation.
31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41 * POSSIBILITY OF SUCH DAMAGES.
47 /*******************************************************************************
49 * Additional ACPI Tables (3)
51 * These tables are not consumed directly by the ACPICA subsystem, but are
52 * included here to support device drivers and the AML disassembler.
54 * The tables in this file are fully defined within the ACPI specification.
56 ******************************************************************************/
59 * Values for description table header signatures for tables defined in this
60 * file. Useful because they make it more difficult to inadvertently type in
61 * the wrong signature.
63 #define ACPI_SIG_BGRT "BGRT" /* Boot Graphics Resource Table */
64 #define ACPI_SIG_DRTM "DRTM" /* Dynamic Root of Trust for Measurement table */
65 #define ACPI_SIG_FPDT "FPDT" /* Firmware Performance Data Table */
66 #define ACPI_SIG_GTDT "GTDT" /* Generic Timer Description Table */
67 #define ACPI_SIG_MPST "MPST" /* Memory Power State Table */
68 #define ACPI_SIG_PCCT "PCCT" /* Platform Communications Channel Table */
69 #define ACPI_SIG_PMTT "PMTT" /* Platform Memory Topology Table */
70 #define ACPI_SIG_RASF "RASF" /* RAS Feature table */
72 #define ACPI_SIG_S3PT "S3PT" /* S3 Performance (sub)Table */
73 #define ACPI_SIG_PCCS "PCC" /* PCC Shared Memory Region */
75 /* Reserved table signatures */
77 #define ACPI_SIG_CSRT "CSRT" /* Core System Resources Table */
78 #define ACPI_SIG_DBG2 "DBG2" /* Debug Port table 2 */
79 #define ACPI_SIG_MATR "MATR" /* Memory Address Translation Table */
80 #define ACPI_SIG_MSDM "MSDM" /* Microsoft Data Management Table */
81 #define ACPI_SIG_WPBT "WPBT" /* Windows Platform Binary Table */
84 * All tables must be byte-packed to match the ACPI specification, since
85 * the tables are provided by the system BIOS.
90 * Note about bitfields: The u8 type is used for bitfields in ACPI tables.
91 * This is the only type that is even remotely portable. Anything else is not
92 * portable, so do not use any other bitfield types.
95 /*******************************************************************************
97 * BGRT - Boot Graphics Resource Table (ACPI 5.0)
100 ******************************************************************************/
102 struct acpi_table_bgrt
{
103 struct acpi_table_header header
; /* Common ACPI table header */
112 /*******************************************************************************
114 * DRTM - Dynamic Root of Trust for Measurement table
116 ******************************************************************************/
118 struct acpi_table_drtm
{
119 struct acpi_table_header header
; /* Common ACPI table header */
120 u64 entry_base_address
;
125 u64 log_area_address
;
127 u64 arch_dependent_address
;
131 /* 1) Validated Tables List */
133 struct acpi_drtm_vtl_list
{
134 u32 validated_table_list_count
;
137 /* 2) Resources List */
139 struct acpi_drtm_resource_list
{
140 u32 resource_list_count
;
143 /* 3) Platform-specific Identifiers List */
145 struct acpi_drtm_id_list
{
149 /*******************************************************************************
151 * FPDT - Firmware Performance Data Table (ACPI 5.0)
154 ******************************************************************************/
156 struct acpi_table_fpdt
{
157 struct acpi_table_header header
; /* Common ACPI table header */
160 /* FPDT subtable header */
162 struct acpi_fpdt_header
{
168 /* Values for Type field above */
170 enum acpi_fpdt_type
{
171 ACPI_FPDT_TYPE_BOOT
= 0,
172 ACPI_FPDT_TYPE_S3PERF
= 1,
179 /* 0: Firmware Basic Boot Performance Record */
181 struct acpi_fpdt_boot
{
182 struct acpi_fpdt_header header
;
187 u64 exit_services_entry
;
188 u64 exit_services_exit
;
191 /* 1: S3 Performance Table Pointer Record */
193 struct acpi_fpdt_s3pt_ptr
{
194 struct acpi_fpdt_header header
;
200 * S3PT - S3 Performance Table. This table is pointed to by the
201 * FPDT S3 Pointer Record above.
203 struct acpi_table_s3pt
{
204 u8 signature
[4]; /* "S3PT" */
211 struct acpi_s3pt_header
{
217 /* Values for Type field above */
219 enum acpi_s3pt_type
{
220 ACPI_S3PT_TYPE_RESUME
= 0,
221 ACPI_S3PT_TYPE_SUSPEND
= 1,
224 struct acpi_s3pt_resume
{
225 struct acpi_s3pt_header header
;
231 struct acpi_s3pt_suspend
{
232 struct acpi_s3pt_header header
;
237 /*******************************************************************************
239 * GTDT - Generic Timer Description Table (ACPI 5.0)
242 ******************************************************************************/
244 struct acpi_table_gtdt
{
245 struct acpi_table_header header
; /* Common ACPI table header */
248 u32 secure_pl1_interrupt
;
249 u32 secure_pl1_flags
;
250 u32 non_secure_pl1_interrupt
;
251 u32 non_secure_pl1_flags
;
252 u32 virtual_timer_interrupt
;
253 u32 virtual_timer_flags
;
254 u32 non_secure_pl2_interrupt
;
255 u32 non_secure_pl2_flags
;
258 /* Values for Flags field above */
260 #define ACPI_GTDT_MAPPED_BLOCK_PRESENT 1
262 /* Values for all "TimerFlags" fields above */
264 #define ACPI_GTDT_INTERRUPT_MODE 1
265 #define ACPI_GTDT_INTERRUPT_POLARITY 2
267 /*******************************************************************************
269 * MPST - Memory Power State Table (ACPI 5.0)
272 ******************************************************************************/
274 #define ACPI_MPST_CHANNEL_INFO \
278 u16 power_node_count;
282 struct acpi_table_mpst
{
283 struct acpi_table_header header
; /* Common ACPI table header */
284 ACPI_MPST_CHANNEL_INFO
/* Platform Communication Channel */
287 /* Memory Platform Communication Channel Info */
289 struct acpi_mpst_channel
{
290 ACPI_MPST_CHANNEL_INFO
/* Platform Communication Channel */
293 /* Memory Power Node Structure */
295 struct acpi_mpst_power_node
{
303 u8 num_physical_components
;
307 /* Values for Flags field above */
309 #define ACPI_MPST_ENABLED 1
310 #define ACPI_MPST_POWER_MANAGED 2
311 #define ACPI_MPST_HOT_PLUG_CAPABLE 4
313 /* Memory Power State Structure (follows POWER_NODE above) */
315 struct acpi_mpst_power_state
{
320 /* Physical Component ID Structure (follows POWER_STATE above) */
322 struct acpi_mpst_component
{
326 /* Memory Power State Characteristics Structure (follows all POWER_NODEs) */
328 struct acpi_mpst_data_hdr
{
329 u16 characteristics_count
;
332 struct acpi_mpst_power_data
{
342 /* Values for Flags field above */
344 #define ACPI_MPST_PRESERVE 1
345 #define ACPI_MPST_AUTOENTRY 2
346 #define ACPI_MPST_AUTOEXIT 4
348 /* Shared Memory Region (not part of an ACPI table) */
350 struct acpi_mpst_shared
{
354 u16 command_register
;
362 /*******************************************************************************
364 * PCCT - Platform Communications Channel Table (ACPI 5.0)
367 ******************************************************************************/
369 struct acpi_table_pcct
{
370 struct acpi_table_header header
; /* Common ACPI table header */
376 /* Values for Flags field above */
378 #define ACPI_PCCT_DOORBELL 1
384 /* 0: Generic Communications Subspace */
386 struct acpi_pcct_subspace
{
387 struct acpi_subtable_header header
;
391 struct acpi_generic_address doorbell_register
;
397 * PCC memory structures (not part of the ACPI table)
400 /* Shared Memory Region */
402 struct acpi_pcct_shared_memory
{
408 /*******************************************************************************
410 * PMTT - Platform Memory Topology Table (ACPI 5.0)
413 ******************************************************************************/
415 struct acpi_table_pmtt
{
416 struct acpi_table_header header
; /* Common ACPI table header */
420 /* Common header for PMTT subtables that follow main table */
422 struct acpi_pmtt_header
{
430 /* Values for Type field above */
432 #define ACPI_PMTT_TYPE_SOCKET 0
433 #define ACPI_PMTT_TYPE_CONTROLLER 1
434 #define ACPI_PMTT_TYPE_DIMM 2
435 #define ACPI_PMTT_TYPE_RESERVED 3 /* 0x03-0xFF are reserved */
437 /* Values for Flags field above */
439 #define ACPI_PMTT_TOP_LEVEL 0x0001
440 #define ACPI_PMTT_PHYSICAL 0x0002
441 #define ACPI_PMTT_MEMORY_TYPE 0x000C
444 * PMTT subtables, correspond to Type in struct acpi_pmtt_header
447 /* 0: Socket Structure */
449 struct acpi_pmtt_socket
{
450 struct acpi_pmtt_header header
;
455 /* 1: Memory Controller subtable */
457 struct acpi_pmtt_controller
{
458 struct acpi_pmtt_header header
;
469 /* 1a: Proximity Domain substructure */
471 struct acpi_pmtt_domain
{
472 u32 proximity_domain
;
475 /* 2: Physical Component Identifier (DIMM) */
477 struct acpi_pmtt_physical_component
{
478 struct acpi_pmtt_header header
;
485 /*******************************************************************************
487 * RASF - RAS Feature Table (ACPI 5.0)
490 ******************************************************************************/
492 struct acpi_table_rasf
{
493 struct acpi_table_header header
; /* Common ACPI table header */
497 /* RASF Platform Communication Channel Shared Memory Region */
499 struct acpi_rasf_shared_memory
{
503 u64 requested_address
;
504 u64 requested_length
;
511 /* Masks for Flags and Speed fields above */
513 #define ACPI_RASF_SCRUBBER_RUNNING 1
514 #define ACPI_RASF_SPEED (7<<1)
516 /* Channel Commands */
518 enum acpi_rasf_commands
{
519 ACPI_RASF_GET_RAS_CAPABILITIES
= 1,
520 ACPI_RASF_GET_PATROL_PARAMETERS
= 2,
521 ACPI_RASF_START_PATROL_SCRUBBER
= 3,
522 ACPI_RASF_STOP_PATROL_SCRUBBER
= 4
525 /* Channel Command flags */
527 #define ACPI_RASF_GENERATE_SCI (1<<15)
531 enum acpi_rasf_status
{
532 ACPI_RASF_SUCCESS
= 0,
533 ACPI_RASF_NOT_VALID
= 1,
534 ACPI_RASF_NOT_SUPPORTED
= 2,
536 ACPI_RASF_FAILED
= 4,
537 ACPI_RASF_ABORTED
= 5,
538 ACPI_RASF_INVALID_DATA
= 6
543 #define ACPI_RASF_COMMAND_COMPLETE (1)
544 #define ACPI_RASF_SCI_DOORBELL (1<<1)
545 #define ACPI_RASF_ERROR (1<<2)
546 #define ACPI_RASF_STATUS (0x1F<<3)
548 /* Reset to default packing */
552 #endif /* __ACTBL3_H__ */