xref: /freebsd/sys/contrib/dev/acpica/common/dmtbdump1.c (revision cfd1ed46817c680fa7822bc523b054ff644055dc)
1ff879b07SJung-uk Kim /******************************************************************************
2ff879b07SJung-uk Kim  *
3ff879b07SJung-uk Kim  * Module Name: dmtbdump1 - Dump ACPI data tables that contain no AML code
4ff879b07SJung-uk Kim  *
5ff879b07SJung-uk Kim  *****************************************************************************/
6ff879b07SJung-uk Kim 
7ff879b07SJung-uk Kim /******************************************************************************
8ff879b07SJung-uk Kim  *
9ff879b07SJung-uk Kim  * 1. Copyright Notice
10ff879b07SJung-uk Kim  *
1129f37e9bSJung-uk Kim  * Some or all of this work - Copyright (c) 1999 - 2021, Intel Corp.
12ff879b07SJung-uk Kim  * All rights reserved.
13ff879b07SJung-uk Kim  *
14ff879b07SJung-uk Kim  * 2. License
15ff879b07SJung-uk Kim  *
16ff879b07SJung-uk Kim  * 2.1. This is your license from Intel Corp. under its intellectual property
17ff879b07SJung-uk Kim  * rights. You may have additional license terms from the party that provided
18ff879b07SJung-uk Kim  * you this software, covering your right to use that party's intellectual
19ff879b07SJung-uk Kim  * property rights.
20ff879b07SJung-uk Kim  *
21ff879b07SJung-uk Kim  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
22ff879b07SJung-uk Kim  * copy of the source code appearing in this file ("Covered Code") an
23ff879b07SJung-uk Kim  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
24ff879b07SJung-uk Kim  * base code distributed originally by Intel ("Original Intel Code") to copy,
25ff879b07SJung-uk Kim  * make derivatives, distribute, use and display any portion of the Covered
26ff879b07SJung-uk Kim  * Code in any form, with the right to sublicense such rights; and
27ff879b07SJung-uk Kim  *
28ff879b07SJung-uk Kim  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
29ff879b07SJung-uk Kim  * license (with the right to sublicense), under only those claims of Intel
30ff879b07SJung-uk Kim  * patents that are infringed by the Original Intel Code, to make, use, sell,
31ff879b07SJung-uk Kim  * offer to sell, and import the Covered Code and derivative works thereof
32ff879b07SJung-uk Kim  * solely to the minimum extent necessary to exercise the above copyright
33ff879b07SJung-uk Kim  * license, and in no event shall the patent license extend to any additions
34ff879b07SJung-uk Kim  * to or modifications of the Original Intel Code. No other license or right
35ff879b07SJung-uk Kim  * is granted directly or by implication, estoppel or otherwise;
36ff879b07SJung-uk Kim  *
37ff879b07SJung-uk Kim  * The above copyright and patent license is granted only if the following
38ff879b07SJung-uk Kim  * conditions are met:
39ff879b07SJung-uk Kim  *
40ff879b07SJung-uk Kim  * 3. Conditions
41ff879b07SJung-uk Kim  *
42ff879b07SJung-uk Kim  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
43ff879b07SJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
44ff879b07SJung-uk Kim  * Code or modification with rights to further distribute source must include
45ff879b07SJung-uk Kim  * the above Copyright Notice, the above License, this list of Conditions,
46ff879b07SJung-uk Kim  * and the following Disclaimer and Export Compliance provision. In addition,
47ff879b07SJung-uk Kim  * Licensee must cause all Covered Code to which Licensee contributes to
48ff879b07SJung-uk Kim  * contain a file documenting the changes Licensee made to create that Covered
49ff879b07SJung-uk Kim  * Code and the date of any change. Licensee must include in that file the
50ff879b07SJung-uk Kim  * documentation of any changes made by any predecessor Licensee. Licensee
51ff879b07SJung-uk Kim  * must include a prominent statement that the modification is derived,
52ff879b07SJung-uk Kim  * directly or indirectly, from Original Intel Code.
53ff879b07SJung-uk Kim  *
54ff879b07SJung-uk Kim  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
55ff879b07SJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
56ff879b07SJung-uk Kim  * Code or modification without rights to further distribute source must
57ff879b07SJung-uk Kim  * include the following Disclaimer and Export Compliance provision in the
58ff879b07SJung-uk Kim  * documentation and/or other materials provided with distribution. In
59ff879b07SJung-uk Kim  * addition, Licensee may not authorize further sublicense of source of any
60ff879b07SJung-uk Kim  * portion of the Covered Code, and must include terms to the effect that the
61ff879b07SJung-uk Kim  * license from Licensee to its licensee is limited to the intellectual
62ff879b07SJung-uk Kim  * property embodied in the software Licensee provides to its licensee, and
63ff879b07SJung-uk Kim  * not to intellectual property embodied in modifications its licensee may
64ff879b07SJung-uk Kim  * make.
65ff879b07SJung-uk Kim  *
66ff879b07SJung-uk Kim  * 3.3. Redistribution of Executable. Redistribution in executable form of any
67ff879b07SJung-uk Kim  * substantial portion of the Covered Code or modification must reproduce the
68ff879b07SJung-uk Kim  * above Copyright Notice, and the following Disclaimer and Export Compliance
69ff879b07SJung-uk Kim  * provision in the documentation and/or other materials provided with the
70ff879b07SJung-uk Kim  * distribution.
71ff879b07SJung-uk Kim  *
72ff879b07SJung-uk Kim  * 3.4. Intel retains all right, title, and interest in and to the Original
73ff879b07SJung-uk Kim  * Intel Code.
74ff879b07SJung-uk Kim  *
75ff879b07SJung-uk Kim  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
76ff879b07SJung-uk Kim  * Intel shall be used in advertising or otherwise to promote the sale, use or
77ff879b07SJung-uk Kim  * other dealings in products derived from or relating to the Covered Code
78ff879b07SJung-uk Kim  * without prior written authorization from Intel.
79ff879b07SJung-uk Kim  *
80ff879b07SJung-uk Kim  * 4. Disclaimer and Export Compliance
81ff879b07SJung-uk Kim  *
82ff879b07SJung-uk Kim  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
83ff879b07SJung-uk Kim  * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
84ff879b07SJung-uk Kim  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
85ff879b07SJung-uk Kim  * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
86ff879b07SJung-uk Kim  * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
87ff879b07SJung-uk Kim  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
88ff879b07SJung-uk Kim  * PARTICULAR PURPOSE.
89ff879b07SJung-uk Kim  *
90ff879b07SJung-uk Kim  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
91ff879b07SJung-uk Kim  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
92ff879b07SJung-uk Kim  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
93ff879b07SJung-uk Kim  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
94ff879b07SJung-uk Kim  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
95ff879b07SJung-uk Kim  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
96ff879b07SJung-uk Kim  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
97ff879b07SJung-uk Kim  * LIMITED REMEDY.
98ff879b07SJung-uk Kim  *
99ff879b07SJung-uk Kim  * 4.3. Licensee shall not export, either directly or indirectly, any of this
100ff879b07SJung-uk Kim  * software or system incorporating such software without first obtaining any
101ff879b07SJung-uk Kim  * required license or other approval from the U. S. Department of Commerce or
102ff879b07SJung-uk Kim  * any other agency or department of the United States Government. In the
103ff879b07SJung-uk Kim  * event Licensee exports any such software from the United States or
104ff879b07SJung-uk Kim  * re-exports any such software from a foreign destination, Licensee shall
105ff879b07SJung-uk Kim  * ensure that the distribution and export/re-export of the software is in
106ff879b07SJung-uk Kim  * compliance with all laws, regulations, orders, or other restrictions of the
107ff879b07SJung-uk Kim  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
108ff879b07SJung-uk Kim  * any of its subsidiaries will export/re-export any technical data, process,
109ff879b07SJung-uk Kim  * software, or service, directly or indirectly, to any country for which the
110ff879b07SJung-uk Kim  * United States government or any agency thereof requires an export license,
111ff879b07SJung-uk Kim  * other governmental approval, or letter of assurance, without first obtaining
112ff879b07SJung-uk Kim  * such license, approval or letter.
113ff879b07SJung-uk Kim  *
114ff879b07SJung-uk Kim  *****************************************************************************
115ff879b07SJung-uk Kim  *
116ff879b07SJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
117ff879b07SJung-uk Kim  * following license:
118ff879b07SJung-uk Kim  *
119ff879b07SJung-uk Kim  * Redistribution and use in source and binary forms, with or without
120ff879b07SJung-uk Kim  * modification, are permitted provided that the following conditions
121ff879b07SJung-uk Kim  * are met:
122ff879b07SJung-uk Kim  * 1. Redistributions of source code must retain the above copyright
123ff879b07SJung-uk Kim  *    notice, this list of conditions, and the following disclaimer,
124ff879b07SJung-uk Kim  *    without modification.
125ff879b07SJung-uk Kim  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
126ff879b07SJung-uk Kim  *    substantially similar to the "NO WARRANTY" disclaimer below
127ff879b07SJung-uk Kim  *    ("Disclaimer") and any redistribution must be conditioned upon
128ff879b07SJung-uk Kim  *    including a substantially similar Disclaimer requirement for further
129ff879b07SJung-uk Kim  *    binary redistribution.
130ff879b07SJung-uk Kim  * 3. Neither the names of the above-listed copyright holders nor the names
131ff879b07SJung-uk Kim  *    of any contributors may be used to endorse or promote products derived
132ff879b07SJung-uk Kim  *    from this software without specific prior written permission.
133ff879b07SJung-uk Kim  *
134ff879b07SJung-uk Kim  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
135ff879b07SJung-uk Kim  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
136ff879b07SJung-uk Kim  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
137ff879b07SJung-uk Kim  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
138ff879b07SJung-uk Kim  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
139ff879b07SJung-uk Kim  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
140ff879b07SJung-uk Kim  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
141ff879b07SJung-uk Kim  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
142ff879b07SJung-uk Kim  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
143ff879b07SJung-uk Kim  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
144ff879b07SJung-uk Kim  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
145ff879b07SJung-uk Kim  *
146ff879b07SJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
147ff879b07SJung-uk Kim  * GNU General Public License ("GPL") version 2 as published by the Free
148ff879b07SJung-uk Kim  * Software Foundation.
149ff879b07SJung-uk Kim  *
150ff879b07SJung-uk Kim  *****************************************************************************/
151ff879b07SJung-uk Kim 
152ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/acpi.h>
153ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/accommon.h>
154ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/acdisasm.h>
155ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/actables.h>
156ff879b07SJung-uk Kim 
157ff879b07SJung-uk Kim /* This module used for application-level code only */
158ff879b07SJung-uk Kim 
159ff879b07SJung-uk Kim #define _COMPONENT          ACPI_CA_DISASSEMBLER
160ff879b07SJung-uk Kim         ACPI_MODULE_NAME    ("dmtbdump1")
161ff879b07SJung-uk Kim 
162ff879b07SJung-uk Kim 
163ff879b07SJung-uk Kim /*******************************************************************************
164ff879b07SJung-uk Kim  *
165ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpAsf
166ff879b07SJung-uk Kim  *
167ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A ASF table
168ff879b07SJung-uk Kim  *
169ff879b07SJung-uk Kim  * RETURN:      None
170ff879b07SJung-uk Kim  *
171ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a ASF table
172ff879b07SJung-uk Kim  *
173ff879b07SJung-uk Kim  ******************************************************************************/
174ff879b07SJung-uk Kim 
175ff879b07SJung-uk Kim void
176ff879b07SJung-uk Kim AcpiDmDumpAsf (
177ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
178ff879b07SJung-uk Kim {
179ff879b07SJung-uk Kim     ACPI_STATUS             Status;
180ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_HEADER);
181ff879b07SJung-uk Kim     ACPI_ASF_INFO           *Subtable;
182ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
183ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *DataInfoTable = NULL;
184ff879b07SJung-uk Kim     UINT8                   *DataTable = NULL;
185ff879b07SJung-uk Kim     UINT32                  DataCount = 0;
186ff879b07SJung-uk Kim     UINT32                  DataLength = 0;
187ff879b07SJung-uk Kim     UINT32                  DataOffset = 0;
188ff879b07SJung-uk Kim     UINT32                  i;
189ff879b07SJung-uk Kim     UINT8                   Type;
190ff879b07SJung-uk Kim 
191ff879b07SJung-uk Kim 
192ff879b07SJung-uk Kim     /* No main table, only subtables */
193ff879b07SJung-uk Kim 
194ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_ASF_INFO, Table, Offset);
195ff879b07SJung-uk Kim     while (Offset < Table->Length)
196ff879b07SJung-uk Kim     {
197ff879b07SJung-uk Kim         /* Common subtable header */
198ff879b07SJung-uk Kim 
199ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
200ff879b07SJung-uk Kim             Subtable->Header.Length, AcpiDmTableInfoAsfHdr);
201ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
202ff879b07SJung-uk Kim         {
203ff879b07SJung-uk Kim             return;
204ff879b07SJung-uk Kim         }
205ff879b07SJung-uk Kim 
206ff879b07SJung-uk Kim         /* The actual type is the lower 7 bits of Type */
207ff879b07SJung-uk Kim 
208ff879b07SJung-uk Kim         Type = (UINT8) (Subtable->Header.Type & 0x7F);
209ff879b07SJung-uk Kim 
210ff879b07SJung-uk Kim         switch (Type)
211ff879b07SJung-uk Kim         {
212ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_INFO:
213ff879b07SJung-uk Kim 
214ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoAsf0;
215ff879b07SJung-uk Kim             break;
216ff879b07SJung-uk Kim 
217ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_ALERT:
218ff879b07SJung-uk Kim 
219ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoAsf1;
220ff879b07SJung-uk Kim             DataInfoTable = AcpiDmTableInfoAsf1a;
221ff879b07SJung-uk Kim             DataTable = ACPI_ADD_PTR (UINT8, Subtable, sizeof (ACPI_ASF_ALERT));
222ff879b07SJung-uk Kim             DataCount = ACPI_CAST_PTR (ACPI_ASF_ALERT, Subtable)->Alerts;
223ff879b07SJung-uk Kim             DataLength = ACPI_CAST_PTR (ACPI_ASF_ALERT, Subtable)->DataLength;
224ff879b07SJung-uk Kim             DataOffset = Offset + sizeof (ACPI_ASF_ALERT);
225ff879b07SJung-uk Kim             break;
226ff879b07SJung-uk Kim 
227ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_CONTROL:
228ff879b07SJung-uk Kim 
229ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoAsf2;
230ff879b07SJung-uk Kim             DataInfoTable = AcpiDmTableInfoAsf2a;
231ff879b07SJung-uk Kim             DataTable = ACPI_ADD_PTR (UINT8, Subtable, sizeof (ACPI_ASF_REMOTE));
232ff879b07SJung-uk Kim             DataCount = ACPI_CAST_PTR (ACPI_ASF_REMOTE, Subtable)->Controls;
233ff879b07SJung-uk Kim             DataLength = ACPI_CAST_PTR (ACPI_ASF_REMOTE, Subtable)->DataLength;
234ff879b07SJung-uk Kim             DataOffset = Offset + sizeof (ACPI_ASF_REMOTE);
235ff879b07SJung-uk Kim             break;
236ff879b07SJung-uk Kim 
237ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_BOOT:
238ff879b07SJung-uk Kim 
239ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoAsf3;
240ff879b07SJung-uk Kim             break;
241ff879b07SJung-uk Kim 
242ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_ADDRESS:
243ff879b07SJung-uk Kim 
244ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoAsf4;
245ff879b07SJung-uk Kim             DataTable = ACPI_ADD_PTR (UINT8, Subtable, sizeof (ACPI_ASF_ADDRESS));
246ff879b07SJung-uk Kim             DataLength = ACPI_CAST_PTR (ACPI_ASF_ADDRESS, Subtable)->Devices;
247ff879b07SJung-uk Kim             DataOffset = Offset + sizeof (ACPI_ASF_ADDRESS);
248ff879b07SJung-uk Kim             break;
249ff879b07SJung-uk Kim 
250ff879b07SJung-uk Kim         default:
251ff879b07SJung-uk Kim 
252ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown ASF subtable type 0x%X\n",
253ff879b07SJung-uk Kim                 Subtable->Header.Type);
254ff879b07SJung-uk Kim             return;
255ff879b07SJung-uk Kim         }
256ff879b07SJung-uk Kim 
257ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
258ff879b07SJung-uk Kim             Subtable->Header.Length, InfoTable);
259ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
260ff879b07SJung-uk Kim         {
261ff879b07SJung-uk Kim             return;
262ff879b07SJung-uk Kim         }
263ff879b07SJung-uk Kim 
264ff879b07SJung-uk Kim         /* Dump variable-length extra data */
265ff879b07SJung-uk Kim 
266ff879b07SJung-uk Kim         switch (Type)
267ff879b07SJung-uk Kim         {
268ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_ALERT:
269ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_CONTROL:
270ff879b07SJung-uk Kim 
271ff879b07SJung-uk Kim             for (i = 0; i < DataCount; i++)
272ff879b07SJung-uk Kim             {
273ff879b07SJung-uk Kim                 AcpiOsPrintf ("\n");
274ff879b07SJung-uk Kim                 Status = AcpiDmDumpTable (Table->Length, DataOffset,
275ff879b07SJung-uk Kim                     DataTable, DataLength, DataInfoTable);
276ff879b07SJung-uk Kim                 if (ACPI_FAILURE (Status))
277ff879b07SJung-uk Kim                 {
278ff879b07SJung-uk Kim                     return;
279ff879b07SJung-uk Kim                 }
280ff879b07SJung-uk Kim 
281ff879b07SJung-uk Kim                 DataTable = ACPI_ADD_PTR (UINT8, DataTable, DataLength);
282ff879b07SJung-uk Kim                 DataOffset += DataLength;
283ff879b07SJung-uk Kim             }
284ff879b07SJung-uk Kim             break;
285ff879b07SJung-uk Kim 
286ff879b07SJung-uk Kim         case ACPI_ASF_TYPE_ADDRESS:
287ff879b07SJung-uk Kim 
288ff879b07SJung-uk Kim             for (i = 0; i < DataLength; i++)
289ff879b07SJung-uk Kim             {
290ff879b07SJung-uk Kim                 if (!(i % 16))
291ff879b07SJung-uk Kim                 {
292ff879b07SJung-uk Kim                     AcpiDmLineHeader (DataOffset, 1, "Addresses");
293ff879b07SJung-uk Kim                 }
294ff879b07SJung-uk Kim 
295ff879b07SJung-uk Kim                 AcpiOsPrintf ("%2.2X ", *DataTable);
296ff879b07SJung-uk Kim                 DataTable++;
297ff879b07SJung-uk Kim                 DataOffset++;
298ff879b07SJung-uk Kim 
299ff879b07SJung-uk Kim                 if (DataOffset > Table->Length)
300ff879b07SJung-uk Kim                 {
301ff879b07SJung-uk Kim                     AcpiOsPrintf (
302ff879b07SJung-uk Kim                         "**** ACPI table terminates in the middle of a "
303ff879b07SJung-uk Kim                         "data structure! (ASF! table)\n");
304ff879b07SJung-uk Kim                     return;
305ff879b07SJung-uk Kim                 }
306ff879b07SJung-uk Kim             }
307ff879b07SJung-uk Kim 
308ff879b07SJung-uk Kim             AcpiOsPrintf ("\n");
309ff879b07SJung-uk Kim             break;
310ff879b07SJung-uk Kim 
311ff879b07SJung-uk Kim         default:
312ff879b07SJung-uk Kim 
313ff879b07SJung-uk Kim             break;
314ff879b07SJung-uk Kim         }
315ff879b07SJung-uk Kim 
316ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
317ff879b07SJung-uk Kim 
318ff879b07SJung-uk Kim         /* Point to next subtable */
319ff879b07SJung-uk Kim 
320ff879b07SJung-uk Kim         if (!Subtable->Header.Length)
321ff879b07SJung-uk Kim         {
322ff879b07SJung-uk Kim             AcpiOsPrintf ("Invalid zero subtable header length\n");
323ff879b07SJung-uk Kim             return;
324ff879b07SJung-uk Kim         }
325ff879b07SJung-uk Kim 
326ff879b07SJung-uk Kim         Offset += Subtable->Header.Length;
327ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_ASF_INFO, Subtable,
328ff879b07SJung-uk Kim             Subtable->Header.Length);
329ff879b07SJung-uk Kim     }
330ff879b07SJung-uk Kim }
331ff879b07SJung-uk Kim 
332*cfd1ed46SJung-uk Kim /*******************************************************************************
333*cfd1ed46SJung-uk Kim  *
334*cfd1ed46SJung-uk Kim  * FUNCTION:    AcpiDmDumpCedt
335*cfd1ed46SJung-uk Kim  *
336*cfd1ed46SJung-uk Kim  * PARAMETERS:  Table               - A CEDT table
337*cfd1ed46SJung-uk Kim  *
338*cfd1ed46SJung-uk Kim  * RETURN:      None
339*cfd1ed46SJung-uk Kim  *
340*cfd1ed46SJung-uk Kim  * DESCRIPTION: Format the contents of a CEDT. This table type consists
341*cfd1ed46SJung-uk Kim  *              of an open-ended number of subtables.
342*cfd1ed46SJung-uk Kim  *
343*cfd1ed46SJung-uk Kim  ******************************************************************************/
344*cfd1ed46SJung-uk Kim 
345*cfd1ed46SJung-uk Kim void
346*cfd1ed46SJung-uk Kim AcpiDmDumpCedt (
347*cfd1ed46SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
348*cfd1ed46SJung-uk Kim {
349*cfd1ed46SJung-uk Kim     ACPI_STATUS             Status;
350*cfd1ed46SJung-uk Kim     ACPI_CEDT_HEADER        *Subtable;
351*cfd1ed46SJung-uk Kim     UINT32                  Length = Table->Length;
352*cfd1ed46SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_CEDT);
353*cfd1ed46SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
354*cfd1ed46SJung-uk Kim 
355*cfd1ed46SJung-uk Kim 
356*cfd1ed46SJung-uk Kim     /* There is no main table (other than the standard ACPI header) */
357*cfd1ed46SJung-uk Kim 
358*cfd1ed46SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_CEDT_HEADER, Table, Offset);
359*cfd1ed46SJung-uk Kim     while (Offset < Table->Length)
360*cfd1ed46SJung-uk Kim     {
361*cfd1ed46SJung-uk Kim         /* Common subtable header */
362*cfd1ed46SJung-uk Kim 
363*cfd1ed46SJung-uk Kim         AcpiOsPrintf ("\n");
364*cfd1ed46SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
365*cfd1ed46SJung-uk Kim             Subtable->Length, AcpiDmTableInfoCedtHdr);
366*cfd1ed46SJung-uk Kim         if (ACPI_FAILURE (Status))
367*cfd1ed46SJung-uk Kim         {
368*cfd1ed46SJung-uk Kim             return;
369*cfd1ed46SJung-uk Kim         }
370*cfd1ed46SJung-uk Kim 
371*cfd1ed46SJung-uk Kim         switch (Subtable->Type)
372*cfd1ed46SJung-uk Kim         {
373*cfd1ed46SJung-uk Kim         case ACPI_CEDT_TYPE_CHBS:
374*cfd1ed46SJung-uk Kim 
375*cfd1ed46SJung-uk Kim             InfoTable = AcpiDmTableInfoCedt0;
376*cfd1ed46SJung-uk Kim             break;
377*cfd1ed46SJung-uk Kim 
378*cfd1ed46SJung-uk Kim         default:
379*cfd1ed46SJung-uk Kim 
380*cfd1ed46SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown CEDT subtable type 0x%X\n\n",
381*cfd1ed46SJung-uk Kim                 Subtable->Type);
382*cfd1ed46SJung-uk Kim 
383*cfd1ed46SJung-uk Kim             /* Attempt to continue */
384*cfd1ed46SJung-uk Kim 
385*cfd1ed46SJung-uk Kim             if (!Subtable->Length)
386*cfd1ed46SJung-uk Kim             {
387*cfd1ed46SJung-uk Kim                 AcpiOsPrintf ("Invalid zero length subtable\n");
388*cfd1ed46SJung-uk Kim                 return;
389*cfd1ed46SJung-uk Kim             }
390*cfd1ed46SJung-uk Kim             goto NextSubtable;
391*cfd1ed46SJung-uk Kim         }
392*cfd1ed46SJung-uk Kim 
393*cfd1ed46SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
394*cfd1ed46SJung-uk Kim             Subtable->Length, InfoTable);
395*cfd1ed46SJung-uk Kim         if (ACPI_FAILURE (Status))
396*cfd1ed46SJung-uk Kim         {
397*cfd1ed46SJung-uk Kim             return;
398*cfd1ed46SJung-uk Kim         }
399*cfd1ed46SJung-uk Kim 
400*cfd1ed46SJung-uk Kim NextSubtable:
401*cfd1ed46SJung-uk Kim         /* Point to next subtable */
402*cfd1ed46SJung-uk Kim 
403*cfd1ed46SJung-uk Kim         Offset += Subtable->Length;
404*cfd1ed46SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_CEDT_HEADER, Subtable,
405*cfd1ed46SJung-uk Kim             Subtable->Length);
406*cfd1ed46SJung-uk Kim     }
407*cfd1ed46SJung-uk Kim }
408ff879b07SJung-uk Kim 
409ff879b07SJung-uk Kim /*******************************************************************************
410ff879b07SJung-uk Kim  *
411ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpCpep
412ff879b07SJung-uk Kim  *
413ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A CPEP table
414ff879b07SJung-uk Kim  *
415ff879b07SJung-uk Kim  * RETURN:      None
416ff879b07SJung-uk Kim  *
417ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a CPEP. This table type consists
418ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
419ff879b07SJung-uk Kim  *
420ff879b07SJung-uk Kim  ******************************************************************************/
421ff879b07SJung-uk Kim 
422ff879b07SJung-uk Kim void
423ff879b07SJung-uk Kim AcpiDmDumpCpep (
424ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
425ff879b07SJung-uk Kim {
426ff879b07SJung-uk Kim     ACPI_STATUS             Status;
427ff879b07SJung-uk Kim     ACPI_CPEP_POLLING       *Subtable;
428ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
429ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_CPEP);
430ff879b07SJung-uk Kim 
431ff879b07SJung-uk Kim 
432ff879b07SJung-uk Kim     /* Main table */
433ff879b07SJung-uk Kim 
434ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoCpep);
435ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
436ff879b07SJung-uk Kim     {
437ff879b07SJung-uk Kim         return;
438ff879b07SJung-uk Kim     }
439ff879b07SJung-uk Kim 
440ff879b07SJung-uk Kim     /* Subtables */
441ff879b07SJung-uk Kim 
442ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_CPEP_POLLING, Table, Offset);
443ff879b07SJung-uk Kim     while (Offset < Table->Length)
444ff879b07SJung-uk Kim     {
445ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
446ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
447ff879b07SJung-uk Kim             Subtable->Header.Length, AcpiDmTableInfoCpep0);
448ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
449ff879b07SJung-uk Kim         {
450ff879b07SJung-uk Kim             return;
451ff879b07SJung-uk Kim         }
452ff879b07SJung-uk Kim 
453ff879b07SJung-uk Kim         /* Point to next subtable */
454ff879b07SJung-uk Kim 
455ff879b07SJung-uk Kim         Offset += Subtable->Header.Length;
456ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_CPEP_POLLING, Subtable,
457ff879b07SJung-uk Kim             Subtable->Header.Length);
458ff879b07SJung-uk Kim     }
459ff879b07SJung-uk Kim }
460ff879b07SJung-uk Kim 
461ff879b07SJung-uk Kim 
462ff879b07SJung-uk Kim /*******************************************************************************
463ff879b07SJung-uk Kim  *
464ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpCsrt
465ff879b07SJung-uk Kim  *
466ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A CSRT table
467ff879b07SJung-uk Kim  *
468ff879b07SJung-uk Kim  * RETURN:      None
469ff879b07SJung-uk Kim  *
470ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a CSRT. This table type consists
471ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
472ff879b07SJung-uk Kim  *
473ff879b07SJung-uk Kim  ******************************************************************************/
474ff879b07SJung-uk Kim 
475ff879b07SJung-uk Kim void
476ff879b07SJung-uk Kim AcpiDmDumpCsrt (
477ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
478ff879b07SJung-uk Kim {
479ff879b07SJung-uk Kim     ACPI_STATUS             Status;
480ff879b07SJung-uk Kim     ACPI_CSRT_GROUP         *Subtable;
481ff879b07SJung-uk Kim     ACPI_CSRT_SHARED_INFO   *SharedInfoTable;
482ff879b07SJung-uk Kim     ACPI_CSRT_DESCRIPTOR    *SubSubtable;
483ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
484ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_CSRT);
485ff879b07SJung-uk Kim     UINT32                  SubOffset;
486ff879b07SJung-uk Kim     UINT32                  SubSubOffset;
487ff879b07SJung-uk Kim     UINT32                  InfoLength;
488ff879b07SJung-uk Kim 
489ff879b07SJung-uk Kim 
490ff879b07SJung-uk Kim     /* The main table only contains the ACPI header, thus already handled */
491ff879b07SJung-uk Kim 
492ff879b07SJung-uk Kim     /* Subtables (Resource Groups) */
493ff879b07SJung-uk Kim 
494ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_CSRT_GROUP, Table, Offset);
495ff879b07SJung-uk Kim     while (Offset < Table->Length)
496ff879b07SJung-uk Kim     {
497ff879b07SJung-uk Kim         /* Resource group subtable */
498ff879b07SJung-uk Kim 
499ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
500ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
501ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoCsrt0);
502ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
503ff879b07SJung-uk Kim         {
504ff879b07SJung-uk Kim             return;
505ff879b07SJung-uk Kim         }
506ff879b07SJung-uk Kim 
507ff879b07SJung-uk Kim         /* Shared info subtable (One per resource group) */
508ff879b07SJung-uk Kim 
509ff879b07SJung-uk Kim         SubOffset = sizeof (ACPI_CSRT_GROUP);
510ff879b07SJung-uk Kim         SharedInfoTable = ACPI_ADD_PTR (ACPI_CSRT_SHARED_INFO, Table,
511ff879b07SJung-uk Kim             Offset + SubOffset);
512ff879b07SJung-uk Kim 
513ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
514ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset + SubOffset, SharedInfoTable,
515ff879b07SJung-uk Kim             sizeof (ACPI_CSRT_SHARED_INFO), AcpiDmTableInfoCsrt1);
516ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
517ff879b07SJung-uk Kim         {
518ff879b07SJung-uk Kim             return;
519ff879b07SJung-uk Kim         }
520ff879b07SJung-uk Kim 
521ff879b07SJung-uk Kim         SubOffset += Subtable->SharedInfoLength;
522ff879b07SJung-uk Kim 
523ff879b07SJung-uk Kim         /* Sub-Subtables (Resource Descriptors) */
524ff879b07SJung-uk Kim 
525ff879b07SJung-uk Kim         SubSubtable = ACPI_ADD_PTR (ACPI_CSRT_DESCRIPTOR, Table,
526ff879b07SJung-uk Kim             Offset + SubOffset);
527ff879b07SJung-uk Kim 
528ff879b07SJung-uk Kim         while ((SubOffset < Subtable->Length) &&
529ff879b07SJung-uk Kim               ((Offset + SubOffset) < Table->Length))
530ff879b07SJung-uk Kim         {
531ff879b07SJung-uk Kim             AcpiOsPrintf ("\n");
532ff879b07SJung-uk Kim             Status = AcpiDmDumpTable (Length, Offset + SubOffset, SubSubtable,
533ff879b07SJung-uk Kim                 SubSubtable->Length, AcpiDmTableInfoCsrt2);
534ff879b07SJung-uk Kim             if (ACPI_FAILURE (Status))
535ff879b07SJung-uk Kim             {
536ff879b07SJung-uk Kim                 return;
537ff879b07SJung-uk Kim             }
538ff879b07SJung-uk Kim 
539ff879b07SJung-uk Kim             SubSubOffset = sizeof (ACPI_CSRT_DESCRIPTOR);
540ff879b07SJung-uk Kim 
541ff879b07SJung-uk Kim             /* Resource-specific info buffer */
542ff879b07SJung-uk Kim 
543ff879b07SJung-uk Kim             InfoLength = SubSubtable->Length - SubSubOffset;
544ff879b07SJung-uk Kim             if (InfoLength)
545ff879b07SJung-uk Kim             {
546ff879b07SJung-uk Kim                 Status = AcpiDmDumpTable (Length,
547ff879b07SJung-uk Kim                     Offset + SubOffset + SubSubOffset, Table,
548ff879b07SJung-uk Kim                     InfoLength, AcpiDmTableInfoCsrt2a);
549ff879b07SJung-uk Kim                 if (ACPI_FAILURE (Status))
550ff879b07SJung-uk Kim                 {
551ff879b07SJung-uk Kim                     return;
552ff879b07SJung-uk Kim                 }
553ff879b07SJung-uk Kim             }
554ff879b07SJung-uk Kim 
555ff879b07SJung-uk Kim             /* Point to next sub-subtable */
556ff879b07SJung-uk Kim 
557ff879b07SJung-uk Kim             SubOffset += SubSubtable->Length;
558ff879b07SJung-uk Kim             SubSubtable = ACPI_ADD_PTR (ACPI_CSRT_DESCRIPTOR, SubSubtable,
559ff879b07SJung-uk Kim                 SubSubtable->Length);
560ff879b07SJung-uk Kim         }
561ff879b07SJung-uk Kim 
562ff879b07SJung-uk Kim         /* Point to next subtable */
563ff879b07SJung-uk Kim 
564ff879b07SJung-uk Kim         Offset += Subtable->Length;
565ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_CSRT_GROUP, Subtable,
566ff879b07SJung-uk Kim             Subtable->Length);
567ff879b07SJung-uk Kim     }
568ff879b07SJung-uk Kim }
569ff879b07SJung-uk Kim 
570ff879b07SJung-uk Kim 
571ff879b07SJung-uk Kim /*******************************************************************************
572ff879b07SJung-uk Kim  *
573ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpDbg2
574ff879b07SJung-uk Kim  *
575ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A DBG2 table
576ff879b07SJung-uk Kim  *
577ff879b07SJung-uk Kim  * RETURN:      None
578ff879b07SJung-uk Kim  *
579ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a DBG2. This table type consists
580ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
581ff879b07SJung-uk Kim  *
582ff879b07SJung-uk Kim  ******************************************************************************/
583ff879b07SJung-uk Kim 
584ff879b07SJung-uk Kim void
585ff879b07SJung-uk Kim AcpiDmDumpDbg2 (
586ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
587ff879b07SJung-uk Kim {
588ff879b07SJung-uk Kim     ACPI_STATUS             Status;
589ff879b07SJung-uk Kim     ACPI_DBG2_DEVICE        *Subtable;
590ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
591ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_DBG2);
592ff879b07SJung-uk Kim     UINT32                  i;
593ff879b07SJung-uk Kim     UINT32                  ArrayOffset;
594ff879b07SJung-uk Kim     UINT32                  AbsoluteOffset;
595ff879b07SJung-uk Kim     UINT8                   *Array;
596ff879b07SJung-uk Kim 
597ff879b07SJung-uk Kim 
598ff879b07SJung-uk Kim     /* Main table */
599ff879b07SJung-uk Kim 
600ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoDbg2);
601ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
602ff879b07SJung-uk Kim     {
603ff879b07SJung-uk Kim         return;
604ff879b07SJung-uk Kim     }
605ff879b07SJung-uk Kim 
606ff879b07SJung-uk Kim     /* Subtables */
607ff879b07SJung-uk Kim 
608ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_DBG2_DEVICE, Table, Offset);
609ff879b07SJung-uk Kim     while (Offset < Table->Length)
610ff879b07SJung-uk Kim     {
611ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
612ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
613ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoDbg2Device);
614ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
615ff879b07SJung-uk Kim         {
616ff879b07SJung-uk Kim             return;
617ff879b07SJung-uk Kim         }
618ff879b07SJung-uk Kim 
619ff879b07SJung-uk Kim         /* Dump the BaseAddress array */
620ff879b07SJung-uk Kim 
621ff879b07SJung-uk Kim         for (i = 0; i < Subtable->RegisterCount; i++)
622ff879b07SJung-uk Kim         {
623ff879b07SJung-uk Kim             ArrayOffset = Subtable->BaseAddressOffset +
624ff879b07SJung-uk Kim                 (sizeof (ACPI_GENERIC_ADDRESS) * i);
625ff879b07SJung-uk Kim             AbsoluteOffset = Offset + ArrayOffset;
626ff879b07SJung-uk Kim             Array = (UINT8 *) Subtable + ArrayOffset;
627ff879b07SJung-uk Kim 
628ff879b07SJung-uk Kim             Status = AcpiDmDumpTable (Length, AbsoluteOffset, Array,
629ff879b07SJung-uk Kim                 Subtable->Length, AcpiDmTableInfoDbg2Addr);
630ff879b07SJung-uk Kim             if (ACPI_FAILURE (Status))
631ff879b07SJung-uk Kim             {
632ff879b07SJung-uk Kim                 return;
633ff879b07SJung-uk Kim             }
634ff879b07SJung-uk Kim         }
635ff879b07SJung-uk Kim 
636ff879b07SJung-uk Kim         /* Dump the AddressSize array */
637ff879b07SJung-uk Kim 
638ff879b07SJung-uk Kim         for (i = 0; i < Subtable->RegisterCount; i++)
639ff879b07SJung-uk Kim         {
640ff879b07SJung-uk Kim             ArrayOffset = Subtable->AddressSizeOffset +
641ff879b07SJung-uk Kim                 (sizeof (UINT32) * i);
642ff879b07SJung-uk Kim             AbsoluteOffset = Offset + ArrayOffset;
643ff879b07SJung-uk Kim             Array = (UINT8 *) Subtable + ArrayOffset;
644ff879b07SJung-uk Kim 
645ff879b07SJung-uk Kim             Status = AcpiDmDumpTable (Length, AbsoluteOffset, Array,
646ff879b07SJung-uk Kim                 Subtable->Length, AcpiDmTableInfoDbg2Size);
647ff879b07SJung-uk Kim             if (ACPI_FAILURE (Status))
648ff879b07SJung-uk Kim             {
649ff879b07SJung-uk Kim                 return;
650ff879b07SJung-uk Kim             }
651ff879b07SJung-uk Kim         }
652ff879b07SJung-uk Kim 
653ff879b07SJung-uk Kim         /* Dump the Namestring (required) */
654ff879b07SJung-uk Kim 
655ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
656ff879b07SJung-uk Kim         ArrayOffset = Subtable->NamepathOffset;
657ff879b07SJung-uk Kim         AbsoluteOffset = Offset + ArrayOffset;
658ff879b07SJung-uk Kim         Array = (UINT8 *) Subtable + ArrayOffset;
659ff879b07SJung-uk Kim 
660ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, AbsoluteOffset, Array,
661ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoDbg2Name);
662ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
663ff879b07SJung-uk Kim         {
664ff879b07SJung-uk Kim             return;
665ff879b07SJung-uk Kim         }
666ff879b07SJung-uk Kim 
667ff879b07SJung-uk Kim         /* Dump the OemData (optional) */
668ff879b07SJung-uk Kim 
669ff879b07SJung-uk Kim         if (Subtable->OemDataOffset)
670ff879b07SJung-uk Kim         {
671ff879b07SJung-uk Kim             Status = AcpiDmDumpTable (Length, Offset + Subtable->OemDataOffset,
672ff879b07SJung-uk Kim                 Table, Subtable->OemDataLength,
673ff879b07SJung-uk Kim                 AcpiDmTableInfoDbg2OemData);
674ff879b07SJung-uk Kim             if (ACPI_FAILURE (Status))
675ff879b07SJung-uk Kim             {
676ff879b07SJung-uk Kim                 return;
677ff879b07SJung-uk Kim             }
678ff879b07SJung-uk Kim         }
679ff879b07SJung-uk Kim 
680ff879b07SJung-uk Kim         /* Point to next subtable */
681ff879b07SJung-uk Kim 
682ff879b07SJung-uk Kim         Offset += Subtable->Length;
683ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_DBG2_DEVICE, Subtable,
684ff879b07SJung-uk Kim             Subtable->Length);
685ff879b07SJung-uk Kim     }
686ff879b07SJung-uk Kim }
687ff879b07SJung-uk Kim 
688ff879b07SJung-uk Kim 
689ff879b07SJung-uk Kim /*******************************************************************************
690ff879b07SJung-uk Kim  *
691ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpDmar
692ff879b07SJung-uk Kim  *
693ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A DMAR table
694ff879b07SJung-uk Kim  *
695ff879b07SJung-uk Kim  * RETURN:      None
696ff879b07SJung-uk Kim  *
697ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a DMAR. This table type consists
698ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
699ff879b07SJung-uk Kim  *
700ff879b07SJung-uk Kim  ******************************************************************************/
701ff879b07SJung-uk Kim 
702ff879b07SJung-uk Kim void
703ff879b07SJung-uk Kim AcpiDmDumpDmar (
704ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
705ff879b07SJung-uk Kim {
706ff879b07SJung-uk Kim     ACPI_STATUS             Status;
707ff879b07SJung-uk Kim     ACPI_DMAR_HEADER        *Subtable;
708ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
709ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_DMAR);
710ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
711ff879b07SJung-uk Kim     ACPI_DMAR_DEVICE_SCOPE  *ScopeTable;
712ff879b07SJung-uk Kim     UINT32                  ScopeOffset;
713ff879b07SJung-uk Kim     UINT8                   *PciPath;
714ff879b07SJung-uk Kim     UINT32                  PathOffset;
715ff879b07SJung-uk Kim 
716ff879b07SJung-uk Kim 
717ff879b07SJung-uk Kim     /* Main table */
718ff879b07SJung-uk Kim 
719ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoDmar);
720ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
721ff879b07SJung-uk Kim     {
722ff879b07SJung-uk Kim         return;
723ff879b07SJung-uk Kim     }
724ff879b07SJung-uk Kim 
725ff879b07SJung-uk Kim     /* Subtables */
726ff879b07SJung-uk Kim 
727ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_DMAR_HEADER, Table, Offset);
728ff879b07SJung-uk Kim     while (Offset < Table->Length)
729ff879b07SJung-uk Kim     {
730ff879b07SJung-uk Kim         /* Common subtable header */
731ff879b07SJung-uk Kim 
732ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
733ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
734ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoDmarHdr);
735ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
736ff879b07SJung-uk Kim         {
737ff879b07SJung-uk Kim             return;
738ff879b07SJung-uk Kim         }
739ff879b07SJung-uk Kim 
740ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
741ff879b07SJung-uk Kim 
742ff879b07SJung-uk Kim         switch (Subtable->Type)
743ff879b07SJung-uk Kim         {
744ff879b07SJung-uk Kim         case ACPI_DMAR_TYPE_HARDWARE_UNIT:
745ff879b07SJung-uk Kim 
746ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoDmar0;
747ff879b07SJung-uk Kim             ScopeOffset = sizeof (ACPI_DMAR_HARDWARE_UNIT);
748ff879b07SJung-uk Kim             break;
749ff879b07SJung-uk Kim 
750ff879b07SJung-uk Kim         case ACPI_DMAR_TYPE_RESERVED_MEMORY:
751ff879b07SJung-uk Kim 
752ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoDmar1;
753ff879b07SJung-uk Kim             ScopeOffset = sizeof (ACPI_DMAR_RESERVED_MEMORY);
754ff879b07SJung-uk Kim             break;
755ff879b07SJung-uk Kim 
756ff879b07SJung-uk Kim         case ACPI_DMAR_TYPE_ROOT_ATS:
757ff879b07SJung-uk Kim 
758ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoDmar2;
759ff879b07SJung-uk Kim             ScopeOffset = sizeof (ACPI_DMAR_ATSR);
760ff879b07SJung-uk Kim             break;
761ff879b07SJung-uk Kim 
762ff879b07SJung-uk Kim         case ACPI_DMAR_TYPE_HARDWARE_AFFINITY:
763ff879b07SJung-uk Kim 
764ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoDmar3;
765ff879b07SJung-uk Kim             ScopeOffset = sizeof (ACPI_DMAR_RHSA);
766ff879b07SJung-uk Kim             break;
767ff879b07SJung-uk Kim 
768ff879b07SJung-uk Kim         case ACPI_DMAR_TYPE_NAMESPACE:
769ff879b07SJung-uk Kim 
770ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoDmar4;
771ff879b07SJung-uk Kim             ScopeOffset = sizeof (ACPI_DMAR_ANDD);
772ff879b07SJung-uk Kim             break;
773ff879b07SJung-uk Kim 
774ff879b07SJung-uk Kim         default:
775ff879b07SJung-uk Kim 
776ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown DMAR subtable type 0x%X\n\n",
777ff879b07SJung-uk Kim                 Subtable->Type);
778ff879b07SJung-uk Kim             return;
779ff879b07SJung-uk Kim         }
780ff879b07SJung-uk Kim 
781ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
782ff879b07SJung-uk Kim             Subtable->Length, InfoTable);
783ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
784ff879b07SJung-uk Kim         {
785ff879b07SJung-uk Kim             return;
786ff879b07SJung-uk Kim         }
787ff879b07SJung-uk Kim 
788ff879b07SJung-uk Kim         /*
789ff879b07SJung-uk Kim          * Dump the optional device scope entries
790ff879b07SJung-uk Kim          */
791ff879b07SJung-uk Kim         if ((Subtable->Type == ACPI_DMAR_TYPE_HARDWARE_AFFINITY) ||
792ff879b07SJung-uk Kim             (Subtable->Type == ACPI_DMAR_TYPE_NAMESPACE))
793ff879b07SJung-uk Kim         {
794ff879b07SJung-uk Kim             /* These types do not support device scopes */
795ff879b07SJung-uk Kim 
796ff879b07SJung-uk Kim             goto NextSubtable;
797ff879b07SJung-uk Kim         }
798ff879b07SJung-uk Kim 
799ff879b07SJung-uk Kim         ScopeTable = ACPI_ADD_PTR (ACPI_DMAR_DEVICE_SCOPE, Subtable, ScopeOffset);
800ff879b07SJung-uk Kim         while (ScopeOffset < Subtable->Length)
801ff879b07SJung-uk Kim         {
802ff879b07SJung-uk Kim             AcpiOsPrintf ("\n");
803ff879b07SJung-uk Kim             Status = AcpiDmDumpTable (Length, Offset + ScopeOffset, ScopeTable,
804ff879b07SJung-uk Kim                 ScopeTable->Length, AcpiDmTableInfoDmarScope);
805ff879b07SJung-uk Kim             if (ACPI_FAILURE (Status))
806ff879b07SJung-uk Kim             {
807ff879b07SJung-uk Kim                 return;
808ff879b07SJung-uk Kim             }
809ff879b07SJung-uk Kim             AcpiOsPrintf ("\n");
810ff879b07SJung-uk Kim 
811ff879b07SJung-uk Kim             /* Dump the PCI Path entries for this device scope */
812ff879b07SJung-uk Kim 
813ff879b07SJung-uk Kim             PathOffset = sizeof (ACPI_DMAR_DEVICE_SCOPE); /* Path entries start at this offset */
814ff879b07SJung-uk Kim 
815ff879b07SJung-uk Kim             PciPath = ACPI_ADD_PTR (UINT8, ScopeTable,
816ff879b07SJung-uk Kim                 sizeof (ACPI_DMAR_DEVICE_SCOPE));
817ff879b07SJung-uk Kim 
818ff879b07SJung-uk Kim             while (PathOffset < ScopeTable->Length)
819ff879b07SJung-uk Kim             {
820ff879b07SJung-uk Kim                 AcpiDmLineHeader ((PathOffset + ScopeOffset + Offset), 2,
821ff879b07SJung-uk Kim                     "PCI Path");
822ff879b07SJung-uk Kim                 AcpiOsPrintf ("%2.2X,%2.2X\n", PciPath[0], PciPath[1]);
823ff879b07SJung-uk Kim 
824ff879b07SJung-uk Kim                 /* Point to next PCI Path entry */
825ff879b07SJung-uk Kim 
826ff879b07SJung-uk Kim                 PathOffset += 2;
827ff879b07SJung-uk Kim                 PciPath += 2;
828ff879b07SJung-uk Kim                 AcpiOsPrintf ("\n");
829ff879b07SJung-uk Kim             }
830ff879b07SJung-uk Kim 
831ff879b07SJung-uk Kim             /* Point to next device scope entry */
832ff879b07SJung-uk Kim 
833ff879b07SJung-uk Kim             ScopeOffset += ScopeTable->Length;
834ff879b07SJung-uk Kim             ScopeTable = ACPI_ADD_PTR (ACPI_DMAR_DEVICE_SCOPE,
835ff879b07SJung-uk Kim                 ScopeTable, ScopeTable->Length);
836ff879b07SJung-uk Kim         }
837ff879b07SJung-uk Kim 
838ff879b07SJung-uk Kim NextSubtable:
839ff879b07SJung-uk Kim         /* Point to next subtable */
840ff879b07SJung-uk Kim 
841ff879b07SJung-uk Kim         Offset += Subtable->Length;
842ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_DMAR_HEADER, Subtable,
843ff879b07SJung-uk Kim             Subtable->Length);
844ff879b07SJung-uk Kim     }
845ff879b07SJung-uk Kim }
846ff879b07SJung-uk Kim 
847ff879b07SJung-uk Kim 
848ff879b07SJung-uk Kim /*******************************************************************************
849ff879b07SJung-uk Kim  *
850ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpDrtm
851ff879b07SJung-uk Kim  *
852ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A DRTM table
853ff879b07SJung-uk Kim  *
854ff879b07SJung-uk Kim  * RETURN:      None
855ff879b07SJung-uk Kim  *
856ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a DRTM.
857ff879b07SJung-uk Kim  *
858ff879b07SJung-uk Kim  ******************************************************************************/
859ff879b07SJung-uk Kim 
860ff879b07SJung-uk Kim void
861ff879b07SJung-uk Kim AcpiDmDumpDrtm (
862ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
863ff879b07SJung-uk Kim {
864ff879b07SJung-uk Kim     ACPI_STATUS             Status;
865ff879b07SJung-uk Kim     UINT32                  Offset;
866ff879b07SJung-uk Kim     ACPI_DRTM_VTABLE_LIST   *DrtmVtl;
867ff879b07SJung-uk Kim     ACPI_DRTM_RESOURCE_LIST *DrtmRl;
868ff879b07SJung-uk Kim     ACPI_DRTM_DPS_ID        *DrtmDps;
869ff879b07SJung-uk Kim     UINT32                  Count;
870ff879b07SJung-uk Kim 
871ff879b07SJung-uk Kim 
872ff879b07SJung-uk Kim     /* Main table */
873ff879b07SJung-uk Kim 
874ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0,
875ff879b07SJung-uk Kim         AcpiDmTableInfoDrtm);
876ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
877ff879b07SJung-uk Kim     {
878ff879b07SJung-uk Kim         return;
879ff879b07SJung-uk Kim     }
880ff879b07SJung-uk Kim 
881ff879b07SJung-uk Kim     Offset = sizeof (ACPI_TABLE_DRTM);
882ff879b07SJung-uk Kim 
883ff879b07SJung-uk Kim     /* Sub-tables */
884ff879b07SJung-uk Kim 
885ff879b07SJung-uk Kim     /* Dump ValidatedTable length */
886ff879b07SJung-uk Kim 
887ff879b07SJung-uk Kim     DrtmVtl = ACPI_ADD_PTR (ACPI_DRTM_VTABLE_LIST, Table, Offset);
888ff879b07SJung-uk Kim     AcpiOsPrintf ("\n");
889ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, Offset,
890ff879b07SJung-uk Kim         DrtmVtl, ACPI_OFFSET (ACPI_DRTM_VTABLE_LIST, ValidatedTables),
891ff879b07SJung-uk Kim         AcpiDmTableInfoDrtm0);
892ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
893ff879b07SJung-uk Kim     {
894ff879b07SJung-uk Kim             return;
895ff879b07SJung-uk Kim     }
896ff879b07SJung-uk Kim 
897ff879b07SJung-uk Kim     Offset += ACPI_OFFSET (ACPI_DRTM_VTABLE_LIST, ValidatedTables);
898ff879b07SJung-uk Kim 
899ff879b07SJung-uk Kim     /* Dump Validated table addresses */
900ff879b07SJung-uk Kim 
901ff879b07SJung-uk Kim     Count = 0;
902ff879b07SJung-uk Kim     while ((Offset < Table->Length) &&
903ff879b07SJung-uk Kim             (DrtmVtl->ValidatedTableCount > Count))
904ff879b07SJung-uk Kim     {
905ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset,
906ff879b07SJung-uk Kim             ACPI_ADD_PTR (void, Table, Offset), sizeof (UINT64),
907ff879b07SJung-uk Kim             AcpiDmTableInfoDrtm0a);
908ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
909ff879b07SJung-uk Kim         {
910ff879b07SJung-uk Kim             return;
911ff879b07SJung-uk Kim         }
912ff879b07SJung-uk Kim 
913ff879b07SJung-uk Kim         Offset += sizeof (UINT64);
914ff879b07SJung-uk Kim         Count++;
915ff879b07SJung-uk Kim     }
916ff879b07SJung-uk Kim 
917ff879b07SJung-uk Kim     /* Dump ResourceList length */
918ff879b07SJung-uk Kim 
919ff879b07SJung-uk Kim     DrtmRl = ACPI_ADD_PTR (ACPI_DRTM_RESOURCE_LIST, Table, Offset);
920ff879b07SJung-uk Kim     AcpiOsPrintf ("\n");
921ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, Offset,
922ff879b07SJung-uk Kim         DrtmRl, ACPI_OFFSET (ACPI_DRTM_RESOURCE_LIST, Resources),
923ff879b07SJung-uk Kim         AcpiDmTableInfoDrtm1);
924ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
925ff879b07SJung-uk Kim     {
926ff879b07SJung-uk Kim         return;
927ff879b07SJung-uk Kim     }
928ff879b07SJung-uk Kim 
929ff879b07SJung-uk Kim     Offset += ACPI_OFFSET (ACPI_DRTM_RESOURCE_LIST, Resources);
930ff879b07SJung-uk Kim 
931ff879b07SJung-uk Kim     /* Dump the Resource List */
932ff879b07SJung-uk Kim 
933ff879b07SJung-uk Kim     Count = 0;
934ff879b07SJung-uk Kim     while ((Offset < Table->Length) &&
935ff879b07SJung-uk Kim            (DrtmRl->ResourceCount > Count))
936ff879b07SJung-uk Kim     {
937ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset,
938ff879b07SJung-uk Kim             ACPI_ADD_PTR (void, Table, Offset),
939ff879b07SJung-uk Kim             sizeof (ACPI_DRTM_RESOURCE), AcpiDmTableInfoDrtm1a);
940ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
941ff879b07SJung-uk Kim         {
942ff879b07SJung-uk Kim             return;
943ff879b07SJung-uk Kim         }
944ff879b07SJung-uk Kim 
945ff879b07SJung-uk Kim         Offset += sizeof (ACPI_DRTM_RESOURCE);
946ff879b07SJung-uk Kim         Count++;
947ff879b07SJung-uk Kim     }
948ff879b07SJung-uk Kim 
949ff879b07SJung-uk Kim     /* Dump DPS */
950ff879b07SJung-uk Kim 
951ff879b07SJung-uk Kim     DrtmDps = ACPI_ADD_PTR (ACPI_DRTM_DPS_ID, Table, Offset);
952ff879b07SJung-uk Kim     AcpiOsPrintf ("\n");
953ff879b07SJung-uk Kim     (void) AcpiDmDumpTable (Table->Length, Offset,
954ff879b07SJung-uk Kim         DrtmDps, sizeof (ACPI_DRTM_DPS_ID), AcpiDmTableInfoDrtm2);
955ff879b07SJung-uk Kim }
956ff879b07SJung-uk Kim 
957ff879b07SJung-uk Kim 
958ff879b07SJung-uk Kim /*******************************************************************************
959ff879b07SJung-uk Kim  *
960ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpEinj
961ff879b07SJung-uk Kim  *
962ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A EINJ table
963ff879b07SJung-uk Kim  *
964ff879b07SJung-uk Kim  * RETURN:      None
965ff879b07SJung-uk Kim  *
966ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a EINJ. This table type consists
967ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
968ff879b07SJung-uk Kim  *
969ff879b07SJung-uk Kim  ******************************************************************************/
970ff879b07SJung-uk Kim 
971ff879b07SJung-uk Kim void
972ff879b07SJung-uk Kim AcpiDmDumpEinj (
973ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
974ff879b07SJung-uk Kim {
975ff879b07SJung-uk Kim     ACPI_STATUS             Status;
976ff879b07SJung-uk Kim     ACPI_WHEA_HEADER        *Subtable;
977ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
978ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_EINJ);
979ff879b07SJung-uk Kim 
980ff879b07SJung-uk Kim 
981ff879b07SJung-uk Kim     /* Main table */
982ff879b07SJung-uk Kim 
983ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoEinj);
984ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
985ff879b07SJung-uk Kim     {
986ff879b07SJung-uk Kim         return;
987ff879b07SJung-uk Kim     }
988ff879b07SJung-uk Kim 
989ff879b07SJung-uk Kim     /* Subtables */
990ff879b07SJung-uk Kim 
991ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_WHEA_HEADER, Table, Offset);
992ff879b07SJung-uk Kim     while (Offset < Table->Length)
993ff879b07SJung-uk Kim     {
994ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
995ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
996ff879b07SJung-uk Kim             sizeof (ACPI_WHEA_HEADER), AcpiDmTableInfoEinj0);
997ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
998ff879b07SJung-uk Kim         {
999ff879b07SJung-uk Kim             return;
1000ff879b07SJung-uk Kim         }
1001ff879b07SJung-uk Kim 
1002ff879b07SJung-uk Kim         /* Point to next subtable (each subtable is of fixed length) */
1003ff879b07SJung-uk Kim 
1004ff879b07SJung-uk Kim         Offset += sizeof (ACPI_WHEA_HEADER);
1005ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_WHEA_HEADER, Subtable,
1006ff879b07SJung-uk Kim             sizeof (ACPI_WHEA_HEADER));
1007ff879b07SJung-uk Kim     }
1008ff879b07SJung-uk Kim }
1009ff879b07SJung-uk Kim 
1010ff879b07SJung-uk Kim 
1011ff879b07SJung-uk Kim /*******************************************************************************
1012ff879b07SJung-uk Kim  *
1013ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpErst
1014ff879b07SJung-uk Kim  *
1015ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A ERST table
1016ff879b07SJung-uk Kim  *
1017ff879b07SJung-uk Kim  * RETURN:      None
1018ff879b07SJung-uk Kim  *
1019ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a ERST. This table type consists
1020ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
1021ff879b07SJung-uk Kim  *
1022ff879b07SJung-uk Kim  ******************************************************************************/
1023ff879b07SJung-uk Kim 
1024ff879b07SJung-uk Kim void
1025ff879b07SJung-uk Kim AcpiDmDumpErst (
1026ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
1027ff879b07SJung-uk Kim {
1028ff879b07SJung-uk Kim     ACPI_STATUS             Status;
1029ff879b07SJung-uk Kim     ACPI_WHEA_HEADER        *Subtable;
1030ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
1031ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_ERST);
1032ff879b07SJung-uk Kim 
1033ff879b07SJung-uk Kim 
1034ff879b07SJung-uk Kim     /* Main table */
1035ff879b07SJung-uk Kim 
1036ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoErst);
1037ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
1038ff879b07SJung-uk Kim     {
1039ff879b07SJung-uk Kim         return;
1040ff879b07SJung-uk Kim     }
1041ff879b07SJung-uk Kim 
1042ff879b07SJung-uk Kim     /* Subtables */
1043ff879b07SJung-uk Kim 
1044ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_WHEA_HEADER, Table, Offset);
1045ff879b07SJung-uk Kim     while (Offset < Table->Length)
1046ff879b07SJung-uk Kim     {
1047ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
1048ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
1049ff879b07SJung-uk Kim             sizeof (ACPI_WHEA_HEADER), AcpiDmTableInfoErst0);
1050ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1051ff879b07SJung-uk Kim         {
1052ff879b07SJung-uk Kim             return;
1053ff879b07SJung-uk Kim         }
1054ff879b07SJung-uk Kim 
1055ff879b07SJung-uk Kim         /* Point to next subtable (each subtable is of fixed length) */
1056ff879b07SJung-uk Kim 
1057ff879b07SJung-uk Kim         Offset += sizeof (ACPI_WHEA_HEADER);
1058ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_WHEA_HEADER, Subtable,
1059ff879b07SJung-uk Kim             sizeof (ACPI_WHEA_HEADER));
1060ff879b07SJung-uk Kim     }
1061ff879b07SJung-uk Kim }
1062ff879b07SJung-uk Kim 
1063ff879b07SJung-uk Kim 
1064ff879b07SJung-uk Kim /*******************************************************************************
1065ff879b07SJung-uk Kim  *
1066ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpFpdt
1067ff879b07SJung-uk Kim  *
1068ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A FPDT table
1069ff879b07SJung-uk Kim  *
1070ff879b07SJung-uk Kim  * RETURN:      None
1071ff879b07SJung-uk Kim  *
1072ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a FPDT. This table type consists
1073ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
1074ff879b07SJung-uk Kim  *
1075ff879b07SJung-uk Kim  ******************************************************************************/
1076ff879b07SJung-uk Kim 
1077ff879b07SJung-uk Kim void
1078ff879b07SJung-uk Kim AcpiDmDumpFpdt (
1079ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
1080ff879b07SJung-uk Kim {
1081ff879b07SJung-uk Kim     ACPI_STATUS             Status;
1082ff879b07SJung-uk Kim     ACPI_FPDT_HEADER        *Subtable;
1083ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
1084ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_FPDT);
1085ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
1086ff879b07SJung-uk Kim 
1087ff879b07SJung-uk Kim 
1088ff879b07SJung-uk Kim     /* There is no main table (other than the standard ACPI header) */
1089ff879b07SJung-uk Kim 
1090ff879b07SJung-uk Kim     /* Subtables */
1091ff879b07SJung-uk Kim 
1092ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_FPDT_HEADER, Table, Offset);
1093ff879b07SJung-uk Kim     while (Offset < Table->Length)
1094ff879b07SJung-uk Kim     {
1095ff879b07SJung-uk Kim         /* Common subtable header */
1096ff879b07SJung-uk Kim 
1097ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
1098ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
1099ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoFpdtHdr);
1100ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1101ff879b07SJung-uk Kim         {
1102ff879b07SJung-uk Kim             return;
1103ff879b07SJung-uk Kim         }
1104ff879b07SJung-uk Kim 
1105ff879b07SJung-uk Kim         switch (Subtable->Type)
1106ff879b07SJung-uk Kim         {
1107ff879b07SJung-uk Kim         case ACPI_FPDT_TYPE_BOOT:
1108ff879b07SJung-uk Kim 
1109ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoFpdt0;
1110ff879b07SJung-uk Kim             break;
1111ff879b07SJung-uk Kim 
1112ff879b07SJung-uk Kim         case ACPI_FPDT_TYPE_S3PERF:
1113ff879b07SJung-uk Kim 
1114ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoFpdt1;
1115ff879b07SJung-uk Kim             break;
1116ff879b07SJung-uk Kim 
1117ff879b07SJung-uk Kim         default:
1118ff879b07SJung-uk Kim 
1119ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown FPDT subtable type 0x%X\n\n",
1120ff879b07SJung-uk Kim                 Subtable->Type);
1121ff879b07SJung-uk Kim 
1122ff879b07SJung-uk Kim             /* Attempt to continue */
1123ff879b07SJung-uk Kim 
1124ff879b07SJung-uk Kim             if (!Subtable->Length)
1125ff879b07SJung-uk Kim             {
1126ff879b07SJung-uk Kim                 AcpiOsPrintf ("Invalid zero length subtable\n");
1127ff879b07SJung-uk Kim                 return;
1128ff879b07SJung-uk Kim             }
1129ff879b07SJung-uk Kim             goto NextSubtable;
1130ff879b07SJung-uk Kim         }
1131ff879b07SJung-uk Kim 
1132ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
1133ff879b07SJung-uk Kim             Subtable->Length, InfoTable);
1134ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1135ff879b07SJung-uk Kim         {
1136ff879b07SJung-uk Kim             return;
1137ff879b07SJung-uk Kim         }
1138ff879b07SJung-uk Kim 
1139ff879b07SJung-uk Kim NextSubtable:
1140ff879b07SJung-uk Kim         /* Point to next subtable */
1141ff879b07SJung-uk Kim 
1142ff879b07SJung-uk Kim         Offset += Subtable->Length;
1143ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_FPDT_HEADER, Subtable,
1144ff879b07SJung-uk Kim             Subtable->Length);
1145ff879b07SJung-uk Kim     }
1146ff879b07SJung-uk Kim }
1147ff879b07SJung-uk Kim 
1148ff879b07SJung-uk Kim 
1149ff879b07SJung-uk Kim /*******************************************************************************
1150ff879b07SJung-uk Kim  *
1151ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpGtdt
1152ff879b07SJung-uk Kim  *
1153ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A GTDT table
1154ff879b07SJung-uk Kim  *
1155ff879b07SJung-uk Kim  * RETURN:      None
1156ff879b07SJung-uk Kim  *
1157ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a GTDT. This table type consists
1158ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
1159ff879b07SJung-uk Kim  *
1160ff879b07SJung-uk Kim  ******************************************************************************/
1161ff879b07SJung-uk Kim 
1162ff879b07SJung-uk Kim void
1163ff879b07SJung-uk Kim AcpiDmDumpGtdt (
1164ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
1165ff879b07SJung-uk Kim {
1166ff879b07SJung-uk Kim     ACPI_STATUS             Status;
1167ff879b07SJung-uk Kim     ACPI_GTDT_HEADER        *Subtable;
1168ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
1169ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_GTDT);
1170ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
1171ff879b07SJung-uk Kim     UINT32                  SubtableLength;
1172ff879b07SJung-uk Kim     UINT32                  GtCount;
1173ff879b07SJung-uk Kim     ACPI_GTDT_TIMER_ENTRY   *GtxTable;
1174ff879b07SJung-uk Kim 
1175ff879b07SJung-uk Kim 
1176ff879b07SJung-uk Kim     /* Main table */
1177ff879b07SJung-uk Kim 
1178ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoGtdt);
1179ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
1180ff879b07SJung-uk Kim     {
1181ff879b07SJung-uk Kim         return;
1182ff879b07SJung-uk Kim     }
1183ff879b07SJung-uk Kim 
1184cd6518c7SJung-uk Kim     /* Rev 3 fields */
1185ff879b07SJung-uk Kim 
1186ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_GTDT_HEADER, Table, Offset);
1187cd6518c7SJung-uk Kim 
1188cd6518c7SJung-uk Kim     if (Table->Revision > 2)
1189cd6518c7SJung-uk Kim     {
1190cd6518c7SJung-uk Kim         SubtableLength = sizeof (ACPI_GTDT_EL2);
1191cd6518c7SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
1192cd6518c7SJung-uk Kim             SubtableLength, AcpiDmTableInfoGtdtEl2);
1193cd6518c7SJung-uk Kim         if (ACPI_FAILURE (Status))
1194cd6518c7SJung-uk Kim         {
1195cd6518c7SJung-uk Kim             return;
1196cd6518c7SJung-uk Kim         }
1197cd6518c7SJung-uk Kim         Offset += SubtableLength;
1198cd6518c7SJung-uk Kim     }
1199cd6518c7SJung-uk Kim 
1200cd6518c7SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_GTDT_HEADER, Table, Offset);
1201cd6518c7SJung-uk Kim 
1202cd6518c7SJung-uk Kim     /* Subtables */
1203cd6518c7SJung-uk Kim 
1204ff879b07SJung-uk Kim     while (Offset < Table->Length)
1205ff879b07SJung-uk Kim     {
1206ff879b07SJung-uk Kim         /* Common subtable header */
1207ff879b07SJung-uk Kim 
1208ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
1209ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
1210ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoGtdtHdr);
1211ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1212ff879b07SJung-uk Kim         {
1213ff879b07SJung-uk Kim             return;
1214ff879b07SJung-uk Kim         }
1215ff879b07SJung-uk Kim 
1216ff879b07SJung-uk Kim         GtCount = 0;
1217ff879b07SJung-uk Kim         switch (Subtable->Type)
1218ff879b07SJung-uk Kim         {
1219ff879b07SJung-uk Kim         case ACPI_GTDT_TYPE_TIMER_BLOCK:
1220ff879b07SJung-uk Kim 
1221ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_GTDT_TIMER_BLOCK);
1222ff879b07SJung-uk Kim             GtCount = (ACPI_CAST_PTR (ACPI_GTDT_TIMER_BLOCK,
1223ff879b07SJung-uk Kim                 Subtable))->TimerCount;
1224ff879b07SJung-uk Kim 
1225ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoGtdt0;
1226ff879b07SJung-uk Kim             break;
1227ff879b07SJung-uk Kim 
1228ff879b07SJung-uk Kim         case ACPI_GTDT_TYPE_WATCHDOG:
1229ff879b07SJung-uk Kim 
1230ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_GTDT_WATCHDOG);
1231ff879b07SJung-uk Kim 
1232ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoGtdt1;
1233ff879b07SJung-uk Kim             break;
1234ff879b07SJung-uk Kim 
1235ff879b07SJung-uk Kim         default:
1236ff879b07SJung-uk Kim 
1237ff879b07SJung-uk Kim             /* Cannot continue on unknown type - no length */
1238ff879b07SJung-uk Kim 
1239ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown GTDT subtable type 0x%X\n",
1240ff879b07SJung-uk Kim                 Subtable->Type);
1241ff879b07SJung-uk Kim             return;
1242ff879b07SJung-uk Kim         }
1243ff879b07SJung-uk Kim 
1244ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
1245ff879b07SJung-uk Kim             Subtable->Length, InfoTable);
1246ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1247ff879b07SJung-uk Kim         {
1248ff879b07SJung-uk Kim             return;
1249ff879b07SJung-uk Kim         }
1250ff879b07SJung-uk Kim 
1251ff879b07SJung-uk Kim         /* Point to end of current subtable (each subtable above is of fixed length) */
1252ff879b07SJung-uk Kim 
1253ff879b07SJung-uk Kim         Offset += SubtableLength;
1254ff879b07SJung-uk Kim 
1255ff879b07SJung-uk Kim         /* If there are any Gt Timer Blocks from above, dump them now */
1256ff879b07SJung-uk Kim 
1257ff879b07SJung-uk Kim         if (GtCount)
1258ff879b07SJung-uk Kim         {
1259ff879b07SJung-uk Kim             GtxTable = ACPI_ADD_PTR (
1260ff879b07SJung-uk Kim                 ACPI_GTDT_TIMER_ENTRY, Subtable, SubtableLength);
1261ff879b07SJung-uk Kim             SubtableLength += GtCount * sizeof (ACPI_GTDT_TIMER_ENTRY);
1262ff879b07SJung-uk Kim 
1263ff879b07SJung-uk Kim             while (GtCount)
1264ff879b07SJung-uk Kim             {
1265ff879b07SJung-uk Kim                 AcpiOsPrintf ("\n");
1266ff879b07SJung-uk Kim                 Status = AcpiDmDumpTable (Length, Offset, GtxTable,
1267ff879b07SJung-uk Kim                     sizeof (ACPI_GTDT_TIMER_ENTRY), AcpiDmTableInfoGtdt0a);
1268ff879b07SJung-uk Kim                 if (ACPI_FAILURE (Status))
1269ff879b07SJung-uk Kim                 {
1270ff879b07SJung-uk Kim                     return;
1271ff879b07SJung-uk Kim                 }
1272ff879b07SJung-uk Kim                 Offset += sizeof (ACPI_GTDT_TIMER_ENTRY);
1273ff879b07SJung-uk Kim                 GtxTable++;
1274ff879b07SJung-uk Kim                 GtCount--;
1275ff879b07SJung-uk Kim             }
1276ff879b07SJung-uk Kim         }
1277ff879b07SJung-uk Kim 
1278ff879b07SJung-uk Kim         /* Point to next subtable */
1279ff879b07SJung-uk Kim 
1280ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_GTDT_HEADER, Subtable, SubtableLength);
1281ff879b07SJung-uk Kim     }
1282ff879b07SJung-uk Kim }
1283ff879b07SJung-uk Kim 
1284ff879b07SJung-uk Kim 
1285ff879b07SJung-uk Kim /*******************************************************************************
1286ff879b07SJung-uk Kim  *
1287ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpHest
1288ff879b07SJung-uk Kim  *
1289ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A HEST table
1290ff879b07SJung-uk Kim  *
1291ff879b07SJung-uk Kim  * RETURN:      None
1292ff879b07SJung-uk Kim  *
1293ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a HEST. This table type consists
1294ff879b07SJung-uk Kim  *              of an open-ended number of subtables.
1295ff879b07SJung-uk Kim  *
1296ff879b07SJung-uk Kim  ******************************************************************************/
1297ff879b07SJung-uk Kim 
1298ff879b07SJung-uk Kim void
1299ff879b07SJung-uk Kim AcpiDmDumpHest (
1300ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
1301ff879b07SJung-uk Kim {
1302ff879b07SJung-uk Kim     ACPI_STATUS             Status;
1303ff879b07SJung-uk Kim     ACPI_HEST_HEADER        *Subtable;
1304ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
1305ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_HEST);
1306ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
1307ff879b07SJung-uk Kim     UINT32                  SubtableLength;
1308ff879b07SJung-uk Kim     UINT32                  BankCount;
1309ff879b07SJung-uk Kim     ACPI_HEST_IA_ERROR_BANK *BankTable;
1310ff879b07SJung-uk Kim 
1311ff879b07SJung-uk Kim 
1312ff879b07SJung-uk Kim     /* Main table */
1313ff879b07SJung-uk Kim 
1314ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoHest);
1315ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
1316ff879b07SJung-uk Kim     {
1317ff879b07SJung-uk Kim         return;
1318ff879b07SJung-uk Kim     }
1319ff879b07SJung-uk Kim 
1320ff879b07SJung-uk Kim     /* Subtables */
1321ff879b07SJung-uk Kim 
1322ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_HEST_HEADER, Table, Offset);
1323ff879b07SJung-uk Kim     while (Offset < Table->Length)
1324ff879b07SJung-uk Kim     {
1325ff879b07SJung-uk Kim         BankCount = 0;
1326ff879b07SJung-uk Kim         switch (Subtable->Type)
1327ff879b07SJung-uk Kim         {
1328ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_IA32_CHECK:
1329ff879b07SJung-uk Kim 
1330ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest0;
1331ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_IA_MACHINE_CHECK);
1332ff879b07SJung-uk Kim             BankCount = (ACPI_CAST_PTR (ACPI_HEST_IA_MACHINE_CHECK,
1333ff879b07SJung-uk Kim                 Subtable))->NumHardwareBanks;
1334ff879b07SJung-uk Kim             break;
1335ff879b07SJung-uk Kim 
1336ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_IA32_CORRECTED_CHECK:
1337ff879b07SJung-uk Kim 
1338ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest1;
1339ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_IA_CORRECTED);
1340ff879b07SJung-uk Kim             BankCount = (ACPI_CAST_PTR (ACPI_HEST_IA_CORRECTED,
1341ff879b07SJung-uk Kim                 Subtable))->NumHardwareBanks;
1342ff879b07SJung-uk Kim             break;
1343ff879b07SJung-uk Kim 
1344ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_IA32_NMI:
1345ff879b07SJung-uk Kim 
1346ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest2;
1347ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_IA_NMI);
1348ff879b07SJung-uk Kim             break;
1349ff879b07SJung-uk Kim 
1350ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_AER_ROOT_PORT:
1351ff879b07SJung-uk Kim 
1352ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest6;
1353ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_AER_ROOT);
1354ff879b07SJung-uk Kim             break;
1355ff879b07SJung-uk Kim 
1356ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_AER_ENDPOINT:
1357ff879b07SJung-uk Kim 
1358ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest7;
1359ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_AER);
1360ff879b07SJung-uk Kim             break;
1361ff879b07SJung-uk Kim 
1362ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_AER_BRIDGE:
1363ff879b07SJung-uk Kim 
1364ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest8;
1365ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_AER_BRIDGE);
1366ff879b07SJung-uk Kim             break;
1367ff879b07SJung-uk Kim 
1368ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_GENERIC_ERROR:
1369ff879b07SJung-uk Kim 
1370ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest9;
1371ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_GENERIC);
1372ff879b07SJung-uk Kim             break;
1373ff879b07SJung-uk Kim 
1374ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_GENERIC_ERROR_V2:
1375ff879b07SJung-uk Kim 
1376ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest10;
1377ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_GENERIC_V2);
1378ff879b07SJung-uk Kim             break;
1379ff879b07SJung-uk Kim 
1380ff879b07SJung-uk Kim         case ACPI_HEST_TYPE_IA32_DEFERRED_CHECK:
1381ff879b07SJung-uk Kim 
1382ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHest11;
1383ff879b07SJung-uk Kim             SubtableLength = sizeof (ACPI_HEST_IA_DEFERRED_CHECK);
1384ff879b07SJung-uk Kim             BankCount = (ACPI_CAST_PTR (ACPI_HEST_IA_DEFERRED_CHECK,
1385ff879b07SJung-uk Kim                 Subtable))->NumHardwareBanks;
1386ff879b07SJung-uk Kim             break;
1387ff879b07SJung-uk Kim 
1388ff879b07SJung-uk Kim         default:
1389ff879b07SJung-uk Kim 
1390ff879b07SJung-uk Kim             /* Cannot continue on unknown type - no length */
1391ff879b07SJung-uk Kim 
1392ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown HEST subtable type 0x%X\n",
1393ff879b07SJung-uk Kim                 Subtable->Type);
1394ff879b07SJung-uk Kim             return;
1395ff879b07SJung-uk Kim         }
1396ff879b07SJung-uk Kim 
1397ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
1398ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Length, Offset, Subtable,
1399ff879b07SJung-uk Kim             SubtableLength, InfoTable);
1400ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1401ff879b07SJung-uk Kim         {
1402ff879b07SJung-uk Kim             return;
1403ff879b07SJung-uk Kim         }
1404ff879b07SJung-uk Kim 
1405ff879b07SJung-uk Kim         /* Point to end of current subtable (each subtable above is of fixed length) */
1406ff879b07SJung-uk Kim 
1407ff879b07SJung-uk Kim         Offset += SubtableLength;
1408ff879b07SJung-uk Kim 
1409ff879b07SJung-uk Kim         /* If there are any (fixed-length) Error Banks from above, dump them now */
1410ff879b07SJung-uk Kim 
1411ff879b07SJung-uk Kim         if (BankCount)
1412ff879b07SJung-uk Kim         {
1413ff879b07SJung-uk Kim             BankTable = ACPI_ADD_PTR (ACPI_HEST_IA_ERROR_BANK, Subtable,
1414ff879b07SJung-uk Kim                 SubtableLength);
1415ff879b07SJung-uk Kim             SubtableLength += BankCount * sizeof (ACPI_HEST_IA_ERROR_BANK);
1416ff879b07SJung-uk Kim 
1417ff879b07SJung-uk Kim             while (BankCount)
1418ff879b07SJung-uk Kim             {
1419ff879b07SJung-uk Kim                 AcpiOsPrintf ("\n");
1420ff879b07SJung-uk Kim                 Status = AcpiDmDumpTable (Length, Offset, BankTable,
1421ff879b07SJung-uk Kim                     sizeof (ACPI_HEST_IA_ERROR_BANK), AcpiDmTableInfoHestBank);
1422ff879b07SJung-uk Kim                 if (ACPI_FAILURE (Status))
1423ff879b07SJung-uk Kim                 {
1424ff879b07SJung-uk Kim                     return;
1425ff879b07SJung-uk Kim                 }
1426ff879b07SJung-uk Kim 
1427ff879b07SJung-uk Kim                 Offset += sizeof (ACPI_HEST_IA_ERROR_BANK);
1428ff879b07SJung-uk Kim                 BankTable++;
1429ff879b07SJung-uk Kim                 BankCount--;
1430ff879b07SJung-uk Kim             }
1431ff879b07SJung-uk Kim         }
1432ff879b07SJung-uk Kim 
1433ff879b07SJung-uk Kim         /* Point to next subtable */
1434ff879b07SJung-uk Kim 
1435ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_HEST_HEADER, Subtable, SubtableLength);
1436ff879b07SJung-uk Kim     }
1437ff879b07SJung-uk Kim }
1438ff879b07SJung-uk Kim 
1439ff879b07SJung-uk Kim 
1440ff879b07SJung-uk Kim /*******************************************************************************
1441ff879b07SJung-uk Kim  *
1442ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpHmat
1443ff879b07SJung-uk Kim  *
1444ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A HMAT table
1445ff879b07SJung-uk Kim  *
1446ff879b07SJung-uk Kim  * RETURN:      None
1447ff879b07SJung-uk Kim  *
1448ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a HMAT.
1449ff879b07SJung-uk Kim  *
1450ff879b07SJung-uk Kim  ******************************************************************************/
1451ff879b07SJung-uk Kim 
1452ff879b07SJung-uk Kim void
1453ff879b07SJung-uk Kim AcpiDmDumpHmat (
1454ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
1455ff879b07SJung-uk Kim {
1456ff879b07SJung-uk Kim     ACPI_STATUS             Status;
1457ff879b07SJung-uk Kim     ACPI_HMAT_STRUCTURE     *HmatStruct;
1458ff879b07SJung-uk Kim     ACPI_HMAT_LOCALITY      *HmatLocality;
1459ff879b07SJung-uk Kim     ACPI_HMAT_CACHE         *HmatCache;
1460ff879b07SJung-uk Kim     UINT32                  Offset;
1461ff879b07SJung-uk Kim     UINT32                  SubtableOffset;
1462ff879b07SJung-uk Kim     UINT32                  Length;
1463ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
1464ff879b07SJung-uk Kim     UINT32                  i, j;
1465ff879b07SJung-uk Kim 
1466ff879b07SJung-uk Kim 
1467ff879b07SJung-uk Kim     /* Main table */
1468ff879b07SJung-uk Kim 
1469ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoHmat);
1470ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
1471ff879b07SJung-uk Kim     {
1472ff879b07SJung-uk Kim         return;
1473ff879b07SJung-uk Kim     }
1474ff879b07SJung-uk Kim     Offset = sizeof (ACPI_TABLE_HMAT);
1475ff879b07SJung-uk Kim 
1476ff879b07SJung-uk Kim     while (Offset < Table->Length)
1477ff879b07SJung-uk Kim     {
1478ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
1479ff879b07SJung-uk Kim 
1480ff879b07SJung-uk Kim         /* Dump HMAT structure header */
1481ff879b07SJung-uk Kim 
1482ff879b07SJung-uk Kim         HmatStruct = ACPI_ADD_PTR (ACPI_HMAT_STRUCTURE, Table, Offset);
1483ff879b07SJung-uk Kim         if (HmatStruct->Length < sizeof (ACPI_HMAT_STRUCTURE))
1484ff879b07SJung-uk Kim         {
1485ff879b07SJung-uk Kim             AcpiOsPrintf ("Invalid HMAT structure length\n");
1486ff879b07SJung-uk Kim             return;
1487ff879b07SJung-uk Kim         }
1488ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, HmatStruct,
1489ff879b07SJung-uk Kim             HmatStruct->Length, AcpiDmTableInfoHmatHdr);
1490ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1491ff879b07SJung-uk Kim         {
1492ff879b07SJung-uk Kim             return;
1493ff879b07SJung-uk Kim         }
1494ff879b07SJung-uk Kim 
1495ff879b07SJung-uk Kim         switch (HmatStruct->Type)
1496ff879b07SJung-uk Kim         {
1497ff879b07SJung-uk Kim         case ACPI_HMAT_TYPE_ADDRESS_RANGE:
1498ff879b07SJung-uk Kim 
1499ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHmat0;
1500cd6518c7SJung-uk Kim             Length = sizeof (ACPI_HMAT_PROXIMITY_DOMAIN);
1501ff879b07SJung-uk Kim             break;
1502ff879b07SJung-uk Kim 
1503ff879b07SJung-uk Kim         case ACPI_HMAT_TYPE_LOCALITY:
1504ff879b07SJung-uk Kim 
1505ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHmat1;
1506ff879b07SJung-uk Kim             Length = sizeof (ACPI_HMAT_LOCALITY);
1507ff879b07SJung-uk Kim             break;
1508ff879b07SJung-uk Kim 
1509ff879b07SJung-uk Kim         case ACPI_HMAT_TYPE_CACHE:
1510ff879b07SJung-uk Kim 
1511ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoHmat2;
1512ff879b07SJung-uk Kim             Length = sizeof (ACPI_HMAT_CACHE);
1513ff879b07SJung-uk Kim             break;
1514ff879b07SJung-uk Kim 
1515ff879b07SJung-uk Kim         default:
1516ff879b07SJung-uk Kim 
1517ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown HMAT structure type 0x%X\n",
1518ff879b07SJung-uk Kim                 HmatStruct->Type);
1519ff879b07SJung-uk Kim 
1520ff879b07SJung-uk Kim             /* Attempt to continue */
1521ff879b07SJung-uk Kim 
1522ff879b07SJung-uk Kim             goto NextSubtable;
1523ff879b07SJung-uk Kim         }
1524ff879b07SJung-uk Kim 
1525ff879b07SJung-uk Kim         /* Dump HMAT structure body */
1526ff879b07SJung-uk Kim 
1527ff879b07SJung-uk Kim         if (HmatStruct->Length < Length)
1528ff879b07SJung-uk Kim         {
1529ff879b07SJung-uk Kim             AcpiOsPrintf ("Invalid HMAT structure length\n");
1530ff879b07SJung-uk Kim             return;
1531ff879b07SJung-uk Kim         }
1532ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, HmatStruct,
1533ff879b07SJung-uk Kim             HmatStruct->Length, InfoTable);
1534ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
1535ff879b07SJung-uk Kim         {
1536ff879b07SJung-uk Kim             return;
1537ff879b07SJung-uk Kim         }
1538ff879b07SJung-uk Kim 
1539ff879b07SJung-uk Kim         /* Dump HMAT structure additionals */
1540ff879b07SJung-uk Kim 
1541ff879b07SJung-uk Kim         switch (HmatStruct->Type)
1542ff879b07SJung-uk Kim         {
1543ff879b07SJung-uk Kim         case ACPI_HMAT_TYPE_LOCALITY:
1544ff879b07SJung-uk Kim 
1545ff879b07SJung-uk Kim             HmatLocality = ACPI_CAST_PTR (ACPI_HMAT_LOCALITY, HmatStruct);
1546ff879b07SJung-uk Kim             SubtableOffset = sizeof (ACPI_HMAT_LOCALITY);
1547ff879b07SJung-uk Kim 
1548ff879b07SJung-uk Kim             /* Dump initiator proximity domains */
1549ff879b07SJung-uk Kim 
1550ff879b07SJung-uk Kim             if ((UINT32)(HmatStruct->Length - SubtableOffset) <
1551ff879b07SJung-uk Kim                 (UINT32)(HmatLocality->NumberOfInitiatorPDs * 4))
1552ff879b07SJung-uk Kim             {
1553ff879b07SJung-uk Kim                 AcpiOsPrintf ("Invalid initiator proximity domain number\n");
1554ff879b07SJung-uk Kim                 return;
1555ff879b07SJung-uk Kim             }
1556ff879b07SJung-uk Kim             for (i = 0; i < HmatLocality->NumberOfInitiatorPDs; i++)
1557ff879b07SJung-uk Kim             {
1558ff879b07SJung-uk Kim                 Status = AcpiDmDumpTable (Table->Length, Offset + SubtableOffset,
1559ff879b07SJung-uk Kim                     ACPI_ADD_PTR (ACPI_HMAT_STRUCTURE, HmatStruct, SubtableOffset),
1560ff879b07SJung-uk Kim                     4, AcpiDmTableInfoHmat1a);
1561a009b7dcSJung-uk Kim                 if (ACPI_FAILURE (Status))
1562a009b7dcSJung-uk Kim                 {
1563a009b7dcSJung-uk Kim                     return;
1564a009b7dcSJung-uk Kim                 }
1565a009b7dcSJung-uk Kim 
1566ff879b07SJung-uk Kim                 SubtableOffset += 4;
1567ff879b07SJung-uk Kim             }
1568ff879b07SJung-uk Kim 
1569ff879b07SJung-uk Kim             /* Dump target proximity domains */
1570ff879b07SJung-uk Kim 
1571ff879b07SJung-uk Kim             if ((UINT32)(HmatStruct->Length - SubtableOffset) <
1572ff879b07SJung-uk Kim                 (UINT32)(HmatLocality->NumberOfTargetPDs * 4))
1573ff879b07SJung-uk Kim             {
1574ff879b07SJung-uk Kim                 AcpiOsPrintf ("Invalid target proximity domain number\n");
1575ff879b07SJung-uk Kim                 return;
1576ff879b07SJung-uk Kim             }
1577ff879b07SJung-uk Kim             for (i = 0; i < HmatLocality->NumberOfTargetPDs; i++)
1578ff879b07SJung-uk Kim             {
1579ff879b07SJung-uk Kim                 Status = AcpiDmDumpTable (Table->Length, Offset + SubtableOffset,
1580ff879b07SJung-uk Kim                     ACPI_ADD_PTR (ACPI_HMAT_STRUCTURE, HmatStruct, SubtableOffset),
1581ff879b07SJung-uk Kim                     4, AcpiDmTableInfoHmat1b);
1582a009b7dcSJung-uk Kim                 if (ACPI_FAILURE (Status))
1583a009b7dcSJung-uk Kim                 {
1584a009b7dcSJung-uk Kim                     return;
1585a009b7dcSJung-uk Kim                 }
1586a009b7dcSJung-uk Kim 
1587ff879b07SJung-uk Kim                 SubtableOffset += 4;
1588ff879b07SJung-uk Kim             }
1589ff879b07SJung-uk Kim 
1590ff879b07SJung-uk Kim             /* Dump latency/bandwidth entris */
1591ff879b07SJung-uk Kim 
1592ff879b07SJung-uk Kim             if ((UINT32)(HmatStruct->Length - SubtableOffset) <
1593ff879b07SJung-uk Kim                 (UINT32)(HmatLocality->NumberOfInitiatorPDs *
1594ff879b07SJung-uk Kim                          HmatLocality->NumberOfTargetPDs * 2))
1595ff879b07SJung-uk Kim             {
1596ff879b07SJung-uk Kim                 AcpiOsPrintf ("Invalid latency/bandwidth entry number\n");
1597ff879b07SJung-uk Kim                 return;
1598ff879b07SJung-uk Kim             }
1599ff879b07SJung-uk Kim             for (i = 0; i < HmatLocality->NumberOfInitiatorPDs; i++)
1600ff879b07SJung-uk Kim             {
1601ff879b07SJung-uk Kim                 for (j = 0; j < HmatLocality->NumberOfTargetPDs; j++)
1602ff879b07SJung-uk Kim                 {
1603ff879b07SJung-uk Kim                     Status = AcpiDmDumpTable (Table->Length, Offset + SubtableOffset,
1604ff879b07SJung-uk Kim                         ACPI_ADD_PTR (ACPI_HMAT_STRUCTURE, HmatStruct, SubtableOffset),
1605ff879b07SJung-uk Kim                         2, AcpiDmTableInfoHmat1c);
1606a009b7dcSJung-uk Kim                     if (ACPI_FAILURE(Status))
1607a009b7dcSJung-uk Kim                     {
1608a009b7dcSJung-uk Kim                         return;
1609a009b7dcSJung-uk Kim                     }
1610a009b7dcSJung-uk Kim 
1611ff879b07SJung-uk Kim                     SubtableOffset += 2;
1612ff879b07SJung-uk Kim                 }
1613ff879b07SJung-uk Kim             }
1614ff879b07SJung-uk Kim             break;
1615ff879b07SJung-uk Kim 
1616ff879b07SJung-uk Kim         case ACPI_HMAT_TYPE_CACHE:
1617ff879b07SJung-uk Kim 
1618ff879b07SJung-uk Kim             HmatCache = ACPI_CAST_PTR (ACPI_HMAT_CACHE, HmatStruct);
1619ff879b07SJung-uk Kim             SubtableOffset = sizeof (ACPI_HMAT_CACHE);
1620ff879b07SJung-uk Kim 
1621ff879b07SJung-uk Kim             /* Dump SMBIOS handles */
1622ff879b07SJung-uk Kim 
1623ff879b07SJung-uk Kim             if ((UINT32)(HmatStruct->Length - SubtableOffset) <
1624ff879b07SJung-uk Kim                 (UINT32)(HmatCache->NumberOfSMBIOSHandles * 2))
1625ff879b07SJung-uk Kim             {
1626ff879b07SJung-uk Kim                 AcpiOsPrintf ("Invalid SMBIOS handle number\n");
1627ff879b07SJung-uk Kim                 return;
1628ff879b07SJung-uk Kim             }
1629ff879b07SJung-uk Kim             for (i = 0; i < HmatCache->NumberOfSMBIOSHandles; i++)
1630ff879b07SJung-uk Kim             {
1631ff879b07SJung-uk Kim                 Status = AcpiDmDumpTable (Table->Length, Offset + SubtableOffset,
1632ff879b07SJung-uk Kim                     ACPI_ADD_PTR (ACPI_HMAT_STRUCTURE, HmatStruct, SubtableOffset),
1633ff879b07SJung-uk Kim                     2, AcpiDmTableInfoHmat2a);
1634a009b7dcSJung-uk Kim                 if (ACPI_FAILURE (Status))
1635a009b7dcSJung-uk Kim                 {
1636a009b7dcSJung-uk Kim                     return;
1637a009b7dcSJung-uk Kim                 }
1638a009b7dcSJung-uk Kim 
1639ff879b07SJung-uk Kim                 SubtableOffset += 2;
1640ff879b07SJung-uk Kim             }
1641ff879b07SJung-uk Kim             break;
1642ff879b07SJung-uk Kim 
1643ff879b07SJung-uk Kim         default:
1644ff879b07SJung-uk Kim 
1645ff879b07SJung-uk Kim             break;
1646ff879b07SJung-uk Kim         }
1647ff879b07SJung-uk Kim 
1648ff879b07SJung-uk Kim NextSubtable:
1649ff879b07SJung-uk Kim         /* Point to next HMAT structure subtable */
1650ff879b07SJung-uk Kim 
1651ff879b07SJung-uk Kim         Offset += (HmatStruct->Length);
1652ff879b07SJung-uk Kim     }
1653ff879b07SJung-uk Kim }
1654