1 /******************************************************************************
3 * Module Name: dttable.c - handling for specific ACPI tables
5 *****************************************************************************/
8 * Copyright (C) 2000 - 2013, 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.
46 /* Compile all complex data tables */
48 #include "aslcompiler.h"
49 #include "dtcompiler.h"
51 #define _COMPONENT DT_COMPILER
52 ACPI_MODULE_NAME ("dttable")
55 /* TBD: merge these into dmtbinfo.c? */
57 static ACPI_DMTABLE_INFO TableInfoAsfAddress[] =
59 {ACPI_DMT_BUFFER, 0, "Addresses", 0},
60 {ACPI_DMT_EXIT, 0, NULL, 0}
63 static ACPI_DMTABLE_INFO TableInfoDmarPciPath[] =
65 {ACPI_DMT_PCI_PATH, 0, "PCI Path", 0},
66 {ACPI_DMT_EXIT, 0, NULL, 0}
70 /* TBD: move to acmacros.h */
72 #define ACPI_SUB_PTR(t, a, b) \
73 ACPI_CAST_PTR (t, (ACPI_CAST_PTR (UINT8, (a)) - (ACPI_SIZE)(b)))
76 /* Local prototypes */
79 DtCompileTwoSubtables (
81 ACPI_DMTABLE_INFO *TableInfo1,
82 ACPI_DMTABLE_INFO *TableInfo2);
85 /******************************************************************************
87 * FUNCTION: DtCompileTwoSubtables
89 * PARAMETERS: List - Current field list pointer
90 * TableInfo1 - Info table 1
91 * TableInfo1 - Info table 2
95 * DESCRIPTION: Compile tables with a header and one or more same subtables.
96 * Include CPEP, EINJ, ERST, MCFG, MSCT, WDAT
98 *****************************************************************************/
101 DtCompileTwoSubtables (
103 ACPI_DMTABLE_INFO *TableInfo1,
104 ACPI_DMTABLE_INFO *TableInfo2)
107 DT_SUBTABLE *Subtable;
108 DT_SUBTABLE *ParentTable;
109 DT_FIELD **PFieldList = (DT_FIELD **) List;
112 Status = DtCompileTable (PFieldList, TableInfo1, &Subtable, TRUE);
113 if (ACPI_FAILURE (Status))
118 ParentTable = DtPeekSubtable ();
119 DtInsertSubtable (ParentTable, Subtable);
123 Status = DtCompileTable (PFieldList, TableInfo2, &Subtable, FALSE);
124 if (ACPI_FAILURE (Status))
129 DtInsertSubtable (ParentTable, Subtable);
136 /******************************************************************************
138 * FUNCTION: DtCompileFacs
140 * PARAMETERS: PFieldList - Current field list pointer
144 * DESCRIPTION: Compile FACS.
146 *****************************************************************************/
150 DT_FIELD **PFieldList)
152 DT_SUBTABLE *Subtable;
153 UINT8 *ReservedBuffer;
158 Status = DtCompileTable (PFieldList, AcpiDmTableInfoFacs,
159 &Gbl_RootTable, TRUE);
160 if (ACPI_FAILURE (Status))
165 /* Large FACS reserved area at the end of the table */
167 ReservedSize = (UINT32) sizeof (((ACPI_TABLE_FACS *) NULL)->Reserved1);
168 ReservedBuffer = UtLocalCalloc (ReservedSize);
170 DtCreateSubtable (ReservedBuffer, ReservedSize, &Subtable);
172 ACPI_FREE (ReservedBuffer);
173 DtInsertSubtable (Gbl_RootTable, Subtable);
178 /******************************************************************************
180 * FUNCTION: DtCompileRsdp
182 * PARAMETERS: PFieldList - Current field list pointer
186 * DESCRIPTION: Compile RSDP.
188 *****************************************************************************/
192 DT_FIELD **PFieldList)
194 DT_SUBTABLE *Subtable;
195 ACPI_TABLE_RSDP *Rsdp;
196 ACPI_RSDP_EXTENSION *RsdpExtension;
200 /* Compile the "common" RSDP (ACPI 1.0) */
202 Status = DtCompileTable (PFieldList, AcpiDmTableInfoRsdp1,
203 &Gbl_RootTable, TRUE);
204 if (ACPI_FAILURE (Status))
209 Rsdp = ACPI_CAST_PTR (ACPI_TABLE_RSDP, Gbl_RootTable->Buffer);
210 DtSetTableChecksum (&Rsdp->Checksum);
212 if (Rsdp->Revision > 0)
214 /* Compile the "extended" part of the RSDP as a subtable */
216 Status = DtCompileTable (PFieldList, AcpiDmTableInfoRsdp2,
218 if (ACPI_FAILURE (Status))
223 DtInsertSubtable (Gbl_RootTable, Subtable);
225 /* Set length and extended checksum for entire RSDP */
227 RsdpExtension = ACPI_CAST_PTR (ACPI_RSDP_EXTENSION, Subtable->Buffer);
228 RsdpExtension->Length = Gbl_RootTable->Length + Subtable->Length;
229 DtSetTableChecksum (&RsdpExtension->ExtendedChecksum);
236 /******************************************************************************
238 * FUNCTION: DtCompileAsf
240 * PARAMETERS: List - Current field list pointer
244 * DESCRIPTION: Compile ASF!.
246 *****************************************************************************/
252 ACPI_ASF_INFO *AsfTable;
253 DT_SUBTABLE *Subtable;
254 DT_SUBTABLE *ParentTable;
255 ACPI_DMTABLE_INFO *InfoTable;
256 ACPI_DMTABLE_INFO *DataInfoTable = NULL;
257 UINT32 DataCount = 0;
260 DT_FIELD **PFieldList = (DT_FIELD **) List;
261 DT_FIELD *SubtableStart;
266 SubtableStart = *PFieldList;
267 Status = DtCompileTable (PFieldList, AcpiDmTableInfoAsfHdr,
269 if (ACPI_FAILURE (Status))
274 ParentTable = DtPeekSubtable ();
275 DtInsertSubtable (ParentTable, Subtable);
276 DtPushSubtable (Subtable);
278 AsfTable = ACPI_CAST_PTR (ACPI_ASF_INFO, Subtable->Buffer);
280 switch (AsfTable->Header.Type & 0x7F) /* Mask off top bit */
282 case ACPI_ASF_TYPE_INFO:
284 InfoTable = AcpiDmTableInfoAsf0;
287 case ACPI_ASF_TYPE_ALERT:
289 InfoTable = AcpiDmTableInfoAsf1;
292 case ACPI_ASF_TYPE_CONTROL:
294 InfoTable = AcpiDmTableInfoAsf2;
297 case ACPI_ASF_TYPE_BOOT:
299 InfoTable = AcpiDmTableInfoAsf3;
302 case ACPI_ASF_TYPE_ADDRESS:
304 InfoTable = AcpiDmTableInfoAsf4;
309 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "ASF!");
313 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
314 if (ACPI_FAILURE (Status))
319 ParentTable = DtPeekSubtable ();
320 DtInsertSubtable (ParentTable, Subtable);
322 switch (AsfTable->Header.Type & 0x7F) /* Mask off top bit */
324 case ACPI_ASF_TYPE_INFO:
326 DataInfoTable = NULL;
329 case ACPI_ASF_TYPE_ALERT:
331 DataInfoTable = AcpiDmTableInfoAsf1a;
332 DataCount = ACPI_CAST_PTR (ACPI_ASF_ALERT,
333 ACPI_SUB_PTR (UINT8, Subtable->Buffer,
334 sizeof (ACPI_ASF_HEADER)))->Alerts;
337 case ACPI_ASF_TYPE_CONTROL:
339 DataInfoTable = AcpiDmTableInfoAsf2a;
340 DataCount = ACPI_CAST_PTR (ACPI_ASF_REMOTE,
341 ACPI_SUB_PTR (UINT8, Subtable->Buffer,
342 sizeof (ACPI_ASF_HEADER)))->Controls;
345 case ACPI_ASF_TYPE_BOOT:
347 DataInfoTable = NULL;
350 case ACPI_ASF_TYPE_ADDRESS:
352 DataInfoTable = TableInfoAsfAddress;
353 DataCount = ACPI_CAST_PTR (ACPI_ASF_ADDRESS,
354 ACPI_SUB_PTR (UINT8, Subtable->Buffer,
355 sizeof (ACPI_ASF_HEADER)))->Devices;
360 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "ASF!");
366 switch (AsfTable->Header.Type & 0x7F)
368 case ACPI_ASF_TYPE_ADDRESS:
370 while (DataCount > 0)
372 Status = DtCompileTable (PFieldList, DataInfoTable,
374 if (ACPI_FAILURE (Status))
379 DtInsertSubtable (ParentTable, Subtable);
380 DataCount = DataCount - Subtable->Length;
386 for (i = 0; i < DataCount; i++)
388 Status = DtCompileTable (PFieldList, DataInfoTable,
390 if (ACPI_FAILURE (Status))
395 DtInsertSubtable (ParentTable, Subtable);
408 /******************************************************************************
410 * FUNCTION: DtCompileCpep
412 * PARAMETERS: List - Current field list pointer
416 * DESCRIPTION: Compile CPEP.
418 *****************************************************************************/
427 Status = DtCompileTwoSubtables (List,
428 AcpiDmTableInfoCpep, AcpiDmTableInfoCpep0);
433 /******************************************************************************
435 * FUNCTION: DtCompileCsrt
437 * PARAMETERS: List - Current field list pointer
441 * DESCRIPTION: Compile CSRT.
443 *****************************************************************************/
449 ACPI_STATUS Status = AE_OK;
450 DT_SUBTABLE *Subtable;
451 DT_SUBTABLE *ParentTable;
452 DT_FIELD **PFieldList = (DT_FIELD **) List;
453 UINT32 DescriptorCount;
457 /* Sub-tables (Resource Groups) */
461 /* Resource group subtable */
463 Status = DtCompileTable (PFieldList, AcpiDmTableInfoCsrt0,
465 if (ACPI_FAILURE (Status))
470 /* Compute the number of resource descriptors */
473 (ACPI_CAST_PTR (ACPI_CSRT_GROUP,
474 Subtable->Buffer))->Length -
475 (ACPI_CAST_PTR (ACPI_CSRT_GROUP,
476 Subtable->Buffer))->SharedInfoLength -
477 sizeof (ACPI_CSRT_GROUP);
479 DescriptorCount = (GroupLength /
480 sizeof (ACPI_CSRT_DESCRIPTOR));
482 ParentTable = DtPeekSubtable ();
483 DtInsertSubtable (ParentTable, Subtable);
484 DtPushSubtable (Subtable);
486 /* Shared info subtable (One per resource group) */
488 Status = DtCompileTable (PFieldList, AcpiDmTableInfoCsrt1,
490 if (ACPI_FAILURE (Status))
495 ParentTable = DtPeekSubtable ();
496 DtInsertSubtable (ParentTable, Subtable);
498 /* Sub-Subtables (Resource Descriptors) */
500 while (*PFieldList && DescriptorCount)
502 Status = DtCompileTable (PFieldList, AcpiDmTableInfoCsrt2,
504 if (ACPI_FAILURE (Status))
509 ParentTable = DtPeekSubtable ();
510 DtInsertSubtable (ParentTable, Subtable);
521 /******************************************************************************
523 * FUNCTION: DtCompileDbg2
525 * PARAMETERS: List - Current field list pointer
529 * DESCRIPTION: Compile DBG2.
531 *****************************************************************************/
538 DT_SUBTABLE *Subtable;
539 DT_SUBTABLE *ParentTable;
540 DT_FIELD **PFieldList = (DT_FIELD **) List;
541 UINT32 SubtableCount;
542 ACPI_DBG2_HEADER *Dbg2Header;
543 ACPI_DBG2_DEVICE *DeviceInfo;
544 UINT16 CurrentOffset;
550 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2, &Subtable, TRUE);
551 if (ACPI_FAILURE (Status))
556 ParentTable = DtPeekSubtable ();
557 DtInsertSubtable (ParentTable, Subtable);
559 /* Main table fields */
561 Dbg2Header = ACPI_CAST_PTR (ACPI_DBG2_HEADER, Subtable->Buffer);
562 Dbg2Header->InfoOffset = sizeof (ACPI_TABLE_HEADER) + ACPI_PTR_DIFF (
563 ACPI_ADD_PTR (UINT8, Dbg2Header, sizeof (ACPI_DBG2_HEADER)), Dbg2Header);
565 SubtableCount = Dbg2Header->InfoCount;
566 DtPushSubtable (Subtable);
568 /* Process all Device Information subtables (Count = InfoCount) */
570 while (*PFieldList && SubtableCount)
572 /* Subtable: Debug Device Information */
574 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Device,
576 if (ACPI_FAILURE (Status))
581 DeviceInfo = ACPI_CAST_PTR (ACPI_DBG2_DEVICE, Subtable->Buffer);
582 CurrentOffset = (UINT16) sizeof (ACPI_DBG2_DEVICE);
584 ParentTable = DtPeekSubtable ();
585 DtInsertSubtable (ParentTable, Subtable);
586 DtPushSubtable (Subtable);
588 ParentTable = DtPeekSubtable ();
590 /* BaseAddressRegister GAS array (Required, size is RegisterCount) */
592 DeviceInfo->BaseAddressOffset = CurrentOffset;
593 for (i = 0; *PFieldList && (i < DeviceInfo->RegisterCount); i++)
595 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Addr,
597 if (ACPI_FAILURE (Status))
602 CurrentOffset += (UINT16) sizeof (ACPI_GENERIC_ADDRESS);
603 DtInsertSubtable (ParentTable, Subtable);
606 /* AddressSize array (Required, size = RegisterCount) */
608 DeviceInfo->AddressSizeOffset = CurrentOffset;
609 for (i = 0; *PFieldList && (i < DeviceInfo->RegisterCount); i++)
611 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Size,
613 if (ACPI_FAILURE (Status))
618 CurrentOffset += (UINT16) sizeof (UINT32);
619 DtInsertSubtable (ParentTable, Subtable);
622 /* NamespaceString device identifier (Required, size = NamePathLength) */
624 DeviceInfo->NamepathOffset = CurrentOffset;
625 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Name,
627 if (ACPI_FAILURE (Status))
632 /* Update the device info header */
634 DeviceInfo->NamepathLength = (UINT16) Subtable->Length;
635 CurrentOffset += (UINT16) DeviceInfo->NamepathLength;
636 DtInsertSubtable (ParentTable, Subtable);
638 /* OemData - Variable-length data (Optional, size = OemDataLength) */
640 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2OemData,
642 if (ACPI_FAILURE (Status))
647 /* Update the device info header (zeros if no OEM data present) */
649 DeviceInfo->OemDataOffset = 0;
650 DeviceInfo->OemDataLength = 0;
652 /* Optional subtable (OemData) */
654 if (Subtable && Subtable->Length)
656 DeviceInfo->OemDataOffset = CurrentOffset;
657 DeviceInfo->OemDataLength = (UINT16) Subtable->Length;
659 DtInsertSubtable (ParentTable, Subtable);
663 DtPopSubtable (); /* Get next Device Information subtable */
671 /******************************************************************************
673 * FUNCTION: DtCompileDmar
675 * PARAMETERS: List - Current field list pointer
679 * DESCRIPTION: Compile DMAR.
681 *****************************************************************************/
688 DT_SUBTABLE *Subtable;
689 DT_SUBTABLE *ParentTable;
690 DT_FIELD **PFieldList = (DT_FIELD **) List;
691 DT_FIELD *SubtableStart;
692 ACPI_DMTABLE_INFO *InfoTable;
693 ACPI_DMAR_HEADER *DmarHeader;
694 ACPI_DMAR_DEVICE_SCOPE *DmarDeviceScope;
695 UINT32 DeviceScopeLength;
696 UINT32 PciPathLength;
699 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDmar, &Subtable, TRUE);
700 if (ACPI_FAILURE (Status))
705 ParentTable = DtPeekSubtable ();
706 DtInsertSubtable (ParentTable, Subtable);
707 DtPushSubtable (Subtable);
713 SubtableStart = *PFieldList;
714 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDmarHdr,
716 if (ACPI_FAILURE (Status))
721 ParentTable = DtPeekSubtable ();
722 DtInsertSubtable (ParentTable, Subtable);
723 DtPushSubtable (Subtable);
725 DmarHeader = ACPI_CAST_PTR (ACPI_DMAR_HEADER, Subtable->Buffer);
727 switch (DmarHeader->Type)
729 case ACPI_DMAR_TYPE_HARDWARE_UNIT:
731 InfoTable = AcpiDmTableInfoDmar0;
734 case ACPI_DMAR_TYPE_RESERVED_MEMORY:
736 InfoTable = AcpiDmTableInfoDmar1;
739 case ACPI_DMAR_TYPE_ATSR:
741 InfoTable = AcpiDmTableInfoDmar2;
744 case ACPI_DMAR_HARDWARE_AFFINITY:
746 InfoTable = AcpiDmTableInfoDmar3;
751 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "DMAR");
757 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
758 if (ACPI_FAILURE (Status))
763 ParentTable = DtPeekSubtable ();
764 DtInsertSubtable (ParentTable, Subtable);
765 DtPushSubtable (Subtable);
767 /* Optional Device Scope subtables */
769 DeviceScopeLength = DmarHeader->Length - Subtable->Length -
771 while (DeviceScopeLength)
773 Status = DtCompileTable (PFieldList, AcpiDmTableInfoDmarScope,
775 if (Status == AE_NOT_FOUND)
780 ParentTable = DtPeekSubtable ();
781 DtInsertSubtable (ParentTable, Subtable);
782 DtPushSubtable (Subtable);
784 DmarDeviceScope = ACPI_CAST_PTR (ACPI_DMAR_DEVICE_SCOPE, Subtable->Buffer);
786 /* Optional PCI Paths */
788 PciPathLength = DmarDeviceScope->Length - Subtable->Length;
789 while (PciPathLength)
791 Status = DtCompileTable (PFieldList, TableInfoDmarPciPath,
793 if (Status == AE_NOT_FOUND)
799 ParentTable = DtPeekSubtable ();
800 DtInsertSubtable (ParentTable, Subtable);
801 PciPathLength -= Subtable->Length;
805 DeviceScopeLength -= DmarDeviceScope->Length;
816 /******************************************************************************
818 * FUNCTION: DtCompileEinj
820 * PARAMETERS: List - Current field list pointer
824 * DESCRIPTION: Compile EINJ.
826 *****************************************************************************/
835 Status = DtCompileTwoSubtables (List,
836 AcpiDmTableInfoEinj, AcpiDmTableInfoEinj0);
841 /******************************************************************************
843 * FUNCTION: DtCompileErst
845 * PARAMETERS: List - Current field list pointer
849 * DESCRIPTION: Compile ERST.
851 *****************************************************************************/
860 Status = DtCompileTwoSubtables (List,
861 AcpiDmTableInfoErst, AcpiDmTableInfoEinj0);
866 /******************************************************************************
868 * FUNCTION: DtCompileFadt
870 * PARAMETERS: List - Current field list pointer
874 * DESCRIPTION: Compile FADT.
876 *****************************************************************************/
883 DT_SUBTABLE *Subtable;
884 DT_SUBTABLE *ParentTable;
885 DT_FIELD **PFieldList = (DT_FIELD **) List;
886 ACPI_TABLE_HEADER *Table;
890 Status = DtCompileTable (PFieldList, AcpiDmTableInfoFadt1,
892 if (ACPI_FAILURE (Status))
897 ParentTable = DtPeekSubtable ();
898 DtInsertSubtable (ParentTable, Subtable);
900 Table = ACPI_CAST_PTR (ACPI_TABLE_HEADER, ParentTable->Buffer);
901 Revision = Table->Revision;
905 Status = DtCompileTable (PFieldList, AcpiDmTableInfoFadt2,
907 if (ACPI_FAILURE (Status))
912 DtInsertSubtable (ParentTable, Subtable);
914 else if (Revision >= 2)
916 Status = DtCompileTable (PFieldList, AcpiDmTableInfoFadt3,
918 if (ACPI_FAILURE (Status))
923 DtInsertSubtable (ParentTable, Subtable);
927 Status = DtCompileTable (PFieldList, AcpiDmTableInfoFadt5,
929 if (ACPI_FAILURE (Status))
934 DtInsertSubtable (ParentTable, Subtable);
942 /******************************************************************************
944 * FUNCTION: DtCompileFpdt
946 * PARAMETERS: List - Current field list pointer
950 * DESCRIPTION: Compile FPDT.
952 *****************************************************************************/
959 ACPI_FPDT_HEADER *FpdtHeader;
960 DT_SUBTABLE *Subtable;
961 DT_SUBTABLE *ParentTable;
962 ACPI_DMTABLE_INFO *InfoTable;
963 DT_FIELD **PFieldList = (DT_FIELD **) List;
964 DT_FIELD *SubtableStart;
969 SubtableStart = *PFieldList;
970 Status = DtCompileTable (PFieldList, AcpiDmTableInfoFpdtHdr,
972 if (ACPI_FAILURE (Status))
977 ParentTable = DtPeekSubtable ();
978 DtInsertSubtable (ParentTable, Subtable);
979 DtPushSubtable (Subtable);
981 FpdtHeader = ACPI_CAST_PTR (ACPI_FPDT_HEADER, Subtable->Buffer);
983 switch (FpdtHeader->Type)
985 case ACPI_FPDT_TYPE_BOOT:
987 InfoTable = AcpiDmTableInfoFpdt0;
990 case ACPI_FPDT_TYPE_S3PERF:
992 InfoTable = AcpiDmTableInfoFpdt1;
997 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "FPDT");
1002 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
1003 if (ACPI_FAILURE (Status))
1008 ParentTable = DtPeekSubtable ();
1009 DtInsertSubtable (ParentTable, Subtable);
1017 /******************************************************************************
1019 * FUNCTION: DtCompileHest
1021 * PARAMETERS: List - Current field list pointer
1025 * DESCRIPTION: Compile HEST.
1027 *****************************************************************************/
1034 DT_SUBTABLE *Subtable;
1035 DT_SUBTABLE *ParentTable;
1036 DT_FIELD **PFieldList = (DT_FIELD **) List;
1037 DT_FIELD *SubtableStart;
1038 ACPI_DMTABLE_INFO *InfoTable;
1043 Status = DtCompileTable (PFieldList, AcpiDmTableInfoHest,
1045 if (ACPI_FAILURE (Status))
1050 ParentTable = DtPeekSubtable ();
1051 DtInsertSubtable (ParentTable, Subtable);
1055 /* Get subtable type */
1057 SubtableStart = *PFieldList;
1058 DtCompileInteger ((UINT8 *) &Type, *PFieldList, 2, 0);
1062 case ACPI_HEST_TYPE_IA32_CHECK:
1064 InfoTable = AcpiDmTableInfoHest0;
1067 case ACPI_HEST_TYPE_IA32_CORRECTED_CHECK:
1069 InfoTable = AcpiDmTableInfoHest1;
1072 case ACPI_HEST_TYPE_IA32_NMI:
1074 InfoTable = AcpiDmTableInfoHest2;
1077 case ACPI_HEST_TYPE_AER_ROOT_PORT:
1079 InfoTable = AcpiDmTableInfoHest6;
1082 case ACPI_HEST_TYPE_AER_ENDPOINT:
1084 InfoTable = AcpiDmTableInfoHest7;
1087 case ACPI_HEST_TYPE_AER_BRIDGE:
1089 InfoTable = AcpiDmTableInfoHest8;
1092 case ACPI_HEST_TYPE_GENERIC_ERROR:
1094 InfoTable = AcpiDmTableInfoHest9;
1099 /* Cannot continue on unknown type */
1101 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "HEST");
1105 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
1106 if (ACPI_FAILURE (Status))
1111 DtInsertSubtable (ParentTable, Subtable);
1114 * Additional subtable data - IA32 Error Bank(s)
1119 case ACPI_HEST_TYPE_IA32_CHECK:
1121 BankCount = (ACPI_CAST_PTR (ACPI_HEST_IA_MACHINE_CHECK,
1122 Subtable->Buffer))->NumHardwareBanks;
1125 case ACPI_HEST_TYPE_IA32_CORRECTED_CHECK:
1127 BankCount = (ACPI_CAST_PTR (ACPI_HEST_IA_CORRECTED,
1128 Subtable->Buffer))->NumHardwareBanks;
1138 Status = DtCompileTable (PFieldList, AcpiDmTableInfoHestBank,
1140 if (ACPI_FAILURE (Status))
1145 DtInsertSubtable (ParentTable, Subtable);
1154 /******************************************************************************
1156 * FUNCTION: DtCompileIvrs
1158 * PARAMETERS: List - Current field list pointer
1162 * DESCRIPTION: Compile IVRS.
1164 *****************************************************************************/
1171 DT_SUBTABLE *Subtable;
1172 DT_SUBTABLE *ParentTable;
1173 DT_FIELD **PFieldList = (DT_FIELD **) List;
1174 DT_FIELD *SubtableStart;
1175 ACPI_DMTABLE_INFO *InfoTable;
1176 ACPI_IVRS_HEADER *IvrsHeader;
1180 Status = DtCompileTable (PFieldList, AcpiDmTableInfoIvrs,
1182 if (ACPI_FAILURE (Status))
1187 ParentTable = DtPeekSubtable ();
1188 DtInsertSubtable (ParentTable, Subtable);
1192 SubtableStart = *PFieldList;
1193 Status = DtCompileTable (PFieldList, AcpiDmTableInfoIvrsHdr,
1195 if (ACPI_FAILURE (Status))
1200 ParentTable = DtPeekSubtable ();
1201 DtInsertSubtable (ParentTable, Subtable);
1202 DtPushSubtable (Subtable);
1204 IvrsHeader = ACPI_CAST_PTR (ACPI_IVRS_HEADER, Subtable->Buffer);
1206 switch (IvrsHeader->Type)
1208 case ACPI_IVRS_TYPE_HARDWARE:
1210 InfoTable = AcpiDmTableInfoIvrs0;
1213 case ACPI_IVRS_TYPE_MEMORY1:
1214 case ACPI_IVRS_TYPE_MEMORY2:
1215 case ACPI_IVRS_TYPE_MEMORY3:
1217 InfoTable = AcpiDmTableInfoIvrs1;
1222 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "IVRS");
1226 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
1227 if (ACPI_FAILURE (Status))
1232 ParentTable = DtPeekSubtable ();
1233 DtInsertSubtable (ParentTable, Subtable);
1235 if (IvrsHeader->Type == ACPI_IVRS_TYPE_HARDWARE)
1237 while (*PFieldList &&
1238 !ACPI_STRCMP ((*PFieldList)->Name, "Entry Type"))
1240 SubtableStart = *PFieldList;
1241 DtCompileInteger (&EntryType, *PFieldList, 1, 0);
1245 /* 4-byte device entries */
1247 case ACPI_IVRS_TYPE_PAD4:
1248 case ACPI_IVRS_TYPE_ALL:
1249 case ACPI_IVRS_TYPE_SELECT:
1250 case ACPI_IVRS_TYPE_START:
1251 case ACPI_IVRS_TYPE_END:
1253 InfoTable = AcpiDmTableInfoIvrs4;
1256 /* 8-byte entries, type A */
1258 case ACPI_IVRS_TYPE_ALIAS_SELECT:
1259 case ACPI_IVRS_TYPE_ALIAS_START:
1261 InfoTable = AcpiDmTableInfoIvrs8a;
1264 /* 8-byte entries, type B */
1266 case ACPI_IVRS_TYPE_PAD8:
1267 case ACPI_IVRS_TYPE_EXT_SELECT:
1268 case ACPI_IVRS_TYPE_EXT_START:
1270 InfoTable = AcpiDmTableInfoIvrs8b;
1273 /* 8-byte entries, type C */
1275 case ACPI_IVRS_TYPE_SPECIAL:
1277 InfoTable = AcpiDmTableInfoIvrs8c;
1282 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart,
1283 "IVRS Device Entry");
1287 Status = DtCompileTable (PFieldList, InfoTable,
1289 if (ACPI_FAILURE (Status))
1294 DtInsertSubtable (ParentTable, Subtable);
1305 /******************************************************************************
1307 * FUNCTION: DtCompileMadt
1309 * PARAMETERS: List - Current field list pointer
1313 * DESCRIPTION: Compile MADT.
1315 *****************************************************************************/
1322 DT_SUBTABLE *Subtable;
1323 DT_SUBTABLE *ParentTable;
1324 DT_FIELD **PFieldList = (DT_FIELD **) List;
1325 DT_FIELD *SubtableStart;
1326 ACPI_SUBTABLE_HEADER *MadtHeader;
1327 ACPI_DMTABLE_INFO *InfoTable;
1330 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMadt,
1332 if (ACPI_FAILURE (Status))
1337 ParentTable = DtPeekSubtable ();
1338 DtInsertSubtable (ParentTable, Subtable);
1342 SubtableStart = *PFieldList;
1343 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMadtHdr,
1345 if (ACPI_FAILURE (Status))
1350 ParentTable = DtPeekSubtable ();
1351 DtInsertSubtable (ParentTable, Subtable);
1352 DtPushSubtable (Subtable);
1354 MadtHeader = ACPI_CAST_PTR (ACPI_SUBTABLE_HEADER, Subtable->Buffer);
1356 switch (MadtHeader->Type)
1358 case ACPI_MADT_TYPE_LOCAL_APIC:
1360 InfoTable = AcpiDmTableInfoMadt0;
1363 case ACPI_MADT_TYPE_IO_APIC:
1365 InfoTable = AcpiDmTableInfoMadt1;
1368 case ACPI_MADT_TYPE_INTERRUPT_OVERRIDE:
1370 InfoTable = AcpiDmTableInfoMadt2;
1373 case ACPI_MADT_TYPE_NMI_SOURCE:
1375 InfoTable = AcpiDmTableInfoMadt3;
1378 case ACPI_MADT_TYPE_LOCAL_APIC_NMI:
1380 InfoTable = AcpiDmTableInfoMadt4;
1383 case ACPI_MADT_TYPE_LOCAL_APIC_OVERRIDE:
1385 InfoTable = AcpiDmTableInfoMadt5;
1388 case ACPI_MADT_TYPE_IO_SAPIC:
1390 InfoTable = AcpiDmTableInfoMadt6;
1393 case ACPI_MADT_TYPE_LOCAL_SAPIC:
1395 InfoTable = AcpiDmTableInfoMadt7;
1398 case ACPI_MADT_TYPE_INTERRUPT_SOURCE:
1400 InfoTable = AcpiDmTableInfoMadt8;
1403 case ACPI_MADT_TYPE_LOCAL_X2APIC:
1405 InfoTable = AcpiDmTableInfoMadt9;
1408 case ACPI_MADT_TYPE_LOCAL_X2APIC_NMI:
1410 InfoTable = AcpiDmTableInfoMadt10;
1413 case ACPI_MADT_TYPE_GENERIC_INTERRUPT:
1415 InfoTable = AcpiDmTableInfoMadt11;
1418 case ACPI_MADT_TYPE_GENERIC_DISTRIBUTOR:
1420 InfoTable = AcpiDmTableInfoMadt12;
1425 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "MADT");
1429 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
1430 if (ACPI_FAILURE (Status))
1435 ParentTable = DtPeekSubtable ();
1436 DtInsertSubtable (ParentTable, Subtable);
1444 /******************************************************************************
1446 * FUNCTION: DtCompileMcfg
1448 * PARAMETERS: List - Current field list pointer
1452 * DESCRIPTION: Compile MCFG.
1454 *****************************************************************************/
1463 Status = DtCompileTwoSubtables (List,
1464 AcpiDmTableInfoMcfg, AcpiDmTableInfoMcfg0);
1469 /******************************************************************************
1471 * FUNCTION: DtCompileMpst
1473 * PARAMETERS: List - Current field list pointer
1477 * DESCRIPTION: Compile MPST.
1479 *****************************************************************************/
1486 DT_SUBTABLE *Subtable;
1487 DT_SUBTABLE *ParentTable;
1488 DT_FIELD **PFieldList = (DT_FIELD **) List;
1489 ACPI_MPST_CHANNEL *MpstChannelInfo;
1490 ACPI_MPST_POWER_NODE *MpstPowerNode;
1491 ACPI_MPST_DATA_HDR *MpstDataHeader;
1492 UINT16 SubtableCount;
1493 UINT32 PowerStateCount;
1494 UINT32 ComponentCount;
1499 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMpst, &Subtable, TRUE);
1500 if (ACPI_FAILURE (Status))
1505 ParentTable = DtPeekSubtable ();
1506 DtInsertSubtable (ParentTable, Subtable);
1507 DtPushSubtable (Subtable);
1509 MpstChannelInfo = ACPI_CAST_PTR (ACPI_MPST_CHANNEL, Subtable->Buffer);
1510 SubtableCount = MpstChannelInfo->PowerNodeCount;
1512 while (*PFieldList && SubtableCount)
1514 /* Subtable: Memory Power Node(s) */
1516 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMpst0,
1518 if (ACPI_FAILURE (Status))
1523 ParentTable = DtPeekSubtable ();
1524 DtInsertSubtable (ParentTable, Subtable);
1525 DtPushSubtable (Subtable);
1527 MpstPowerNode = ACPI_CAST_PTR (ACPI_MPST_POWER_NODE, Subtable->Buffer);
1528 PowerStateCount = MpstPowerNode->NumPowerStates;
1529 ComponentCount = MpstPowerNode->NumPhysicalComponents;
1531 ParentTable = DtPeekSubtable ();
1533 /* Sub-subtables - Memory Power State Structure(s) */
1535 while (*PFieldList && PowerStateCount)
1537 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMpst0A,
1539 if (ACPI_FAILURE (Status))
1544 DtInsertSubtable (ParentTable, Subtable);
1548 /* Sub-subtables - Physical Component ID Structure(s) */
1550 while (*PFieldList && ComponentCount)
1552 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMpst0B,
1554 if (ACPI_FAILURE (Status))
1559 DtInsertSubtable (ParentTable, Subtable);
1567 /* Subtable: Count of Memory Power State Characteristic structures */
1571 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMpst1, &Subtable, TRUE);
1572 if (ACPI_FAILURE (Status))
1577 ParentTable = DtPeekSubtable ();
1578 DtInsertSubtable (ParentTable, Subtable);
1579 DtPushSubtable (Subtable);
1581 MpstDataHeader = ACPI_CAST_PTR (ACPI_MPST_DATA_HDR, Subtable->Buffer);
1582 SubtableCount = MpstDataHeader->CharacteristicsCount;
1584 ParentTable = DtPeekSubtable ();
1586 /* Subtable: Memory Power State Characteristics structure(s) */
1588 while (*PFieldList && SubtableCount)
1590 Status = DtCompileTable (PFieldList, AcpiDmTableInfoMpst2,
1592 if (ACPI_FAILURE (Status))
1597 DtInsertSubtable (ParentTable, Subtable);
1606 /******************************************************************************
1608 * FUNCTION: DtCompileMsct
1610 * PARAMETERS: List - Current field list pointer
1614 * DESCRIPTION: Compile MSCT.
1616 *****************************************************************************/
1625 Status = DtCompileTwoSubtables (List,
1626 AcpiDmTableInfoMsct, AcpiDmTableInfoMsct0);
1631 /******************************************************************************
1633 * FUNCTION: DtCompileMtmr
1635 * PARAMETERS: List - Current field list pointer
1639 * DESCRIPTION: Compile MTMR.
1641 *****************************************************************************/
1650 Status = DtCompileTwoSubtables (List,
1651 AcpiDmTableInfoMtmr, AcpiDmTableInfoMtmr0);
1656 /******************************************************************************
1658 * FUNCTION: DtCompilePcct
1660 * PARAMETERS: List - Current field list pointer
1664 * DESCRIPTION: Compile PCCT.
1666 *****************************************************************************/
1673 DT_SUBTABLE *Subtable;
1674 DT_SUBTABLE *ParentTable;
1675 DT_FIELD **PFieldList = (DT_FIELD **) List;
1676 DT_FIELD *SubtableStart;
1677 ACPI_SUBTABLE_HEADER *PcctHeader;
1678 ACPI_DMTABLE_INFO *InfoTable;
1681 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPcct,
1683 if (ACPI_FAILURE (Status))
1688 ParentTable = DtPeekSubtable ();
1689 DtInsertSubtable (ParentTable, Subtable);
1693 SubtableStart = *PFieldList;
1694 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPcctHdr,
1696 if (ACPI_FAILURE (Status))
1701 ParentTable = DtPeekSubtable ();
1702 DtInsertSubtable (ParentTable, Subtable);
1703 DtPushSubtable (Subtable);
1705 PcctHeader = ACPI_CAST_PTR (ACPI_SUBTABLE_HEADER, Subtable->Buffer);
1707 switch (PcctHeader->Type)
1709 case ACPI_PCCT_TYPE_GENERIC_SUBSPACE:
1711 InfoTable = AcpiDmTableInfoPcct0;
1716 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "PCCT");
1720 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
1721 if (ACPI_FAILURE (Status))
1726 ParentTable = DtPeekSubtable ();
1727 DtInsertSubtable (ParentTable, Subtable);
1735 /******************************************************************************
1737 * FUNCTION: DtCompilePmtt
1739 * PARAMETERS: List - Current field list pointer
1743 * DESCRIPTION: Compile PMTT.
1745 *****************************************************************************/
1752 DT_SUBTABLE *Subtable;
1753 DT_SUBTABLE *ParentTable;
1754 DT_FIELD **PFieldList = (DT_FIELD **) List;
1755 DT_FIELD *SubtableStart;
1756 ACPI_PMTT_HEADER *PmttHeader;
1757 ACPI_PMTT_CONTROLLER *PmttController;
1759 UINT8 PrevType = ACPI_PMTT_TYPE_SOCKET;
1764 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPmtt, &Subtable, TRUE);
1765 if (ACPI_FAILURE (Status))
1770 ParentTable = DtPeekSubtable ();
1771 DtInsertSubtable (ParentTable, Subtable);
1772 DtPushSubtable (Subtable);
1776 SubtableStart = *PFieldList;
1777 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPmttHdr,
1779 if (ACPI_FAILURE (Status))
1784 PmttHeader = ACPI_CAST_PTR (ACPI_PMTT_HEADER, Subtable->Buffer);
1785 while (PrevType >= PmttHeader->Type)
1789 if (PrevType == ACPI_PMTT_TYPE_SOCKET)
1795 PrevType = PmttHeader->Type;
1797 ParentTable = DtPeekSubtable ();
1798 DtInsertSubtable (ParentTable, Subtable);
1799 DtPushSubtable (Subtable);
1801 switch (PmttHeader->Type)
1803 case ACPI_PMTT_TYPE_SOCKET:
1805 /* Subtable: Socket Structure */
1807 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPmtt0,
1809 if (ACPI_FAILURE (Status))
1814 ParentTable = DtPeekSubtable ();
1815 DtInsertSubtable (ParentTable, Subtable);
1818 case ACPI_PMTT_TYPE_CONTROLLER:
1820 /* Subtable: Memory Controller Structure */
1822 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPmtt1,
1824 if (ACPI_FAILURE (Status))
1829 ParentTable = DtPeekSubtable ();
1830 DtInsertSubtable (ParentTable, Subtable);
1832 PmttController = ACPI_CAST_PTR (ACPI_PMTT_CONTROLLER,
1833 (Subtable->Buffer - sizeof (ACPI_PMTT_HEADER)));
1834 DomainCount = PmttController->DomainCount;
1838 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPmtt1a,
1840 if (ACPI_FAILURE (Status))
1845 DtInsertSubtable (ParentTable, Subtable);
1850 case ACPI_PMTT_TYPE_DIMM:
1852 /* Subtable: Physical Component Structure */
1854 Status = DtCompileTable (PFieldList, AcpiDmTableInfoPmtt2,
1856 if (ACPI_FAILURE (Status))
1861 ParentTable = DtPeekSubtable ();
1862 DtInsertSubtable (ParentTable, Subtable);
1867 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "PMTT");
1876 /******************************************************************************
1878 * FUNCTION: DtCompileRsdt
1880 * PARAMETERS: List - Current field list pointer
1884 * DESCRIPTION: Compile RSDT.
1886 *****************************************************************************/
1892 DT_SUBTABLE *Subtable;
1893 DT_SUBTABLE *ParentTable;
1894 DT_FIELD *FieldList = *(DT_FIELD **) List;
1898 ParentTable = DtPeekSubtable ();
1902 DtCompileInteger ((UINT8 *) &Address, FieldList, 4, DT_NON_ZERO);
1904 DtCreateSubtable ((UINT8 *) &Address, 4, &Subtable);
1905 DtInsertSubtable (ParentTable, Subtable);
1906 FieldList = FieldList->Next;
1913 /******************************************************************************
1915 * FUNCTION: DtCompileS3pt
1917 * PARAMETERS: PFieldList - Current field list pointer
1921 * DESCRIPTION: Compile S3PT (Pointed to by FPDT)
1923 *****************************************************************************/
1927 DT_FIELD **PFieldList)
1930 ACPI_S3PT_HEADER *S3ptHeader;
1931 DT_SUBTABLE *Subtable;
1932 DT_SUBTABLE *ParentTable;
1933 ACPI_DMTABLE_INFO *InfoTable;
1934 DT_FIELD *SubtableStart;
1937 Status = DtCompileTable (PFieldList, AcpiDmTableInfoS3pt,
1938 &Gbl_RootTable, TRUE);
1939 if (ACPI_FAILURE (Status))
1944 DtPushSubtable (Gbl_RootTable);
1948 SubtableStart = *PFieldList;
1949 Status = DtCompileTable (PFieldList, AcpiDmTableInfoS3ptHdr,
1951 if (ACPI_FAILURE (Status))
1956 ParentTable = DtPeekSubtable ();
1957 DtInsertSubtable (ParentTable, Subtable);
1958 DtPushSubtable (Subtable);
1960 S3ptHeader = ACPI_CAST_PTR (ACPI_S3PT_HEADER, Subtable->Buffer);
1962 switch (S3ptHeader->Type)
1964 case ACPI_S3PT_TYPE_RESUME:
1966 InfoTable = AcpiDmTableInfoS3pt0;
1969 case ACPI_S3PT_TYPE_SUSPEND:
1971 InfoTable = AcpiDmTableInfoS3pt1;
1976 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "S3PT");
1980 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
1981 if (ACPI_FAILURE (Status))
1986 ParentTable = DtPeekSubtable ();
1987 DtInsertSubtable (ParentTable, Subtable);
1995 /******************************************************************************
1997 * FUNCTION: DtCompileSlic
1999 * PARAMETERS: List - Current field list pointer
2003 * DESCRIPTION: Compile SLIC.
2005 *****************************************************************************/
2012 DT_SUBTABLE *Subtable;
2013 DT_SUBTABLE *ParentTable;
2014 DT_FIELD **PFieldList = (DT_FIELD **) List;
2015 DT_FIELD *SubtableStart;
2016 ACPI_SLIC_HEADER *SlicHeader;
2017 ACPI_DMTABLE_INFO *InfoTable;
2022 SubtableStart = *PFieldList;
2023 Status = DtCompileTable (PFieldList, AcpiDmTableInfoSlicHdr,
2025 if (ACPI_FAILURE (Status))
2030 ParentTable = DtPeekSubtable ();
2031 DtInsertSubtable (ParentTable, Subtable);
2032 DtPushSubtable (Subtable);
2034 SlicHeader = ACPI_CAST_PTR (ACPI_SLIC_HEADER, Subtable->Buffer);
2036 switch (SlicHeader->Type)
2038 case ACPI_SLIC_TYPE_PUBLIC_KEY:
2040 InfoTable = AcpiDmTableInfoSlic0;
2043 case ACPI_SLIC_TYPE_WINDOWS_MARKER:
2045 InfoTable = AcpiDmTableInfoSlic1;
2050 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "SLIC");
2054 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
2055 if (ACPI_FAILURE (Status))
2060 ParentTable = DtPeekSubtable ();
2061 DtInsertSubtable (ParentTable, Subtable);
2069 /******************************************************************************
2071 * FUNCTION: DtCompileSlit
2073 * PARAMETERS: List - Current field list pointer
2077 * DESCRIPTION: Compile SLIT.
2079 *****************************************************************************/
2086 DT_SUBTABLE *Subtable;
2087 DT_SUBTABLE *ParentTable;
2088 DT_FIELD **PFieldList = (DT_FIELD **) List;
2089 DT_FIELD *FieldList;
2091 UINT8 *LocalityBuffer;
2094 Status = DtCompileTable (PFieldList, AcpiDmTableInfoSlit,
2096 if (ACPI_FAILURE (Status))
2101 ParentTable = DtPeekSubtable ();
2102 DtInsertSubtable (ParentTable, Subtable);
2104 Localities = *ACPI_CAST_PTR (UINT32, Subtable->Buffer);
2105 LocalityBuffer = UtLocalCalloc (Localities);
2107 /* Compile each locality buffer */
2109 FieldList = *PFieldList;
2112 DtCompileBuffer (LocalityBuffer,
2113 FieldList->Value, FieldList, Localities);
2115 DtCreateSubtable (LocalityBuffer, Localities, &Subtable);
2116 DtInsertSubtable (ParentTable, Subtable);
2117 FieldList = FieldList->Next;
2120 ACPI_FREE (LocalityBuffer);
2125 /******************************************************************************
2127 * FUNCTION: DtCompileSrat
2129 * PARAMETERS: List - Current field list pointer
2133 * DESCRIPTION: Compile SRAT.
2135 *****************************************************************************/
2142 DT_SUBTABLE *Subtable;
2143 DT_SUBTABLE *ParentTable;
2144 DT_FIELD **PFieldList = (DT_FIELD **) List;
2145 DT_FIELD *SubtableStart;
2146 ACPI_SUBTABLE_HEADER *SratHeader;
2147 ACPI_DMTABLE_INFO *InfoTable;
2150 Status = DtCompileTable (PFieldList, AcpiDmTableInfoSrat,
2152 if (ACPI_FAILURE (Status))
2157 ParentTable = DtPeekSubtable ();
2158 DtInsertSubtable (ParentTable, Subtable);
2162 SubtableStart = *PFieldList;
2163 Status = DtCompileTable (PFieldList, AcpiDmTableInfoSratHdr,
2165 if (ACPI_FAILURE (Status))
2170 ParentTable = DtPeekSubtable ();
2171 DtInsertSubtable (ParentTable, Subtable);
2172 DtPushSubtable (Subtable);
2174 SratHeader = ACPI_CAST_PTR (ACPI_SUBTABLE_HEADER, Subtable->Buffer);
2176 switch (SratHeader->Type)
2178 case ACPI_SRAT_TYPE_CPU_AFFINITY:
2180 InfoTable = AcpiDmTableInfoSrat0;
2183 case ACPI_SRAT_TYPE_MEMORY_AFFINITY:
2185 InfoTable = AcpiDmTableInfoSrat1;
2188 case ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY:
2190 InfoTable = AcpiDmTableInfoSrat2;
2195 DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "SRAT");
2199 Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
2200 if (ACPI_FAILURE (Status))
2205 ParentTable = DtPeekSubtable ();
2206 DtInsertSubtable (ParentTable, Subtable);
2214 /******************************************************************************
2216 * FUNCTION: DtGetGenericTableInfo
2218 * PARAMETERS: Name - Generic type name
2220 * RETURN: Info entry
2222 * DESCRIPTION: Obtain table info for a generic name entry
2224 *****************************************************************************/
2227 DtGetGenericTableInfo (
2230 ACPI_DMTABLE_INFO *Info;
2239 /* Search info table for name match */
2243 Info = AcpiDmTableInfoGeneric[i];
2244 if (Info->Opcode == ACPI_DMT_EXIT)
2250 /* Use caseless compare for generic keywords */
2252 if (!AcpiUtStricmp (Name, Info->Name))
2262 /******************************************************************************
2264 * FUNCTION: DtCompileUefi
2266 * PARAMETERS: List - Current field list pointer
2270 * DESCRIPTION: Compile UEFI.
2272 *****************************************************************************/
2279 DT_SUBTABLE *Subtable;
2280 DT_SUBTABLE *ParentTable;
2281 DT_FIELD **PFieldList = (DT_FIELD **) List;
2285 /* Compile the predefined portion of the UEFI table */
2287 Status = DtCompileTable (PFieldList, AcpiDmTableInfoUefi,
2289 if (ACPI_FAILURE (Status))
2294 DataOffset = (UINT16 *) (Subtable->Buffer + 16);
2295 *DataOffset = sizeof (ACPI_TABLE_UEFI);
2297 ParentTable = DtPeekSubtable ();
2298 DtInsertSubtable (ParentTable, Subtable);
2301 * Compile the "generic" portion of the UEFI table. This
2302 * part of the table is not predefined and any of the generic
2303 * operators may be used.
2306 DtCompileGeneric ((void **) PFieldList);
2312 /******************************************************************************
2314 * FUNCTION: DtCompileVrtc
2316 * PARAMETERS: List - Current field list pointer
2320 * DESCRIPTION: Compile VRTC.
2322 *****************************************************************************/
2331 Status = DtCompileTwoSubtables (List,
2332 AcpiDmTableInfoVrtc, AcpiDmTableInfoVrtc0);
2337 /******************************************************************************
2339 * FUNCTION: DtCompileWdat
2341 * PARAMETERS: List - Current field list pointer
2345 * DESCRIPTION: Compile WDAT.
2347 *****************************************************************************/
2356 Status = DtCompileTwoSubtables (List,
2357 AcpiDmTableInfoWdat, AcpiDmTableInfoWdat0);
2362 /******************************************************************************
2364 * FUNCTION: DtCompileXsdt
2366 * PARAMETERS: List - Current field list pointer
2370 * DESCRIPTION: Compile XSDT.
2372 *****************************************************************************/
2378 DT_SUBTABLE *Subtable;
2379 DT_SUBTABLE *ParentTable;
2380 DT_FIELD *FieldList = *(DT_FIELD **) List;
2383 ParentTable = DtPeekSubtable ();
2387 DtCompileInteger ((UINT8 *) &Address, FieldList, 8, DT_NON_ZERO);
2389 DtCreateSubtable ((UINT8 *) &Address, 8, &Subtable);
2390 DtInsertSubtable (ParentTable, Subtable);
2391 FieldList = FieldList->Next;
2398 /******************************************************************************
2400 * FUNCTION: DtCompileGeneric
2402 * PARAMETERS: List - Current field list pointer
2406 * DESCRIPTION: Compile generic unknown table.
2408 *****************************************************************************/
2415 DT_SUBTABLE *Subtable;
2416 DT_SUBTABLE *ParentTable;
2417 DT_FIELD **PFieldList = (DT_FIELD **) List;
2418 ACPI_DMTABLE_INFO *Info;
2421 ParentTable = DtPeekSubtable ();
2424 * Compile the "generic" portion of the table. This
2425 * part of the table is not predefined and any of the generic
2426 * operators may be used.
2429 /* Find any and all labels in the entire generic portion */
2431 DtDetectAllLabels (*PFieldList);
2433 /* Now we can actually compile the parse tree */
2437 Info = DtGetGenericTableInfo ((*PFieldList)->Name);
2440 sprintf (MsgBuffer, "Generic data type \"%s\" not found",
2441 (*PFieldList)->Name);
2442 DtNameError (ASL_ERROR, ASL_MSG_INVALID_FIELD_NAME,
2443 (*PFieldList), MsgBuffer);
2445 *PFieldList = (*PFieldList)->Next;
2449 Status = DtCompileTable (PFieldList, Info,
2451 if (ACPI_SUCCESS (Status))
2453 DtInsertSubtable (ParentTable, Subtable);
2457 *PFieldList = (*PFieldList)->Next;
2459 if (Status == AE_NOT_FOUND)
2461 sprintf (MsgBuffer, "Generic data type \"%s\" not found",
2462 (*PFieldList)->Name);
2463 DtNameError (ASL_ERROR, ASL_MSG_INVALID_FIELD_NAME,
2464 (*PFieldList), MsgBuffer);