xref: /freebsd/sys/contrib/dev/acpica/common/dmtbdump3.c (revision 1970d69303946116e6c88ab5b903ae4b65efddc5)
1ff879b07SJung-uk Kim /******************************************************************************
2ff879b07SJung-uk Kim  *
3ff879b07SJung-uk Kim  * Module Name: dmtbdump3 - 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    ("dmtbdump3")
161ff879b07SJung-uk Kim 
162ff879b07SJung-uk Kim 
163ff879b07SJung-uk Kim /*******************************************************************************
164ff879b07SJung-uk Kim  *
165ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpSlic
166ff879b07SJung-uk Kim  *
167ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A SLIC table
168ff879b07SJung-uk Kim  *
169ff879b07SJung-uk Kim  * RETURN:      None
170ff879b07SJung-uk Kim  *
171ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a SLIC
172ff879b07SJung-uk Kim  *
173ff879b07SJung-uk Kim  ******************************************************************************/
174ff879b07SJung-uk Kim 
175ff879b07SJung-uk Kim void
176ff879b07SJung-uk Kim AcpiDmDumpSlic (
177ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
178ff879b07SJung-uk Kim {
179ff879b07SJung-uk Kim 
180ff879b07SJung-uk Kim     (void) AcpiDmDumpTable (Table->Length, sizeof (ACPI_TABLE_HEADER), Table,
181ff879b07SJung-uk Kim         Table->Length - sizeof (*Table), AcpiDmTableInfoSlic);
182ff879b07SJung-uk Kim }
183ff879b07SJung-uk Kim 
184ff879b07SJung-uk Kim 
185ff879b07SJung-uk Kim /*******************************************************************************
186ff879b07SJung-uk Kim  *
187ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpSlit
188ff879b07SJung-uk Kim  *
189ff879b07SJung-uk Kim  * PARAMETERS:  Table               - An SLIT
190ff879b07SJung-uk Kim  *
191ff879b07SJung-uk Kim  * RETURN:      None
192ff879b07SJung-uk Kim  *
193ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a SLIT
194ff879b07SJung-uk Kim  *
195ff879b07SJung-uk Kim  ******************************************************************************/
196ff879b07SJung-uk Kim 
197ff879b07SJung-uk Kim void
198ff879b07SJung-uk Kim AcpiDmDumpSlit (
199ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
200ff879b07SJung-uk Kim {
201ff879b07SJung-uk Kim     ACPI_STATUS             Status;
202ff879b07SJung-uk Kim     UINT32                  Offset;
203ff879b07SJung-uk Kim     UINT8                   *Row;
204ff879b07SJung-uk Kim     UINT32                  Localities;
205ff879b07SJung-uk Kim     UINT32                  i;
206ff879b07SJung-uk Kim     UINT32                  j;
207ff879b07SJung-uk Kim 
208ff879b07SJung-uk Kim 
209ff879b07SJung-uk Kim     /* Main table */
210ff879b07SJung-uk Kim 
211ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSlit);
212ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
213ff879b07SJung-uk Kim     {
214ff879b07SJung-uk Kim         return;
215ff879b07SJung-uk Kim     }
216ff879b07SJung-uk Kim 
217ff879b07SJung-uk Kim     /* Display the Locality NxN Matrix */
218ff879b07SJung-uk Kim 
219ff879b07SJung-uk Kim     Localities = (UINT32) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->LocalityCount;
220ff879b07SJung-uk Kim     Offset = ACPI_OFFSET (ACPI_TABLE_SLIT, Entry[0]);
221ff879b07SJung-uk Kim     Row = (UINT8 *) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->Entry;
222ff879b07SJung-uk Kim 
223ff879b07SJung-uk Kim     for (i = 0; i < Localities; i++)
224ff879b07SJung-uk Kim     {
225ff879b07SJung-uk Kim         /* Display one row of the matrix */
226ff879b07SJung-uk Kim 
227ff879b07SJung-uk Kim         AcpiDmLineHeader2 (Offset, Localities, "Locality", i);
228ff879b07SJung-uk Kim         for  (j = 0; j < Localities; j++)
229ff879b07SJung-uk Kim         {
230ff879b07SJung-uk Kim             /* Check for beyond EOT */
231ff879b07SJung-uk Kim 
232ff879b07SJung-uk Kim             if (Offset >= Table->Length)
233ff879b07SJung-uk Kim             {
234ff879b07SJung-uk Kim                 AcpiOsPrintf (
235ff879b07SJung-uk Kim                     "\n**** Not enough room in table for all localities\n");
236ff879b07SJung-uk Kim                 return;
237ff879b07SJung-uk Kim             }
238ff879b07SJung-uk Kim 
239ff879b07SJung-uk Kim             AcpiOsPrintf ("%2.2X", Row[j]);
240ff879b07SJung-uk Kim             Offset++;
241ff879b07SJung-uk Kim 
242ff879b07SJung-uk Kim             /* Display up to 16 bytes per output row */
243ff879b07SJung-uk Kim 
244ff879b07SJung-uk Kim             if ((j+1) < Localities)
245ff879b07SJung-uk Kim             {
246ff879b07SJung-uk Kim                 AcpiOsPrintf (" ");
247ff879b07SJung-uk Kim 
248ff879b07SJung-uk Kim                 if (j && (((j+1) % 16) == 0))
249ff879b07SJung-uk Kim                 {
250ff879b07SJung-uk Kim                     AcpiOsPrintf ("\\\n"); /* With line continuation char */
251ff879b07SJung-uk Kim                     AcpiDmLineHeader (Offset, 0, NULL);
252ff879b07SJung-uk Kim                 }
253ff879b07SJung-uk Kim             }
254ff879b07SJung-uk Kim         }
255ff879b07SJung-uk Kim 
256ff879b07SJung-uk Kim         /* Point to next row */
257ff879b07SJung-uk Kim 
258ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
259ff879b07SJung-uk Kim         Row += Localities;
260ff879b07SJung-uk Kim     }
261ff879b07SJung-uk Kim }
262ff879b07SJung-uk Kim 
263ff879b07SJung-uk Kim 
264ff879b07SJung-uk Kim /*******************************************************************************
265ff879b07SJung-uk Kim  *
266ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpSrat
267ff879b07SJung-uk Kim  *
268ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A SRAT table
269ff879b07SJung-uk Kim  *
270ff879b07SJung-uk Kim  * RETURN:      None
271ff879b07SJung-uk Kim  *
272ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a SRAT
273ff879b07SJung-uk Kim  *
274ff879b07SJung-uk Kim  ******************************************************************************/
275ff879b07SJung-uk Kim 
276ff879b07SJung-uk Kim void
277ff879b07SJung-uk Kim AcpiDmDumpSrat (
278ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
279ff879b07SJung-uk Kim {
280ff879b07SJung-uk Kim     ACPI_STATUS             Status;
281ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_SRAT);
282ff879b07SJung-uk Kim     ACPI_SUBTABLE_HEADER    *Subtable;
283ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
284ff879b07SJung-uk Kim 
285ff879b07SJung-uk Kim 
286ff879b07SJung-uk Kim     /* Main table */
287ff879b07SJung-uk Kim 
288ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSrat);
289ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
290ff879b07SJung-uk Kim     {
291ff879b07SJung-uk Kim         return;
292ff879b07SJung-uk Kim     }
293ff879b07SJung-uk Kim 
294ff879b07SJung-uk Kim     /* Subtables */
295ff879b07SJung-uk Kim 
296ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Table, Offset);
297ff879b07SJung-uk Kim     while (Offset < Table->Length)
298ff879b07SJung-uk Kim     {
299ff879b07SJung-uk Kim         /* Common subtable header */
300ff879b07SJung-uk Kim 
301ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
302ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
303ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoSratHdr);
304ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
305ff879b07SJung-uk Kim         {
306ff879b07SJung-uk Kim             return;
307ff879b07SJung-uk Kim         }
308ff879b07SJung-uk Kim 
309ff879b07SJung-uk Kim         switch (Subtable->Type)
310ff879b07SJung-uk Kim         {
311ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_CPU_AFFINITY:
312ff879b07SJung-uk Kim 
313ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat0;
314ff879b07SJung-uk Kim             break;
315ff879b07SJung-uk Kim 
316ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_MEMORY_AFFINITY:
317ff879b07SJung-uk Kim 
318ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat1;
319ff879b07SJung-uk Kim             break;
320ff879b07SJung-uk Kim 
321ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY:
322ff879b07SJung-uk Kim 
323ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat2;
324ff879b07SJung-uk Kim             break;
325ff879b07SJung-uk Kim 
326ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_GICC_AFFINITY:
327ff879b07SJung-uk Kim 
328ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat3;
329ff879b07SJung-uk Kim             break;
330ff879b07SJung-uk Kim 
331ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_GIC_ITS_AFFINITY:
332ff879b07SJung-uk Kim 
333ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat4;
334ff879b07SJung-uk Kim             break;
335ff879b07SJung-uk Kim 
336cd6518c7SJung-uk Kim         case ACPI_SRAT_TYPE_GENERIC_AFFINITY:
337cd6518c7SJung-uk Kim 
338cd6518c7SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat5;
339cd6518c7SJung-uk Kim             break;
340cd6518c7SJung-uk Kim 
341ff879b07SJung-uk Kim         default:
342ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown SRAT subtable type 0x%X\n",
343ff879b07SJung-uk Kim                 Subtable->Type);
344ff879b07SJung-uk Kim 
345ff879b07SJung-uk Kim             /* Attempt to continue */
346ff879b07SJung-uk Kim 
347ff879b07SJung-uk Kim             if (!Subtable->Length)
348ff879b07SJung-uk Kim             {
349ff879b07SJung-uk Kim                 AcpiOsPrintf ("Invalid zero length subtable\n");
350ff879b07SJung-uk Kim                 return;
351ff879b07SJung-uk Kim             }
352ff879b07SJung-uk Kim             goto NextSubtable;
353ff879b07SJung-uk Kim         }
354ff879b07SJung-uk Kim 
355ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
356ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
357ff879b07SJung-uk Kim             Subtable->Length, InfoTable);
358ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
359ff879b07SJung-uk Kim         {
360ff879b07SJung-uk Kim             return;
361ff879b07SJung-uk Kim         }
362ff879b07SJung-uk Kim 
363ff879b07SJung-uk Kim NextSubtable:
364ff879b07SJung-uk Kim         /* Point to next subtable */
365ff879b07SJung-uk Kim 
366ff879b07SJung-uk Kim         Offset += Subtable->Length;
367ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Subtable,
368ff879b07SJung-uk Kim             Subtable->Length);
369ff879b07SJung-uk Kim     }
370ff879b07SJung-uk Kim }
371ff879b07SJung-uk Kim 
372ff879b07SJung-uk Kim 
373ff879b07SJung-uk Kim /*******************************************************************************
374ff879b07SJung-uk Kim  *
375ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpStao
376ff879b07SJung-uk Kim  *
377ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A STAO table
378ff879b07SJung-uk Kim  *
379ff879b07SJung-uk Kim  * RETURN:      None
380ff879b07SJung-uk Kim  *
381ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a STAO. This is a variable-length
382ff879b07SJung-uk Kim  *              table that contains an open-ended number of ASCII strings
383ff879b07SJung-uk Kim  *              at the end of the table.
384ff879b07SJung-uk Kim  *
385ff879b07SJung-uk Kim  ******************************************************************************/
386ff879b07SJung-uk Kim 
387ff879b07SJung-uk Kim void
388ff879b07SJung-uk Kim AcpiDmDumpStao (
389ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
390ff879b07SJung-uk Kim {
391ff879b07SJung-uk Kim     ACPI_STATUS             Status;
392ff879b07SJung-uk Kim     char                    *Namepath;
393ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
394ff879b07SJung-uk Kim     UINT32                  StringLength;
395ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_STAO);
396ff879b07SJung-uk Kim 
397ff879b07SJung-uk Kim 
398ff879b07SJung-uk Kim     /* Main table */
399ff879b07SJung-uk Kim 
400ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoStao);
401ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
402ff879b07SJung-uk Kim     {
403ff879b07SJung-uk Kim         return;
404ff879b07SJung-uk Kim     }
405ff879b07SJung-uk Kim 
406ff879b07SJung-uk Kim     /* The rest of the table consists of Namepath strings */
407ff879b07SJung-uk Kim 
408ff879b07SJung-uk Kim     while (Offset < Table->Length)
409ff879b07SJung-uk Kim     {
410ff879b07SJung-uk Kim         Namepath = ACPI_ADD_PTR (char, Table, Offset);
411ff879b07SJung-uk Kim         StringLength = strlen (Namepath) + 1;
412ff879b07SJung-uk Kim 
413a009b7dcSJung-uk Kim         AcpiDmLineHeader (Offset, StringLength, "Namepath");
414ff879b07SJung-uk Kim         AcpiOsPrintf ("\"%s\"\n", Namepath);
415ff879b07SJung-uk Kim 
416ff879b07SJung-uk Kim         /* Point to next namepath */
417ff879b07SJung-uk Kim 
418ff879b07SJung-uk Kim         Offset += StringLength;
419ff879b07SJung-uk Kim     }
420ff879b07SJung-uk Kim }
421ff879b07SJung-uk Kim 
422ff879b07SJung-uk Kim 
423ff879b07SJung-uk Kim /*******************************************************************************
424ff879b07SJung-uk Kim  *
425*1970d693SJung-uk Kim  * FUNCTION:    AcpiDmDumpSvkl
426*1970d693SJung-uk Kim  *
427*1970d693SJung-uk Kim  * PARAMETERS:  Table               - A SVKL table
428*1970d693SJung-uk Kim  *
429*1970d693SJung-uk Kim  * RETURN:      None
430*1970d693SJung-uk Kim  *
431*1970d693SJung-uk Kim  * DESCRIPTION: Format the contents of a SVKL. This is a variable-length
432*1970d693SJung-uk Kim  *              table that contains an open-ended number of key subtables at
433*1970d693SJung-uk Kim  *              the end of the header.
434*1970d693SJung-uk Kim  *
435*1970d693SJung-uk Kim  * NOTES: SVKL is essentially a flat table, with a small main table and
436*1970d693SJung-uk Kim  *          a variable number of a single type of subtable.
437*1970d693SJung-uk Kim  *
438*1970d693SJung-uk Kim  ******************************************************************************/
439*1970d693SJung-uk Kim 
440*1970d693SJung-uk Kim void
441*1970d693SJung-uk Kim AcpiDmDumpSvkl (
442*1970d693SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
443*1970d693SJung-uk Kim {
444*1970d693SJung-uk Kim     ACPI_STATUS             Status;
445*1970d693SJung-uk Kim     UINT32                  Length = Table->Length;
446*1970d693SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_SVKL);
447*1970d693SJung-uk Kim     ACPI_SVKL_KEY           *Subtable;
448*1970d693SJung-uk Kim 
449*1970d693SJung-uk Kim 
450*1970d693SJung-uk Kim     /* Main table */
451*1970d693SJung-uk Kim 
452*1970d693SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoSvkl);
453*1970d693SJung-uk Kim     if (ACPI_FAILURE (Status))
454*1970d693SJung-uk Kim     {
455*1970d693SJung-uk Kim         return;
456*1970d693SJung-uk Kim     }
457*1970d693SJung-uk Kim 
458*1970d693SJung-uk Kim     /* The rest of the table consists of subtables (single type) */
459*1970d693SJung-uk Kim 
460*1970d693SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_SVKL_KEY, Table, Offset);
461*1970d693SJung-uk Kim     while (Offset < Table->Length)
462*1970d693SJung-uk Kim     {
463*1970d693SJung-uk Kim         /* Dump the subtable */
464*1970d693SJung-uk Kim 
465*1970d693SJung-uk Kim         AcpiOsPrintf ("\n");
466*1970d693SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
467*1970d693SJung-uk Kim             sizeof (ACPI_SVKL_KEY), AcpiDmTableInfoSvkl0);
468*1970d693SJung-uk Kim         if (ACPI_FAILURE (Status))
469*1970d693SJung-uk Kim         {
470*1970d693SJung-uk Kim             return;
471*1970d693SJung-uk Kim         }
472*1970d693SJung-uk Kim 
473*1970d693SJung-uk Kim         /* Point to next subtable */
474*1970d693SJung-uk Kim 
475*1970d693SJung-uk Kim         Offset += sizeof (ACPI_SVKL_KEY);
476*1970d693SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_SVKL_KEY, Subtable,
477*1970d693SJung-uk Kim             sizeof (ACPI_SVKL_KEY));
478*1970d693SJung-uk Kim     }
479*1970d693SJung-uk Kim }
480*1970d693SJung-uk Kim 
481*1970d693SJung-uk Kim 
482*1970d693SJung-uk Kim /*******************************************************************************
483*1970d693SJung-uk Kim  *
484ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpTcpa
485ff879b07SJung-uk Kim  *
486ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A TCPA table
487ff879b07SJung-uk Kim  *
488ff879b07SJung-uk Kim  * RETURN:      None
489ff879b07SJung-uk Kim  *
490ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a TCPA.
491ff879b07SJung-uk Kim  *
492ff879b07SJung-uk Kim  * NOTE:        There are two versions of the table with the same signature:
493ff879b07SJung-uk Kim  *              the client version and the server version. The common
494ff879b07SJung-uk Kim  *              PlatformClass field is used to differentiate the two types of
495ff879b07SJung-uk Kim  *              tables.
496ff879b07SJung-uk Kim  *
497ff879b07SJung-uk Kim  ******************************************************************************/
498ff879b07SJung-uk Kim 
499ff879b07SJung-uk Kim void
500ff879b07SJung-uk Kim AcpiDmDumpTcpa (
501ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
502ff879b07SJung-uk Kim {
503ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_TCPA_HDR);
504ff879b07SJung-uk Kim     ACPI_TABLE_TCPA_HDR     *CommonHeader = ACPI_CAST_PTR (
505ff879b07SJung-uk Kim                                 ACPI_TABLE_TCPA_HDR, Table);
506ff879b07SJung-uk Kim     ACPI_TABLE_TCPA_HDR     *Subtable = ACPI_ADD_PTR (
507ff879b07SJung-uk Kim                                 ACPI_TABLE_TCPA_HDR, Table, Offset);
508ff879b07SJung-uk Kim     ACPI_STATUS             Status;
509ff879b07SJung-uk Kim 
510ff879b07SJung-uk Kim 
511ff879b07SJung-uk Kim     /* Main table */
512ff879b07SJung-uk Kim 
513ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table,
514ff879b07SJung-uk Kim         0, AcpiDmTableInfoTcpaHdr);
515ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
516ff879b07SJung-uk Kim     {
517ff879b07SJung-uk Kim         return;
518ff879b07SJung-uk Kim     }
519ff879b07SJung-uk Kim 
520ff879b07SJung-uk Kim     /*
521ff879b07SJung-uk Kim      * Examine the PlatformClass field to determine the table type.
522ff879b07SJung-uk Kim      * Either a client or server table. Only one.
523ff879b07SJung-uk Kim      */
524ff879b07SJung-uk Kim     switch (CommonHeader->PlatformClass)
525ff879b07SJung-uk Kim     {
526ff879b07SJung-uk Kim     case ACPI_TCPA_CLIENT_TABLE:
527ff879b07SJung-uk Kim 
528ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
529ff879b07SJung-uk Kim             Table->Length - Offset, AcpiDmTableInfoTcpaClient);
530ff879b07SJung-uk Kim         break;
531ff879b07SJung-uk Kim 
532ff879b07SJung-uk Kim     case ACPI_TCPA_SERVER_TABLE:
533ff879b07SJung-uk Kim 
534ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
535ff879b07SJung-uk Kim             Table->Length - Offset, AcpiDmTableInfoTcpaServer);
536ff879b07SJung-uk Kim         break;
537ff879b07SJung-uk Kim 
538ff879b07SJung-uk Kim     default:
539ff879b07SJung-uk Kim 
540ff879b07SJung-uk Kim         AcpiOsPrintf ("\n**** Unknown TCPA Platform Class 0x%X\n",
541ff879b07SJung-uk Kim             CommonHeader->PlatformClass);
542ff879b07SJung-uk Kim         Status = AE_ERROR;
543ff879b07SJung-uk Kim         break;
544ff879b07SJung-uk Kim     }
545ff879b07SJung-uk Kim 
546ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
547ff879b07SJung-uk Kim     {
548ff879b07SJung-uk Kim         AcpiOsPrintf ("\n**** Cannot disassemble TCPA table\n");
549ff879b07SJung-uk Kim     }
550ff879b07SJung-uk Kim }
551ff879b07SJung-uk Kim 
552ff879b07SJung-uk Kim 
553ff879b07SJung-uk Kim /*******************************************************************************
554ff879b07SJung-uk Kim  *
555ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpTpm2
556ff879b07SJung-uk Kim  *
557ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A TPM2 table
558ff879b07SJung-uk Kim  *
559ff879b07SJung-uk Kim  * RETURN:      None
560ff879b07SJung-uk Kim  *
561ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a TPM2.
562ff879b07SJung-uk Kim  *
563ff879b07SJung-uk Kim  ******************************************************************************/
564*1970d693SJung-uk Kim 
5654a38ee6dSJung-uk Kim static void
5664a38ee6dSJung-uk Kim AcpiDmDumpTpm2Rev3 (
5674a38ee6dSJung-uk Kim     ACPI_TABLE_HEADER       *Table)
5684a38ee6dSJung-uk Kim {
5694a38ee6dSJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_TPM23);
5704a38ee6dSJung-uk Kim     ACPI_TABLE_TPM23        *CommonHeader = ACPI_CAST_PTR (ACPI_TABLE_TPM23, Table);
5714a38ee6dSJung-uk Kim     ACPI_TPM23_TRAILER      *Subtable = ACPI_ADD_PTR (ACPI_TPM23_TRAILER, Table, Offset);
5724a38ee6dSJung-uk Kim     ACPI_STATUS             Status;
5734a38ee6dSJung-uk Kim 
5744a38ee6dSJung-uk Kim 
5754a38ee6dSJung-uk Kim     /* Main table */
5764a38ee6dSJung-uk Kim 
5774a38ee6dSJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoTpm23);
5784a38ee6dSJung-uk Kim     if (ACPI_FAILURE (Status))
5794a38ee6dSJung-uk Kim     {
5804a38ee6dSJung-uk Kim         return;
5814a38ee6dSJung-uk Kim     }
5824a38ee6dSJung-uk Kim 
5834a38ee6dSJung-uk Kim     /* Optional subtable if start method is ACPI start method */
5844a38ee6dSJung-uk Kim 
5854a38ee6dSJung-uk Kim     switch (CommonHeader->StartMethod)
5864a38ee6dSJung-uk Kim     {
5874a38ee6dSJung-uk Kim     case ACPI_TPM23_ACPI_START_METHOD:
5884a38ee6dSJung-uk Kim 
589a009b7dcSJung-uk Kim         (void) AcpiDmDumpTable (Table->Length, Offset, Subtable,
5904a38ee6dSJung-uk Kim             Table->Length - Offset, AcpiDmTableInfoTpm23a);
5914a38ee6dSJung-uk Kim         break;
5924a38ee6dSJung-uk Kim 
5934a38ee6dSJung-uk Kim     default:
5944a38ee6dSJung-uk Kim         break;
5954a38ee6dSJung-uk Kim     }
5964a38ee6dSJung-uk Kim }
5974a38ee6dSJung-uk Kim 
5984a38ee6dSJung-uk Kim 
5994a38ee6dSJung-uk Kim /*******************************************************************************
6004a38ee6dSJung-uk Kim  *
6014a38ee6dSJung-uk Kim  * FUNCTION:    AcpiDmDumpTpm2
6024a38ee6dSJung-uk Kim  *
6034a38ee6dSJung-uk Kim  * PARAMETERS:  Table               - A TPM2 table
6044a38ee6dSJung-uk Kim  *
6054a38ee6dSJung-uk Kim  * RETURN:      None
6064a38ee6dSJung-uk Kim  *
6074a38ee6dSJung-uk Kim  * DESCRIPTION: Format the contents of a TPM2.
6084a38ee6dSJung-uk Kim  *
6094a38ee6dSJung-uk Kim  ******************************************************************************/
610ff879b07SJung-uk Kim 
611ff879b07SJung-uk Kim void
612ff879b07SJung-uk Kim AcpiDmDumpTpm2 (
613ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
614ff879b07SJung-uk Kim {
615ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_TPM2);
616ff879b07SJung-uk Kim     ACPI_TABLE_TPM2         *CommonHeader = ACPI_CAST_PTR (ACPI_TABLE_TPM2, Table);
617ff879b07SJung-uk Kim     ACPI_TPM2_TRAILER       *Subtable = ACPI_ADD_PTR (ACPI_TPM2_TRAILER, Table, Offset);
618ff879b07SJung-uk Kim     ACPI_TPM2_ARM_SMC       *ArmSubtable;
619ff879b07SJung-uk Kim     ACPI_STATUS             Status;
620ff879b07SJung-uk Kim 
621ff879b07SJung-uk Kim 
6224a38ee6dSJung-uk Kim     if (Table->Revision == 3)
6234a38ee6dSJung-uk Kim     {
6244a38ee6dSJung-uk Kim         AcpiDmDumpTpm2Rev3(Table);
6254a38ee6dSJung-uk Kim         return;
6264a38ee6dSJung-uk Kim     }
6274a38ee6dSJung-uk Kim 
628ff879b07SJung-uk Kim     /* Main table */
629ff879b07SJung-uk Kim 
630ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoTpm2);
6314a38ee6dSJung-uk Kim 
632ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
633ff879b07SJung-uk Kim     {
634ff879b07SJung-uk Kim         return;
635ff879b07SJung-uk Kim     }
636ff879b07SJung-uk Kim 
637ff879b07SJung-uk Kim     AcpiOsPrintf ("\n");
638ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
639ff879b07SJung-uk Kim         Table->Length - Offset, AcpiDmTableInfoTpm2a);
640ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
641ff879b07SJung-uk Kim     {
642ff879b07SJung-uk Kim         return;
643ff879b07SJung-uk Kim     }
644ff879b07SJung-uk Kim 
645ff879b07SJung-uk Kim     switch (CommonHeader->StartMethod)
646ff879b07SJung-uk Kim     {
647ff879b07SJung-uk Kim     case ACPI_TPM2_COMMAND_BUFFER_WITH_ARM_SMC:
648ff879b07SJung-uk Kim 
649ff879b07SJung-uk Kim         ArmSubtable = ACPI_ADD_PTR (ACPI_TPM2_ARM_SMC, Subtable,
650ff879b07SJung-uk Kim             sizeof (ACPI_TPM2_TRAILER));
651ff879b07SJung-uk Kim         Offset += sizeof (ACPI_TPM2_TRAILER);
652ff879b07SJung-uk Kim 
653ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
654a009b7dcSJung-uk Kim         (void) AcpiDmDumpTable (Table->Length, Offset, ArmSubtable,
655ff879b07SJung-uk Kim             Table->Length - Offset, AcpiDmTableInfoTpm211);
656ff879b07SJung-uk Kim         break;
657ff879b07SJung-uk Kim 
658ff879b07SJung-uk Kim     default:
659ff879b07SJung-uk Kim         break;
660ff879b07SJung-uk Kim     }
661ff879b07SJung-uk Kim }
662ff879b07SJung-uk Kim 
663ff879b07SJung-uk Kim 
664ff879b07SJung-uk Kim /*******************************************************************************
665ff879b07SJung-uk Kim  *
666cfd1ed46SJung-uk Kim  * FUNCTION:    AcpiDmDumpViot
667cfd1ed46SJung-uk Kim  *
668cfd1ed46SJung-uk Kim  * PARAMETERS:  Table               - A VIOT table
669cfd1ed46SJung-uk Kim  *
670cfd1ed46SJung-uk Kim  * RETURN:      None
671cfd1ed46SJung-uk Kim  *
672cfd1ed46SJung-uk Kim  * DESCRIPTION: Format the contents of a VIOT
673cfd1ed46SJung-uk Kim  *
674cfd1ed46SJung-uk Kim  ******************************************************************************/
675cfd1ed46SJung-uk Kim 
676cfd1ed46SJung-uk Kim void
677cfd1ed46SJung-uk Kim AcpiDmDumpViot (
678cfd1ed46SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
679cfd1ed46SJung-uk Kim {
680cfd1ed46SJung-uk Kim     ACPI_STATUS             Status;
681cfd1ed46SJung-uk Kim     ACPI_TABLE_VIOT         *Viot;
682cfd1ed46SJung-uk Kim     ACPI_VIOT_HEADER        *ViotHeader;
683cfd1ed46SJung-uk Kim     UINT16                  Length;
684cfd1ed46SJung-uk Kim     UINT16                  Offset;
685cfd1ed46SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
686cfd1ed46SJung-uk Kim 
687cfd1ed46SJung-uk Kim     /* Main table */
688cfd1ed46SJung-uk Kim 
689cfd1ed46SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoViot);
690cfd1ed46SJung-uk Kim     if (ACPI_FAILURE (Status))
691cfd1ed46SJung-uk Kim     {
692cfd1ed46SJung-uk Kim         return;
693cfd1ed46SJung-uk Kim     }
694cfd1ed46SJung-uk Kim 
695cfd1ed46SJung-uk Kim     Viot = ACPI_CAST_PTR (ACPI_TABLE_VIOT, Table);
696cfd1ed46SJung-uk Kim 
697cfd1ed46SJung-uk Kim     Offset = Viot->NodeOffset;
698cfd1ed46SJung-uk Kim     while (Offset < Table->Length)
699cfd1ed46SJung-uk Kim     {
700cfd1ed46SJung-uk Kim         /* Common subtable header */
701cfd1ed46SJung-uk Kim         ViotHeader = ACPI_ADD_PTR (ACPI_VIOT_HEADER, Table, Offset);
702cfd1ed46SJung-uk Kim         AcpiOsPrintf ("\n");
703cfd1ed46SJung-uk Kim 
704cfd1ed46SJung-uk Kim         Length = sizeof (ACPI_VIOT_HEADER);
705cfd1ed46SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, ViotHeader, Length,
706cfd1ed46SJung-uk Kim             AcpiDmTableInfoViotHeader);
707cfd1ed46SJung-uk Kim         if (ACPI_FAILURE (Status))
708cfd1ed46SJung-uk Kim         {
709cfd1ed46SJung-uk Kim             return;
710cfd1ed46SJung-uk Kim         }
711cfd1ed46SJung-uk Kim 
712cfd1ed46SJung-uk Kim         Length = ViotHeader->Length;
713cfd1ed46SJung-uk Kim         switch (ViotHeader->Type)
714cfd1ed46SJung-uk Kim         {
715cfd1ed46SJung-uk Kim         case ACPI_VIOT_NODE_PCI_RANGE:
716cfd1ed46SJung-uk Kim 
717cfd1ed46SJung-uk Kim             InfoTable = AcpiDmTableInfoViot1;
718cfd1ed46SJung-uk Kim             break;
719cfd1ed46SJung-uk Kim 
720cfd1ed46SJung-uk Kim         case ACPI_VIOT_NODE_MMIO:
721cfd1ed46SJung-uk Kim 
722cfd1ed46SJung-uk Kim             InfoTable = AcpiDmTableInfoViot2;
723cfd1ed46SJung-uk Kim             break;
724cfd1ed46SJung-uk Kim 
725cfd1ed46SJung-uk Kim         case ACPI_VIOT_NODE_VIRTIO_IOMMU_PCI:
726cfd1ed46SJung-uk Kim 
727cfd1ed46SJung-uk Kim             InfoTable = AcpiDmTableInfoViot3;
728cfd1ed46SJung-uk Kim             break;
729cfd1ed46SJung-uk Kim 
730cfd1ed46SJung-uk Kim         case ACPI_VIOT_NODE_VIRTIO_IOMMU_MMIO:
731cfd1ed46SJung-uk Kim 
732cfd1ed46SJung-uk Kim             InfoTable = AcpiDmTableInfoViot4;
733cfd1ed46SJung-uk Kim             break;
734cfd1ed46SJung-uk Kim 
735cfd1ed46SJung-uk Kim         default:
736cfd1ed46SJung-uk Kim 
737cfd1ed46SJung-uk Kim             AcpiOsPrintf ("\n*** Unknown VIOT node type 0x%X\n",
738cfd1ed46SJung-uk Kim                 ViotHeader->Type);
739cfd1ed46SJung-uk Kim 
740cfd1ed46SJung-uk Kim             /* Attempt to continue */
741cfd1ed46SJung-uk Kim 
742cfd1ed46SJung-uk Kim             if (!Length)
743cfd1ed46SJung-uk Kim             {
744cfd1ed46SJung-uk Kim                 AcpiOsPrintf ("Invalid zero length VIOT node\n");
745cfd1ed46SJung-uk Kim                 return;
746cfd1ed46SJung-uk Kim             }
747cfd1ed46SJung-uk Kim             goto NextSubtable;
748cfd1ed46SJung-uk Kim         }
749cfd1ed46SJung-uk Kim 
750cfd1ed46SJung-uk Kim         AcpiOsPrintf ("\n");
751cfd1ed46SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, ViotHeader, Length,
752cfd1ed46SJung-uk Kim             InfoTable);
753cfd1ed46SJung-uk Kim         if (ACPI_FAILURE (Status))
754cfd1ed46SJung-uk Kim         {
755cfd1ed46SJung-uk Kim             return;
756cfd1ed46SJung-uk Kim         }
757cfd1ed46SJung-uk Kim 
758cfd1ed46SJung-uk Kim NextSubtable:
759cfd1ed46SJung-uk Kim         Offset += Length;
760cfd1ed46SJung-uk Kim     }
761cfd1ed46SJung-uk Kim }
762cfd1ed46SJung-uk Kim 
763cfd1ed46SJung-uk Kim 
764cfd1ed46SJung-uk Kim /*******************************************************************************
765cfd1ed46SJung-uk Kim  *
766ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpWdat
767ff879b07SJung-uk Kim  *
768ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A WDAT table
769ff879b07SJung-uk Kim  *
770ff879b07SJung-uk Kim  * RETURN:      None
771ff879b07SJung-uk Kim  *
772ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a WDAT
773ff879b07SJung-uk Kim  *
774ff879b07SJung-uk Kim  ******************************************************************************/
775ff879b07SJung-uk Kim 
776ff879b07SJung-uk Kim void
777ff879b07SJung-uk Kim AcpiDmDumpWdat (
778ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
779ff879b07SJung-uk Kim {
780ff879b07SJung-uk Kim     ACPI_STATUS             Status;
781ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_WDAT);
782ff879b07SJung-uk Kim     ACPI_WDAT_ENTRY         *Subtable;
783ff879b07SJung-uk Kim 
784ff879b07SJung-uk Kim 
785ff879b07SJung-uk Kim     /* Main table */
786ff879b07SJung-uk Kim 
787ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoWdat);
788ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
789ff879b07SJung-uk Kim     {
790ff879b07SJung-uk Kim         return;
791ff879b07SJung-uk Kim     }
792ff879b07SJung-uk Kim 
793ff879b07SJung-uk Kim     /* Subtables */
794ff879b07SJung-uk Kim 
795ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Table, Offset);
796ff879b07SJung-uk Kim     while (Offset < Table->Length)
797ff879b07SJung-uk Kim     {
798ff879b07SJung-uk Kim         /* Common subtable header */
799ff879b07SJung-uk Kim 
800ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
801ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
802ff879b07SJung-uk Kim             sizeof (ACPI_WDAT_ENTRY), AcpiDmTableInfoWdat0);
803ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
804ff879b07SJung-uk Kim         {
805ff879b07SJung-uk Kim             return;
806ff879b07SJung-uk Kim         }
807ff879b07SJung-uk Kim 
808ff879b07SJung-uk Kim         /* Point to next subtable */
809ff879b07SJung-uk Kim 
810ff879b07SJung-uk Kim         Offset += sizeof (ACPI_WDAT_ENTRY);
811ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Subtable,
812ff879b07SJung-uk Kim             sizeof (ACPI_WDAT_ENTRY));
813ff879b07SJung-uk Kim     }
814ff879b07SJung-uk Kim }
815ff879b07SJung-uk Kim 
816ff879b07SJung-uk Kim 
817ff879b07SJung-uk Kim /*******************************************************************************
818ff879b07SJung-uk Kim  *
819ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpWpbt
820ff879b07SJung-uk Kim  *
821ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A WPBT table
822ff879b07SJung-uk Kim  *
823ff879b07SJung-uk Kim  * RETURN:      None
824ff879b07SJung-uk Kim  *
825ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a WPBT. This table type consists
826ff879b07SJung-uk Kim  *              of an open-ended arguments buffer at the end of the table.
827ff879b07SJung-uk Kim  *
828ff879b07SJung-uk Kim  ******************************************************************************/
829ff879b07SJung-uk Kim 
830ff879b07SJung-uk Kim void
831ff879b07SJung-uk Kim AcpiDmDumpWpbt (
832ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
833ff879b07SJung-uk Kim {
834ff879b07SJung-uk Kim     ACPI_STATUS             Status;
835ff879b07SJung-uk Kim     ACPI_TABLE_WPBT         *Subtable;
836ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
837ff879b07SJung-uk Kim     UINT16                  ArgumentsLength;
838ff879b07SJung-uk Kim 
839ff879b07SJung-uk Kim 
840ff879b07SJung-uk Kim     /* Dump the main table */
841ff879b07SJung-uk Kim 
842ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoWpbt);
843ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
844ff879b07SJung-uk Kim     {
845ff879b07SJung-uk Kim         return;
846ff879b07SJung-uk Kim     }
847ff879b07SJung-uk Kim 
848ff879b07SJung-uk Kim     /* Extract the arguments buffer length from the main table */
849ff879b07SJung-uk Kim 
850ff879b07SJung-uk Kim     Subtable = ACPI_CAST_PTR (ACPI_TABLE_WPBT, Table);
851ff879b07SJung-uk Kim     ArgumentsLength = Subtable->ArgumentsLength;
852ff879b07SJung-uk Kim 
853ff879b07SJung-uk Kim     /* Dump the arguments buffer */
854ff879b07SJung-uk Kim 
855ff879b07SJung-uk Kim     (void) AcpiDmDumpTable (Table->Length, 0, Table, ArgumentsLength,
856ff879b07SJung-uk Kim         AcpiDmTableInfoWpbt0);
857ff879b07SJung-uk Kim }
858