]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Include/IndustryStandard/Acpi20.h
MdePkg: Replace BSD License with BSD+Patent License
[mirror_edk2.git] / MdePkg / Include / IndustryStandard / Acpi20.h
CommitLineData
9095d37b 1/** @file\r
ee6c452c 2 ACPI 2.0 definitions from the ACPI Specification, revision 2.0\r
568eb0cb 3\r
9095d37b 4 Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>\r
9344f092 5 SPDX-License-Identifier: BSD-2-Clause-Patent\r
568eb0cb 6**/\r
7\r
8#ifndef _ACPI_2_0_H_\r
9#define _ACPI_2_0_H_\r
10\r
732fb201 11#include <IndustryStandard/Acpi10.h>\r
568eb0cb 12\r
4a18b92c
JY
13//\r
14// Define for Desriptor\r
15//\r
16#define ACPI_LARGE_GENERIC_REGISTER_DESCRIPTOR_NAME 0x02\r
17\r
18#define ACPI_GENERIC_REGISTER_DESCRIPTOR 0x82\r
19\r
20//\r
21// Ensure proper structure formats\r
22//\r
23#pragma pack(1)\r
24\r
25///\r
26/// Generic Register Descriptor\r
27///\r
28typedef PACKED struct {\r
29 ACPI_LARGE_RESOURCE_HEADER Header;\r
30 UINT8 AddressSpaceId;\r
31 UINT8 RegisterBitWidth;\r
32 UINT8 RegisterBitOffset;\r
33 UINT8 AddressSize;\r
34 UINT64 RegisterAddress;\r
35} EFI_ACPI_GENERIC_REGISTER_DESCRIPTOR;\r
36\r
37#pragma pack()\r
38\r
568eb0cb 39//\r
40// Ensure proper structure formats\r
41//\r
42#pragma pack(1)\r
568eb0cb 43\r
1bc5d021 44///\r
45/// ACPI 2.0 Generic Address Space definition\r
46///\r
568eb0cb 47typedef struct {\r
48 UINT8 AddressSpaceId;\r
49 UINT8 RegisterBitWidth;\r
50 UINT8 RegisterBitOffset;\r
51 UINT8 Reserved;\r
52 UINT64 Address;\r
53} EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE;\r
54\r
55//\r
56// Generic Address Space Address IDs\r
57//\r
58#define EFI_ACPI_2_0_SYSTEM_MEMORY 0\r
59#define EFI_ACPI_2_0_SYSTEM_IO 1\r
60#define EFI_ACPI_2_0_PCI_CONFIGURATION_SPACE 2\r
61#define EFI_ACPI_2_0_EMBEDDED_CONTROLLER 3\r
62#define EFI_ACPI_2_0_SMBUS 4\r
63#define EFI_ACPI_2_0_FUNCTIONAL_FIXED_HARDWARE 0x7F\r
64\r
65//\r
66// ACPI 2.0 table structures\r
67//\r
1bc5d021 68\r
69///\r
70/// Root System Description Pointer Structure\r
71///\r
568eb0cb 72typedef struct {\r
73 UINT64 Signature;\r
74 UINT8 Checksum;\r
75 UINT8 OemId[6];\r
76 UINT8 Revision;\r
77 UINT32 RsdtAddress;\r
78 UINT32 Length;\r
79 UINT64 XsdtAddress;\r
80 UINT8 ExtendedChecksum;\r
81 UINT8 Reserved[3];\r
82} EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_POINTER;\r
83\r
1bc5d021 84///\r
85/// RSD_PTR Revision (as defined in ACPI 2.0 spec.)\r
86///\r
568eb0cb 87#define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_POINTER_REVISION 0x02\r
88\r
1bc5d021 89///\r
90/// Common table header, this prefaces all ACPI tables, including FACS, but\r
91/// excluding the RSD PTR structure\r
92///\r
568eb0cb 93typedef struct {\r
94 UINT32 Signature;\r
95 UINT32 Length;\r
96} EFI_ACPI_2_0_COMMON_HEADER;\r
97\r
98//\r
99// Root System Description Table\r
9095d37b 100// No definition needed as it is a common description table header, the same with\r
2b1cf49a 101// EFI_ACPI_DESCRIPTION_HEADER, followed by a variable number of UINT32 table pointers.\r
568eb0cb 102//\r
1bc5d021 103\r
104///\r
105/// RSDT Revision (as defined in ACPI 2.0 spec.)\r
106///\r
568eb0cb 107#define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_TABLE_REVISION 0x01\r
108\r
109//\r
110// Extended System Description Table\r
9095d37b 111// No definition needed as it is a common description table header, the same with\r
2b1cf49a 112// EFI_ACPI_DESCRIPTION_HEADER, followed by a variable number of UINT64 table pointers.\r
568eb0cb 113//\r
1bc5d021 114\r
115///\r
116/// XSDT Revision (as defined in ACPI 2.0 spec.)\r
117///\r
568eb0cb 118#define EFI_ACPI_2_0_EXTENDED_SYSTEM_DESCRIPTION_TABLE_REVISION 0x01\r
119\r
1bc5d021 120///\r
121/// Fixed ACPI Description Table Structure (FADT)\r
122///\r
568eb0cb 123typedef struct {\r
124 EFI_ACPI_DESCRIPTION_HEADER Header;\r
125 UINT32 FirmwareCtrl;\r
126 UINT32 Dsdt;\r
127 UINT8 Reserved0;\r
128 UINT8 PreferredPmProfile;\r
129 UINT16 SciInt;\r
130 UINT32 SmiCmd;\r
131 UINT8 AcpiEnable;\r
132 UINT8 AcpiDisable;\r
133 UINT8 S4BiosReq;\r
134 UINT8 PstateCnt;\r
135 UINT32 Pm1aEvtBlk;\r
136 UINT32 Pm1bEvtBlk;\r
137 UINT32 Pm1aCntBlk;\r
138 UINT32 Pm1bCntBlk;\r
139 UINT32 Pm2CntBlk;\r
140 UINT32 PmTmrBlk;\r
141 UINT32 Gpe0Blk;\r
142 UINT32 Gpe1Blk;\r
143 UINT8 Pm1EvtLen;\r
144 UINT8 Pm1CntLen;\r
145 UINT8 Pm2CntLen;\r
146 UINT8 PmTmrLen;\r
147 UINT8 Gpe0BlkLen;\r
148 UINT8 Gpe1BlkLen;\r
149 UINT8 Gpe1Base;\r
150 UINT8 CstCnt;\r
151 UINT16 PLvl2Lat;\r
152 UINT16 PLvl3Lat;\r
153 UINT16 FlushSize;\r
154 UINT16 FlushStride;\r
155 UINT8 DutyOffset;\r
156 UINT8 DutyWidth;\r
157 UINT8 DayAlrm;\r
158 UINT8 MonAlrm;\r
159 UINT8 Century;\r
160 UINT16 IaPcBootArch;\r
161 UINT8 Reserved1;\r
162 UINT32 Flags;\r
163 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE ResetReg;\r
164 UINT8 ResetValue;\r
165 UINT8 Reserved2[3];\r
166 UINT64 XFirmwareCtrl;\r
167 UINT64 XDsdt;\r
168 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XPm1aEvtBlk;\r
169 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XPm1bEvtBlk;\r
170 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XPm1aCntBlk;\r
171 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XPm1bCntBlk;\r
172 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XPm2CntBlk;\r
173 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XPmTmrBlk;\r
174 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XGpe0Blk;\r
175 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE XGpe1Blk;\r
176} EFI_ACPI_2_0_FIXED_ACPI_DESCRIPTION_TABLE;\r
177\r
1bc5d021 178///\r
179/// FADT Version (as defined in ACPI 2.0 spec.)\r
180///\r
568eb0cb 181#define EFI_ACPI_2_0_FIXED_ACPI_DESCRIPTION_TABLE_REVISION 0x03\r
182\r
4a18b92c
JY
183//\r
184// Fixed ACPI Description Table Preferred Power Management Profile\r
185//\r
186#define EFI_ACPI_2_0_PM_PROFILE_UNSPECIFIED 0\r
187#define EFI_ACPI_2_0_PM_PROFILE_DESKTOP 1\r
188#define EFI_ACPI_2_0_PM_PROFILE_MOBILE 2\r
189#define EFI_ACPI_2_0_PM_PROFILE_WORKSTATION 3\r
190#define EFI_ACPI_2_0_PM_PROFILE_ENTERPRISE_SERVER 4\r
191#define EFI_ACPI_2_0_PM_PROFILE_SOHO_SERVER 5\r
192#define EFI_ACPI_2_0_PM_PROFILE_APPLIANCE_PC 6\r
193\r
a2461f6b 194//\r
195// Fixed ACPI Description Table Boot Architecture Flags\r
196// All other bits are reserved and must be set to 0.\r
197//\r
198#define EFI_ACPI_2_0_LEGACY_DEVICES BIT0\r
199#define EFI_ACPI_2_0_8042 BIT1\r
568eb0cb 200\r
201//\r
202// Fixed ACPI Description Table Fixed Feature Flags\r
203// All other bits are reserved and must be set to 0.\r
204//\r
a2461f6b 205#define EFI_ACPI_2_0_WBINVD BIT0\r
206#define EFI_ACPI_2_0_WBINVD_FLUSH BIT1\r
207#define EFI_ACPI_2_0_PROC_C1 BIT2\r
208#define EFI_ACPI_2_0_P_LVL2_UP BIT3\r
209#define EFI_ACPI_2_0_PWR_BUTTON BIT4\r
210#define EFI_ACPI_2_0_SLP_BUTTON BIT5\r
211#define EFI_ACPI_2_0_FIX_RTC BIT6\r
212#define EFI_ACPI_2_0_RTC_S4 BIT7\r
213#define EFI_ACPI_2_0_TMR_VAL_EXT BIT8\r
214#define EFI_ACPI_2_0_DCK_CAP BIT9\r
215#define EFI_ACPI_2_0_RESET_REG_SUP BIT10\r
216#define EFI_ACPI_2_0_SEALED_CASE BIT11\r
217#define EFI_ACPI_2_0_HEADLESS BIT12\r
218#define EFI_ACPI_2_0_CPU_SW_SLP BIT13\r
568eb0cb 219\r
1bc5d021 220///\r
221/// Firmware ACPI Control Structure\r
222///\r
568eb0cb 223typedef struct {\r
224 UINT32 Signature;\r
225 UINT32 Length;\r
226 UINT32 HardwareSignature;\r
227 UINT32 FirmwareWakingVector;\r
228 UINT32 GlobalLock;\r
229 UINT32 Flags;\r
230 UINT64 XFirmwareWakingVector;\r
231 UINT8 Version;\r
232 UINT8 Reserved[31];\r
233} EFI_ACPI_2_0_FIRMWARE_ACPI_CONTROL_STRUCTURE;\r
234\r
1bc5d021 235///\r
236/// FACS Version (as defined in ACPI 2.0 spec.)\r
237///\r
568eb0cb 238#define EFI_ACPI_2_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_VERSION 0x01\r
239\r
1bc5d021 240///\r
241/// Firmware Control Structure Feature Flags\r
242/// All other bits are reserved and must be set to 0.\r
243///\r
a2461f6b 244#define EFI_ACPI_2_0_S4BIOS_F BIT0\r
568eb0cb 245\r
1bc5d021 246///\r
247/// Multiple APIC Description Table header definition. The rest of the table\r
248/// must be defined in a platform specific manner.\r
249///\r
568eb0cb 250typedef struct {\r
251 EFI_ACPI_DESCRIPTION_HEADER Header;\r
252 UINT32 LocalApicAddress;\r
253 UINT32 Flags;\r
254} EFI_ACPI_2_0_MULTIPLE_APIC_DESCRIPTION_TABLE_HEADER;\r
255\r
1bc5d021 256///\r
257/// MADT Revision (as defined in ACPI 2.0 spec.)\r
258///\r
568eb0cb 259#define EFI_ACPI_2_0_MULTIPLE_APIC_DESCRIPTION_TABLE_REVISION 0x01\r
260\r
1bc5d021 261///\r
262/// Multiple APIC Flags\r
263/// All other bits are reserved and must be set to 0.\r
264///\r
a2461f6b 265#define EFI_ACPI_2_0_PCAT_COMPAT BIT0\r
568eb0cb 266\r
267//\r
268// Multiple APIC Description Table APIC structure types\r
269// All other values between 0x09 an 0xFF are reserved and\r
270// will be ignored by OSPM.\r
271//\r
272#define EFI_ACPI_2_0_PROCESSOR_LOCAL_APIC 0x00\r
273#define EFI_ACPI_2_0_IO_APIC 0x01\r
274#define EFI_ACPI_2_0_INTERRUPT_SOURCE_OVERRIDE 0x02\r
275#define EFI_ACPI_2_0_NON_MASKABLE_INTERRUPT_SOURCE 0x03\r
276#define EFI_ACPI_2_0_LOCAL_APIC_NMI 0x04\r
277#define EFI_ACPI_2_0_LOCAL_APIC_ADDRESS_OVERRIDE 0x05\r
278#define EFI_ACPI_2_0_IO_SAPIC 0x06\r
279#define EFI_ACPI_2_0_PROCESSOR_LOCAL_SAPIC 0x07\r
280#define EFI_ACPI_2_0_PLATFORM_INTERRUPT_SOURCES 0x08\r
281\r
282//\r
283// APIC Structure Definitions\r
284//\r
1bc5d021 285\r
286///\r
287/// Processor Local APIC Structure Definition\r
288///\r
568eb0cb 289typedef struct {\r
290 UINT8 Type;\r
291 UINT8 Length;\r
292 UINT8 AcpiProcessorId;\r
293 UINT8 ApicId;\r
294 UINT32 Flags;\r
295} EFI_ACPI_2_0_PROCESSOR_LOCAL_APIC_STRUCTURE;\r
296\r
1bc5d021 297///\r
298/// Local APIC Flags. All other bits are reserved and must be 0.\r
299///\r
a2461f6b 300#define EFI_ACPI_2_0_LOCAL_APIC_ENABLED BIT0\r
568eb0cb 301\r
1bc5d021 302///\r
303/// IO APIC Structure\r
304///\r
568eb0cb 305typedef struct {\r
306 UINT8 Type;\r
307 UINT8 Length;\r
308 UINT8 IoApicId;\r
309 UINT8 Reserved;\r
310 UINT32 IoApicAddress;\r
311 UINT32 GlobalSystemInterruptBase;\r
312} EFI_ACPI_2_0_IO_APIC_STRUCTURE;\r
313\r
1bc5d021 314///\r
315/// Interrupt Source Override Structure\r
316///\r
568eb0cb 317typedef struct {\r
318 UINT8 Type;\r
319 UINT8 Length;\r
320 UINT8 Bus;\r
321 UINT8 Source;\r
322 UINT32 GlobalSystemInterrupt;\r
323 UINT16 Flags;\r
324} EFI_ACPI_2_0_INTERRUPT_SOURCE_OVERRIDE_STRUCTURE;\r
325\r
1bc5d021 326///\r
327/// Non-Maskable Interrupt Source Structure\r
328///\r
568eb0cb 329typedef struct {\r
330 UINT8 Type;\r
331 UINT8 Length;\r
332 UINT16 Flags;\r
333 UINT32 GlobalSystemInterrupt;\r
334} EFI_ACPI_2_0_NON_MASKABLE_INTERRUPT_SOURCE_STRUCTURE;\r
335\r
1bc5d021 336///\r
337/// Local APIC NMI Structure\r
338///\r
568eb0cb 339typedef struct {\r
340 UINT8 Type;\r
341 UINT8 Length;\r
342 UINT8 AcpiProcessorId;\r
343 UINT16 Flags;\r
344 UINT8 LocalApicLint;\r
345} EFI_ACPI_2_0_LOCAL_APIC_NMI_STRUCTURE;\r
346\r
1bc5d021 347///\r
348/// Local APIC Address Override Structure\r
349///\r
568eb0cb 350typedef struct {\r
351 UINT8 Type;\r
352 UINT8 Length;\r
353 UINT16 Reserved;\r
354 UINT64 LocalApicAddress;\r
355} EFI_ACPI_2_0_LOCAL_APIC_ADDRESS_OVERRIDE_STRUCTURE;\r
356\r
1bc5d021 357///\r
358/// IO SAPIC Structure\r
359///\r
568eb0cb 360typedef struct {\r
361 UINT8 Type;\r
362 UINT8 Length;\r
363 UINT8 IoApicId;\r
364 UINT8 Reserved;\r
365 UINT32 GlobalSystemInterruptBase;\r
366 UINT64 IoSapicAddress;\r
367} EFI_ACPI_2_0_IO_SAPIC_STRUCTURE;\r
368\r
1bc5d021 369///\r
370/// Local SAPIC Structure\r
371///\r
568eb0cb 372typedef struct {\r
373 UINT8 Type;\r
374 UINT8 Length;\r
375 UINT8 AcpiProcessorId;\r
376 UINT8 LocalSapicId;\r
377 UINT8 LocalSapicEid;\r
378 UINT8 Reserved[3];\r
379 UINT32 Flags;\r
380} EFI_ACPI_2_0_PROCESSOR_LOCAL_SAPIC_STRUCTURE;\r
381\r
1bc5d021 382///\r
383/// Platform Interrupt Sources Structure\r
384///\r
568eb0cb 385typedef struct {\r
386 UINT8 Type;\r
387 UINT8 Length;\r
388 UINT16 Flags;\r
389 UINT8 InterruptType;\r
390 UINT8 ProcessorId;\r
391 UINT8 ProcessorEid;\r
392 UINT8 IoSapicVector;\r
393 UINT32 GlobalSystemInterrupt;\r
394 UINT32 Reserved;\r
395} EFI_ACPI_2_0_PLATFORM_INTERRUPT_SOURCES_STRUCTURE;\r
396\r
1bc5d021 397///\r
398/// Smart Battery Description Table (SBST)\r
399///\r
568eb0cb 400typedef struct {\r
401 EFI_ACPI_DESCRIPTION_HEADER Header;\r
402 UINT32 WarningEnergyLevel;\r
403 UINT32 LowEnergyLevel;\r
404 UINT32 CriticalEnergyLevel;\r
405} EFI_ACPI_2_0_SMART_BATTERY_DESCRIPTION_TABLE;\r
406\r
1bc5d021 407///\r
408/// SBST Version (as defined in ACPI 2.0 spec.)\r
409///\r
568eb0cb 410#define EFI_ACPI_2_0_SMART_BATTERY_DESCRIPTION_TABLE_REVISION 0x01\r
411\r
1bc5d021 412///\r
413/// Embedded Controller Boot Resources Table (ECDT)\r
414/// The table is followed by a null terminated ASCII string that contains\r
415/// a fully qualified reference to the name space object.\r
416///\r
568eb0cb 417typedef struct {\r
418 EFI_ACPI_DESCRIPTION_HEADER Header;\r
419 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE EcControl;\r
420 EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE EcData;\r
421 UINT32 Uid;\r
422 UINT8 GpeBit;\r
423} EFI_ACPI_2_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE;\r
424\r
1bc5d021 425///\r
426/// ECDT Version (as defined in ACPI 2.0 spec.)\r
427///\r
568eb0cb 428#define EFI_ACPI_2_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE_REVISION 0x01\r
429\r
430//\r
431// Known table signatures\r
432//\r
1bc5d021 433\r
434///\r
435/// "RSD PTR " Root System Description Pointer\r
436///\r
13c31065 437#define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_POINTER_SIGNATURE SIGNATURE_64('R', 'S', 'D', ' ', 'P', 'T', 'R', ' ')\r
568eb0cb 438\r
1bc5d021 439///\r
440/// "SPIC" Multiple SAPIC Description Table\r
441///\r
442/// BUGBUG: Don't know where this came from except SR870BN4 uses it.\r
443/// #define EFI_ACPI_2_0_MULTIPLE_SAPIC_DESCRIPTION_TABLE_SIGNATURE 0x43495053\r
444///\r
75c123cc 445#define EFI_ACPI_2_0_MULTIPLE_SAPIC_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('A', 'P', 'I', 'C')\r
568eb0cb 446\r
1bc5d021 447///\r
448/// "BOOT" MS Simple Boot Spec\r
449///\r
13c31065 450#define EFI_ACPI_2_0_SIMPLE_BOOT_FLAG_TABLE_SIGNATURE SIGNATURE_32('B', 'O', 'O', 'T')\r
568eb0cb 451\r
1bc5d021 452///\r
453/// "DBGP" MS Bebug Port Spec\r
454///\r
13c31065 455#define EFI_ACPI_2_0_DEBUG_PORT_TABLE_SIGNATURE SIGNATURE_32('D', 'B', 'G', 'P')\r
568eb0cb 456\r
1bc5d021 457///\r
458/// "DSDT" Differentiated System Description Table\r
459///\r
13c31065 460#define EFI_ACPI_2_0_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('D', 'S', 'D', 'T')\r
568eb0cb 461\r
1bc5d021 462///\r
463/// "ECDT" Embedded Controller Boot Resources Table\r
464///\r
13c31065 465#define EFI_ACPI_2_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE_SIGNATURE SIGNATURE_32('E', 'C', 'D', 'T')\r
568eb0cb 466\r
1bc5d021 467///\r
468/// "ETDT" Event Timer Description Table\r
469///\r
13c31065 470#define EFI_ACPI_2_0_EVENT_TIMER_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('E', 'T', 'D', 'T')\r
568eb0cb 471\r
1bc5d021 472///\r
473/// "FACS" Firmware ACPI Control Structure\r
474///\r
13c31065 475#define EFI_ACPI_2_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_SIGNATURE SIGNATURE_32('F', 'A', 'C', 'S')\r
568eb0cb 476\r
1bc5d021 477///\r
478/// "FACP" Fixed ACPI Description Table\r
479///\r
13c31065 480#define EFI_ACPI_2_0_FIXED_ACPI_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('F', 'A', 'C', 'P')\r
568eb0cb 481\r
1bc5d021 482///\r
483/// "APIC" Multiple APIC Description Table\r
484///\r
13c31065 485#define EFI_ACPI_2_0_MULTIPLE_APIC_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('A', 'P', 'I', 'C')\r
568eb0cb 486\r
1bc5d021 487///\r
488/// "PSDT" Persistent System Description Table\r
489///\r
13c31065 490#define EFI_ACPI_2_0_PERSISTENT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('P', 'S', 'D', 'T')\r
568eb0cb 491\r
1bc5d021 492///\r
493/// "RSDT" Root System Description Table\r
494///\r
13c31065 495#define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('R', 'S', 'D', 'T')\r
568eb0cb 496\r
1bc5d021 497///\r
498/// "SBST" Smart Battery Specification Table\r
499///\r
13c31065 500#define EFI_ACPI_2_0_SMART_BATTERY_SPECIFICATION_TABLE_SIGNATURE SIGNATURE_32('S', 'B', 'S', 'T')\r
568eb0cb 501\r
1bc5d021 502///\r
503/// "SLIT" System Locality Information Table\r
504///\r
13c31065 505#define EFI_ACPI_2_0_SYSTEM_LOCALITY_INFORMATION_TABLE_SIGNATURE SIGNATURE_32('S', 'L', 'I', 'T')\r
568eb0cb 506\r
1bc5d021 507///\r
508/// "SPCR" Serial Port Concole Redirection Table\r
509///\r
13c31065 510#define EFI_ACPI_2_0_SERIAL_PORT_CONSOLE_REDIRECTION_TABLE_SIGNATURE SIGNATURE_32('S', 'P', 'C', 'R')\r
568eb0cb 511\r
1bc5d021 512///\r
513/// "SRAT" Static Resource Affinity Table\r
514///\r
13c31065 515#define EFI_ACPI_2_0_STATIC_RESOURCE_AFFINITY_TABLE_SIGNATURE SIGNATURE_32('S', 'R', 'A', 'T')\r
568eb0cb 516\r
1bc5d021 517///\r
518/// "SSDT" Secondary System Description Table\r
519///\r
13c31065 520#define EFI_ACPI_2_0_SECONDARY_SYSTEM_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('S', 'S', 'D', 'T')\r
568eb0cb 521\r
1bc5d021 522///\r
523/// "SPMI" Server Platform Management Interface Table\r
524///\r
13c31065 525#define EFI_ACPI_2_0_SERVER_PLATFORM_MANAGEMENT_INTERFACE_SIGNATURE SIGNATURE_32('S', 'P', 'M', 'I')\r
568eb0cb 526\r
1bc5d021 527///\r
528/// "XSDT" Extended System Description Table\r
529///\r
13c31065 530#define EFI_ACPI_2_0_EXTENDED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE SIGNATURE_32('X', 'S', 'D', 'T')\r
568eb0cb 531\r
1bc5d021 532///\r
4a18b92c 533/// "MCFG" PCI Express Memory Mapped Configuration Space Base Address Description Table\r
1bc5d021 534///\r
13c31065 535#define EFI_ACPI_2_0_MEMORY_MAPPED_CONFIGURATION_BASE_ADDRESS_TABLE_SIGNATURE SIGNATURE_32('M', 'C', 'F', 'G')\r
3431f363 536\r
766f4bc1 537#pragma pack()\r
538\r
568eb0cb 539#endif\r