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 *
11*58308fadSJung-uk Kim * Some or all of this work - Copyright (c) 1999 - 2025, 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
AcpiDmDumpSlic(ACPI_TABLE_HEADER * Table)176ff879b07SJung-uk Kim AcpiDmDumpSlic (
177ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
178ff879b07SJung-uk Kim {
179ff879b07SJung-uk Kim
18092f570c3SJung-uk Kim (void) AcpiDmDumpTable (Table->Length, sizeof (ACPI_TABLE_HEADER),
1811a259ad4SJung-uk Kim (void *) ((UINT8 *)Table + sizeof (*Table)),
182ff879b07SJung-uk Kim Table->Length - sizeof (*Table), AcpiDmTableInfoSlic);
183ff879b07SJung-uk Kim }
184ff879b07SJung-uk Kim
185ff879b07SJung-uk Kim
186ff879b07SJung-uk Kim /*******************************************************************************
187ff879b07SJung-uk Kim *
188ff879b07SJung-uk Kim * FUNCTION: AcpiDmDumpSlit
189ff879b07SJung-uk Kim *
190ff879b07SJung-uk Kim * PARAMETERS: Table - An SLIT
191ff879b07SJung-uk Kim *
192ff879b07SJung-uk Kim * RETURN: None
193ff879b07SJung-uk Kim *
194ff879b07SJung-uk Kim * DESCRIPTION: Format the contents of a SLIT
195ff879b07SJung-uk Kim *
196ff879b07SJung-uk Kim ******************************************************************************/
197ff879b07SJung-uk Kim
198ff879b07SJung-uk Kim void
AcpiDmDumpSlit(ACPI_TABLE_HEADER * Table)199ff879b07SJung-uk Kim AcpiDmDumpSlit (
200ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
201ff879b07SJung-uk Kim {
202ff879b07SJung-uk Kim ACPI_STATUS Status;
203ff879b07SJung-uk Kim UINT32 Offset;
204ff879b07SJung-uk Kim UINT8 *Row;
205ff879b07SJung-uk Kim UINT32 Localities;
206ff879b07SJung-uk Kim UINT32 i;
207ff879b07SJung-uk Kim UINT32 j;
208ff879b07SJung-uk Kim
209ff879b07SJung-uk Kim
210ff879b07SJung-uk Kim /* Main table */
211ff879b07SJung-uk Kim
212ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSlit);
213ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
214ff879b07SJung-uk Kim {
215ff879b07SJung-uk Kim return;
216ff879b07SJung-uk Kim }
217ff879b07SJung-uk Kim
218ff879b07SJung-uk Kim /* Display the Locality NxN Matrix */
219ff879b07SJung-uk Kim
220ff879b07SJung-uk Kim Localities = (UINT32) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->LocalityCount;
221ff879b07SJung-uk Kim Offset = ACPI_OFFSET (ACPI_TABLE_SLIT, Entry[0]);
222ff879b07SJung-uk Kim Row = (UINT8 *) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->Entry;
223ff879b07SJung-uk Kim
224ff879b07SJung-uk Kim for (i = 0; i < Localities; i++)
225ff879b07SJung-uk Kim {
226ff879b07SJung-uk Kim /* Display one row of the matrix */
227ff879b07SJung-uk Kim
228ff879b07SJung-uk Kim AcpiDmLineHeader2 (Offset, Localities, "Locality", i);
229ff879b07SJung-uk Kim for (j = 0; j < Localities; j++)
230ff879b07SJung-uk Kim {
231ff879b07SJung-uk Kim /* Check for beyond EOT */
232ff879b07SJung-uk Kim
233ff879b07SJung-uk Kim if (Offset >= Table->Length)
234ff879b07SJung-uk Kim {
235ff879b07SJung-uk Kim AcpiOsPrintf (
236ff879b07SJung-uk Kim "\n**** Not enough room in table for all localities\n");
237ff879b07SJung-uk Kim return;
238ff879b07SJung-uk Kim }
239ff879b07SJung-uk Kim
240ff879b07SJung-uk Kim AcpiOsPrintf ("%2.2X", Row[j]);
241ff879b07SJung-uk Kim Offset++;
242ff879b07SJung-uk Kim
243ff879b07SJung-uk Kim /* Display up to 16 bytes per output row */
244ff879b07SJung-uk Kim
245ff879b07SJung-uk Kim if ((j+1) < Localities)
246ff879b07SJung-uk Kim {
247ff879b07SJung-uk Kim AcpiOsPrintf (" ");
248ff879b07SJung-uk Kim
249ff879b07SJung-uk Kim if (j && (((j+1) % 16) == 0))
250ff879b07SJung-uk Kim {
251ff879b07SJung-uk Kim AcpiOsPrintf ("\\\n"); /* With line continuation char */
252ff879b07SJung-uk Kim AcpiDmLineHeader (Offset, 0, NULL);
253ff879b07SJung-uk Kim }
254ff879b07SJung-uk Kim }
255ff879b07SJung-uk Kim }
256ff879b07SJung-uk Kim
257ff879b07SJung-uk Kim /* Point to next row */
258ff879b07SJung-uk Kim
259ff879b07SJung-uk Kim AcpiOsPrintf ("\n");
260ff879b07SJung-uk Kim Row += Localities;
261ff879b07SJung-uk Kim }
262ff879b07SJung-uk Kim }
263ff879b07SJung-uk Kim
264ff879b07SJung-uk Kim
265ff879b07SJung-uk Kim /*******************************************************************************
266ff879b07SJung-uk Kim *
267ff879b07SJung-uk Kim * FUNCTION: AcpiDmDumpSrat
268ff879b07SJung-uk Kim *
269ff879b07SJung-uk Kim * PARAMETERS: Table - A SRAT table
270ff879b07SJung-uk Kim *
271ff879b07SJung-uk Kim * RETURN: None
272ff879b07SJung-uk Kim *
273ff879b07SJung-uk Kim * DESCRIPTION: Format the contents of a SRAT
274ff879b07SJung-uk Kim *
275ff879b07SJung-uk Kim ******************************************************************************/
276ff879b07SJung-uk Kim
277ff879b07SJung-uk Kim void
AcpiDmDumpSrat(ACPI_TABLE_HEADER * Table)278ff879b07SJung-uk Kim AcpiDmDumpSrat (
279ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
280ff879b07SJung-uk Kim {
281ff879b07SJung-uk Kim ACPI_STATUS Status;
282ff879b07SJung-uk Kim UINT32 Offset = sizeof (ACPI_TABLE_SRAT);
283ff879b07SJung-uk Kim ACPI_SUBTABLE_HEADER *Subtable;
284ff879b07SJung-uk Kim ACPI_DMTABLE_INFO *InfoTable;
285ff879b07SJung-uk Kim
286ff879b07SJung-uk Kim
287ff879b07SJung-uk Kim /* Main table */
288ff879b07SJung-uk Kim
289ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSrat);
290ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
291ff879b07SJung-uk Kim {
292ff879b07SJung-uk Kim return;
293ff879b07SJung-uk Kim }
294ff879b07SJung-uk Kim
295ff879b07SJung-uk Kim /* Subtables */
296ff879b07SJung-uk Kim
297ff879b07SJung-uk Kim Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Table, Offset);
298ff879b07SJung-uk Kim while (Offset < Table->Length)
299ff879b07SJung-uk Kim {
300ff879b07SJung-uk Kim /* Common subtable header */
301ff879b07SJung-uk Kim
302ff879b07SJung-uk Kim AcpiOsPrintf ("\n");
303ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
304ff879b07SJung-uk Kim Subtable->Length, AcpiDmTableInfoSratHdr);
305ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
306ff879b07SJung-uk Kim {
307ff879b07SJung-uk Kim return;
308ff879b07SJung-uk Kim }
309ff879b07SJung-uk Kim
310ff879b07SJung-uk Kim switch (Subtable->Type)
311ff879b07SJung-uk Kim {
312ff879b07SJung-uk Kim case ACPI_SRAT_TYPE_CPU_AFFINITY:
313ff879b07SJung-uk Kim
314ff879b07SJung-uk Kim InfoTable = AcpiDmTableInfoSrat0;
315ff879b07SJung-uk Kim break;
316ff879b07SJung-uk Kim
317ff879b07SJung-uk Kim case ACPI_SRAT_TYPE_MEMORY_AFFINITY:
318ff879b07SJung-uk Kim
319ff879b07SJung-uk Kim InfoTable = AcpiDmTableInfoSrat1;
320ff879b07SJung-uk Kim break;
321ff879b07SJung-uk Kim
322ff879b07SJung-uk Kim case ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY:
323ff879b07SJung-uk Kim
324ff879b07SJung-uk Kim InfoTable = AcpiDmTableInfoSrat2;
325ff879b07SJung-uk Kim break;
326ff879b07SJung-uk Kim
327ff879b07SJung-uk Kim case ACPI_SRAT_TYPE_GICC_AFFINITY:
328ff879b07SJung-uk Kim
329ff879b07SJung-uk Kim InfoTable = AcpiDmTableInfoSrat3;
330ff879b07SJung-uk Kim break;
331ff879b07SJung-uk Kim
332ff879b07SJung-uk Kim case ACPI_SRAT_TYPE_GIC_ITS_AFFINITY:
333ff879b07SJung-uk Kim
334ff879b07SJung-uk Kim InfoTable = AcpiDmTableInfoSrat4;
335ff879b07SJung-uk Kim break;
336ff879b07SJung-uk Kim
337cd6518c7SJung-uk Kim case ACPI_SRAT_TYPE_GENERIC_AFFINITY:
338cd6518c7SJung-uk Kim
339cd6518c7SJung-uk Kim InfoTable = AcpiDmTableInfoSrat5;
340cd6518c7SJung-uk Kim break;
341cd6518c7SJung-uk Kim
3421b7a2680SJung-uk Kim case ACPI_SRAT_TYPE_GENERIC_PORT_AFFINITY:
3431b7a2680SJung-uk Kim
3441b7a2680SJung-uk Kim InfoTable = AcpiDmTableInfoSrat6;
3451b7a2680SJung-uk Kim break;
3461b7a2680SJung-uk Kim
347804fe266SJung-uk Kim case ACPI_SRAT_TYPE_RINTC_AFFINITY:
348804fe266SJung-uk Kim
349804fe266SJung-uk Kim InfoTable = AcpiDmTableInfoSrat7;
350804fe266SJung-uk Kim break;
351804fe266SJung-uk Kim
352ff879b07SJung-uk Kim default:
353ff879b07SJung-uk Kim AcpiOsPrintf ("\n**** Unknown SRAT subtable type 0x%X\n",
354ff879b07SJung-uk Kim Subtable->Type);
355ff879b07SJung-uk Kim
356ff879b07SJung-uk Kim /* Attempt to continue */
357ff879b07SJung-uk Kim
358ff879b07SJung-uk Kim if (!Subtable->Length)
359ff879b07SJung-uk Kim {
360ff879b07SJung-uk Kim AcpiOsPrintf ("Invalid zero length subtable\n");
361ff879b07SJung-uk Kim return;
362ff879b07SJung-uk Kim }
363ff879b07SJung-uk Kim goto NextSubtable;
364ff879b07SJung-uk Kim }
365ff879b07SJung-uk Kim
366ff879b07SJung-uk Kim AcpiOsPrintf ("\n");
367ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
368ff879b07SJung-uk Kim Subtable->Length, InfoTable);
369ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
370ff879b07SJung-uk Kim {
371ff879b07SJung-uk Kim return;
372ff879b07SJung-uk Kim }
373ff879b07SJung-uk Kim
374ff879b07SJung-uk Kim NextSubtable:
375ff879b07SJung-uk Kim /* Point to next subtable */
376ff879b07SJung-uk Kim
377ff879b07SJung-uk Kim Offset += Subtable->Length;
378ff879b07SJung-uk Kim Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Subtable,
379ff879b07SJung-uk Kim Subtable->Length);
380ff879b07SJung-uk Kim }
381ff879b07SJung-uk Kim }
382ff879b07SJung-uk Kim
383ff879b07SJung-uk Kim
384ff879b07SJung-uk Kim /*******************************************************************************
385ff879b07SJung-uk Kim *
386ff879b07SJung-uk Kim * FUNCTION: AcpiDmDumpStao
387ff879b07SJung-uk Kim *
388ff879b07SJung-uk Kim * PARAMETERS: Table - A STAO table
389ff879b07SJung-uk Kim *
390ff879b07SJung-uk Kim * RETURN: None
391ff879b07SJung-uk Kim *
392ff879b07SJung-uk Kim * DESCRIPTION: Format the contents of a STAO. This is a variable-length
393ff879b07SJung-uk Kim * table that contains an open-ended number of ASCII strings
394ff879b07SJung-uk Kim * at the end of the table.
395ff879b07SJung-uk Kim *
396ff879b07SJung-uk Kim ******************************************************************************/
397ff879b07SJung-uk Kim
398ff879b07SJung-uk Kim void
AcpiDmDumpStao(ACPI_TABLE_HEADER * Table)399ff879b07SJung-uk Kim AcpiDmDumpStao (
400ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
401ff879b07SJung-uk Kim {
402ff879b07SJung-uk Kim ACPI_STATUS Status;
403ff879b07SJung-uk Kim char *Namepath;
404ff879b07SJung-uk Kim UINT32 Length = Table->Length;
405ff879b07SJung-uk Kim UINT32 StringLength;
406ff879b07SJung-uk Kim UINT32 Offset = sizeof (ACPI_TABLE_STAO);
407ff879b07SJung-uk Kim
408ff879b07SJung-uk Kim
409ff879b07SJung-uk Kim /* Main table */
410ff879b07SJung-uk Kim
411ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoStao);
412ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
413ff879b07SJung-uk Kim {
414ff879b07SJung-uk Kim return;
415ff879b07SJung-uk Kim }
416ff879b07SJung-uk Kim
417ff879b07SJung-uk Kim /* The rest of the table consists of Namepath strings */
418ff879b07SJung-uk Kim
419ff879b07SJung-uk Kim while (Offset < Table->Length)
420ff879b07SJung-uk Kim {
421ff879b07SJung-uk Kim Namepath = ACPI_ADD_PTR (char, Table, Offset);
422ff879b07SJung-uk Kim StringLength = strlen (Namepath) + 1;
423ff879b07SJung-uk Kim
424a009b7dcSJung-uk Kim AcpiDmLineHeader (Offset, StringLength, "Namepath");
425ff879b07SJung-uk Kim AcpiOsPrintf ("\"%s\"\n", Namepath);
426ff879b07SJung-uk Kim
427ff879b07SJung-uk Kim /* Point to next namepath */
428ff879b07SJung-uk Kim
429ff879b07SJung-uk Kim Offset += StringLength;
430ff879b07SJung-uk Kim }
431ff879b07SJung-uk Kim }
432ff879b07SJung-uk Kim
433ff879b07SJung-uk Kim
434ff879b07SJung-uk Kim /*******************************************************************************
435ff879b07SJung-uk Kim *
4361970d693SJung-uk Kim * FUNCTION: AcpiDmDumpSvkl
4371970d693SJung-uk Kim *
4381970d693SJung-uk Kim * PARAMETERS: Table - A SVKL table
4391970d693SJung-uk Kim *
4401970d693SJung-uk Kim * RETURN: None
4411970d693SJung-uk Kim *
4421970d693SJung-uk Kim * DESCRIPTION: Format the contents of a SVKL. This is a variable-length
4431970d693SJung-uk Kim * table that contains an open-ended number of key subtables at
4441970d693SJung-uk Kim * the end of the header.
4451970d693SJung-uk Kim *
4461970d693SJung-uk Kim * NOTES: SVKL is essentially a flat table, with a small main table and
4471970d693SJung-uk Kim * a variable number of a single type of subtable.
4481970d693SJung-uk Kim *
4491970d693SJung-uk Kim ******************************************************************************/
4501970d693SJung-uk Kim
4511970d693SJung-uk Kim void
AcpiDmDumpSvkl(ACPI_TABLE_HEADER * Table)4521970d693SJung-uk Kim AcpiDmDumpSvkl (
4531970d693SJung-uk Kim ACPI_TABLE_HEADER *Table)
4541970d693SJung-uk Kim {
4551970d693SJung-uk Kim ACPI_STATUS Status;
4561970d693SJung-uk Kim UINT32 Length = Table->Length;
4571970d693SJung-uk Kim UINT32 Offset = sizeof (ACPI_TABLE_SVKL);
4581970d693SJung-uk Kim ACPI_SVKL_KEY *Subtable;
4591970d693SJung-uk Kim
4601970d693SJung-uk Kim
4611970d693SJung-uk Kim /* Main table */
4621970d693SJung-uk Kim
4631970d693SJung-uk Kim Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoSvkl);
4641970d693SJung-uk Kim if (ACPI_FAILURE (Status))
4651970d693SJung-uk Kim {
4661970d693SJung-uk Kim return;
4671970d693SJung-uk Kim }
4681970d693SJung-uk Kim
4691970d693SJung-uk Kim /* The rest of the table consists of subtables (single type) */
4701970d693SJung-uk Kim
4711970d693SJung-uk Kim Subtable = ACPI_ADD_PTR (ACPI_SVKL_KEY, Table, Offset);
4721970d693SJung-uk Kim while (Offset < Table->Length)
4731970d693SJung-uk Kim {
4741970d693SJung-uk Kim /* Dump the subtable */
4751970d693SJung-uk Kim
4761970d693SJung-uk Kim AcpiOsPrintf ("\n");
4771970d693SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
4781970d693SJung-uk Kim sizeof (ACPI_SVKL_KEY), AcpiDmTableInfoSvkl0);
4791970d693SJung-uk Kim if (ACPI_FAILURE (Status))
4801970d693SJung-uk Kim {
4811970d693SJung-uk Kim return;
4821970d693SJung-uk Kim }
4831970d693SJung-uk Kim
4841970d693SJung-uk Kim /* Point to next subtable */
4851970d693SJung-uk Kim
4861970d693SJung-uk Kim Offset += sizeof (ACPI_SVKL_KEY);
4871970d693SJung-uk Kim Subtable = ACPI_ADD_PTR (ACPI_SVKL_KEY, Subtable,
4881970d693SJung-uk Kim sizeof (ACPI_SVKL_KEY));
4891970d693SJung-uk Kim }
4901970d693SJung-uk Kim }
4911970d693SJung-uk Kim
4921970d693SJung-uk Kim
4931970d693SJung-uk Kim /*******************************************************************************
4941970d693SJung-uk Kim *
495ff879b07SJung-uk Kim * FUNCTION: AcpiDmDumpTcpa
496ff879b07SJung-uk Kim *
497ff879b07SJung-uk Kim * PARAMETERS: Table - A TCPA table
498ff879b07SJung-uk Kim *
499ff879b07SJung-uk Kim * RETURN: None
500ff879b07SJung-uk Kim *
501ff879b07SJung-uk Kim * DESCRIPTION: Format the contents of a TCPA.
502ff879b07SJung-uk Kim *
503ff879b07SJung-uk Kim * NOTE: There are two versions of the table with the same signature:
504ff879b07SJung-uk Kim * the client version and the server version. The common
505ff879b07SJung-uk Kim * PlatformClass field is used to differentiate the two types of
506ff879b07SJung-uk Kim * tables.
507ff879b07SJung-uk Kim *
508ff879b07SJung-uk Kim ******************************************************************************/
509ff879b07SJung-uk Kim
510ff879b07SJung-uk Kim void
AcpiDmDumpTcpa(ACPI_TABLE_HEADER * Table)511ff879b07SJung-uk Kim AcpiDmDumpTcpa (
512ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
513ff879b07SJung-uk Kim {
514ff879b07SJung-uk Kim UINT32 Offset = sizeof (ACPI_TABLE_TCPA_HDR);
515ff879b07SJung-uk Kim ACPI_TABLE_TCPA_HDR *CommonHeader = ACPI_CAST_PTR (
516ff879b07SJung-uk Kim ACPI_TABLE_TCPA_HDR, Table);
517ff879b07SJung-uk Kim ACPI_TABLE_TCPA_HDR *Subtable = ACPI_ADD_PTR (
518ff879b07SJung-uk Kim ACPI_TABLE_TCPA_HDR, Table, Offset);
519ff879b07SJung-uk Kim ACPI_STATUS Status;
520ff879b07SJung-uk Kim
521ff879b07SJung-uk Kim
522ff879b07SJung-uk Kim /* Main table */
523ff879b07SJung-uk Kim
524ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table,
525ff879b07SJung-uk Kim 0, AcpiDmTableInfoTcpaHdr);
526ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
527ff879b07SJung-uk Kim {
528ff879b07SJung-uk Kim return;
529ff879b07SJung-uk Kim }
530ff879b07SJung-uk Kim
531ff879b07SJung-uk Kim /*
532ff879b07SJung-uk Kim * Examine the PlatformClass field to determine the table type.
533ff879b07SJung-uk Kim * Either a client or server table. Only one.
534ff879b07SJung-uk Kim */
535ff879b07SJung-uk Kim switch (CommonHeader->PlatformClass)
536ff879b07SJung-uk Kim {
537ff879b07SJung-uk Kim case ACPI_TCPA_CLIENT_TABLE:
538ff879b07SJung-uk Kim
539ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
540ff879b07SJung-uk Kim Table->Length - Offset, AcpiDmTableInfoTcpaClient);
541ff879b07SJung-uk Kim break;
542ff879b07SJung-uk Kim
543ff879b07SJung-uk Kim case ACPI_TCPA_SERVER_TABLE:
544ff879b07SJung-uk Kim
545ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
546ff879b07SJung-uk Kim Table->Length - Offset, AcpiDmTableInfoTcpaServer);
547ff879b07SJung-uk Kim break;
548ff879b07SJung-uk Kim
549ff879b07SJung-uk Kim default:
550ff879b07SJung-uk Kim
551ff879b07SJung-uk Kim AcpiOsPrintf ("\n**** Unknown TCPA Platform Class 0x%X\n",
552ff879b07SJung-uk Kim CommonHeader->PlatformClass);
553ff879b07SJung-uk Kim Status = AE_ERROR;
554ff879b07SJung-uk Kim break;
555ff879b07SJung-uk Kim }
556ff879b07SJung-uk Kim
557ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
558ff879b07SJung-uk Kim {
559ff879b07SJung-uk Kim AcpiOsPrintf ("\n**** Cannot disassemble TCPA table\n");
560ff879b07SJung-uk Kim }
561ff879b07SJung-uk Kim }
562ff879b07SJung-uk Kim
563ff879b07SJung-uk Kim
564ff879b07SJung-uk Kim /*******************************************************************************
565ff879b07SJung-uk Kim *
566ff879b07SJung-uk Kim * FUNCTION: AcpiDmDumpTpm2
567ff879b07SJung-uk Kim *
568ff879b07SJung-uk Kim * PARAMETERS: Table - A TPM2 table
569ff879b07SJung-uk Kim *
570ff879b07SJung-uk Kim * RETURN: None
571ff879b07SJung-uk Kim *
572ff879b07SJung-uk Kim * DESCRIPTION: Format the contents of a TPM2.
573ff879b07SJung-uk Kim *
574ff879b07SJung-uk Kim ******************************************************************************/
5751970d693SJung-uk Kim
5764a38ee6dSJung-uk Kim static void
AcpiDmDumpTpm2Rev3(ACPI_TABLE_HEADER * Table)5774a38ee6dSJung-uk Kim AcpiDmDumpTpm2Rev3 (
5784a38ee6dSJung-uk Kim ACPI_TABLE_HEADER *Table)
5794a38ee6dSJung-uk Kim {
5804a38ee6dSJung-uk Kim UINT32 Offset = sizeof (ACPI_TABLE_TPM23);
5814a38ee6dSJung-uk Kim ACPI_TABLE_TPM23 *CommonHeader = ACPI_CAST_PTR (ACPI_TABLE_TPM23, Table);
5824a38ee6dSJung-uk Kim ACPI_TPM23_TRAILER *Subtable = ACPI_ADD_PTR (ACPI_TPM23_TRAILER, Table, Offset);
5834a38ee6dSJung-uk Kim ACPI_STATUS Status;
5844a38ee6dSJung-uk Kim
5854a38ee6dSJung-uk Kim
5864a38ee6dSJung-uk Kim /* Main table */
5874a38ee6dSJung-uk Kim
5884a38ee6dSJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoTpm23);
5894a38ee6dSJung-uk Kim if (ACPI_FAILURE (Status))
5904a38ee6dSJung-uk Kim {
5914a38ee6dSJung-uk Kim return;
5924a38ee6dSJung-uk Kim }
5934a38ee6dSJung-uk Kim
5944a38ee6dSJung-uk Kim /* Optional subtable if start method is ACPI start method */
5954a38ee6dSJung-uk Kim
5964a38ee6dSJung-uk Kim switch (CommonHeader->StartMethod)
5974a38ee6dSJung-uk Kim {
5984a38ee6dSJung-uk Kim case ACPI_TPM23_ACPI_START_METHOD:
5994a38ee6dSJung-uk Kim
600a009b7dcSJung-uk Kim (void) AcpiDmDumpTable (Table->Length, Offset, Subtable,
6014a38ee6dSJung-uk Kim Table->Length - Offset, AcpiDmTableInfoTpm23a);
6024a38ee6dSJung-uk Kim break;
6034a38ee6dSJung-uk Kim
6044a38ee6dSJung-uk Kim default:
6054a38ee6dSJung-uk Kim break;
6064a38ee6dSJung-uk Kim }
6074a38ee6dSJung-uk Kim }
6084a38ee6dSJung-uk Kim
6094a38ee6dSJung-uk Kim
6104a38ee6dSJung-uk Kim /*******************************************************************************
6114a38ee6dSJung-uk Kim *
6124a38ee6dSJung-uk Kim * FUNCTION: AcpiDmDumpTpm2
6134a38ee6dSJung-uk Kim *
6144a38ee6dSJung-uk Kim * PARAMETERS: Table - A TPM2 table
6154a38ee6dSJung-uk Kim *
6164a38ee6dSJung-uk Kim * RETURN: None
6174a38ee6dSJung-uk Kim *
6184a38ee6dSJung-uk Kim * DESCRIPTION: Format the contents of a TPM2.
6194a38ee6dSJung-uk Kim *
6204a38ee6dSJung-uk Kim ******************************************************************************/
621ff879b07SJung-uk Kim
622ff879b07SJung-uk Kim void
AcpiDmDumpTpm2(ACPI_TABLE_HEADER * Table)623ff879b07SJung-uk Kim AcpiDmDumpTpm2 (
624ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
625ff879b07SJung-uk Kim {
626ff879b07SJung-uk Kim UINT32 Offset = sizeof (ACPI_TABLE_TPM2);
627ff879b07SJung-uk Kim ACPI_TABLE_TPM2 *CommonHeader = ACPI_CAST_PTR (ACPI_TABLE_TPM2, Table);
628ff879b07SJung-uk Kim ACPI_TPM2_TRAILER *Subtable = ACPI_ADD_PTR (ACPI_TPM2_TRAILER, Table, Offset);
629ff879b07SJung-uk Kim ACPI_TPM2_ARM_SMC *ArmSubtable;
630ff879b07SJung-uk Kim ACPI_STATUS Status;
631ff879b07SJung-uk Kim
632ff879b07SJung-uk Kim
6334a38ee6dSJung-uk Kim if (Table->Revision == 3)
6344a38ee6dSJung-uk Kim {
6354a38ee6dSJung-uk Kim AcpiDmDumpTpm2Rev3(Table);
6364a38ee6dSJung-uk Kim return;
6374a38ee6dSJung-uk Kim }
6384a38ee6dSJung-uk Kim
639ff879b07SJung-uk Kim /* Main table */
640ff879b07SJung-uk Kim
641ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoTpm2);
6424a38ee6dSJung-uk Kim
643ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
644ff879b07SJung-uk Kim {
645ff879b07SJung-uk Kim return;
646ff879b07SJung-uk Kim }
647ff879b07SJung-uk Kim
648ff879b07SJung-uk Kim AcpiOsPrintf ("\n");
649ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
650ff879b07SJung-uk Kim Table->Length - Offset, AcpiDmTableInfoTpm2a);
651ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
652ff879b07SJung-uk Kim {
653ff879b07SJung-uk Kim return;
654ff879b07SJung-uk Kim }
655ff879b07SJung-uk Kim
656ff879b07SJung-uk Kim switch (CommonHeader->StartMethod)
657ff879b07SJung-uk Kim {
658ff879b07SJung-uk Kim case ACPI_TPM2_COMMAND_BUFFER_WITH_ARM_SMC:
659ff879b07SJung-uk Kim
660ff879b07SJung-uk Kim ArmSubtable = ACPI_ADD_PTR (ACPI_TPM2_ARM_SMC, Subtable,
661ff879b07SJung-uk Kim sizeof (ACPI_TPM2_TRAILER));
662ff879b07SJung-uk Kim Offset += sizeof (ACPI_TPM2_TRAILER);
663ff879b07SJung-uk Kim
664ff879b07SJung-uk Kim AcpiOsPrintf ("\n");
665a009b7dcSJung-uk Kim (void) AcpiDmDumpTable (Table->Length, Offset, ArmSubtable,
666ff879b07SJung-uk Kim Table->Length - Offset, AcpiDmTableInfoTpm211);
667ff879b07SJung-uk Kim break;
668ff879b07SJung-uk Kim
669ff879b07SJung-uk Kim default:
670ff879b07SJung-uk Kim break;
671ff879b07SJung-uk Kim }
672ff879b07SJung-uk Kim }
673ff879b07SJung-uk Kim
674ff879b07SJung-uk Kim
675ff879b07SJung-uk Kim /*******************************************************************************
676ff879b07SJung-uk Kim *
677cfd1ed46SJung-uk Kim * FUNCTION: AcpiDmDumpViot
678cfd1ed46SJung-uk Kim *
679cfd1ed46SJung-uk Kim * PARAMETERS: Table - A VIOT table
680cfd1ed46SJung-uk Kim *
681cfd1ed46SJung-uk Kim * RETURN: None
682cfd1ed46SJung-uk Kim *
683cfd1ed46SJung-uk Kim * DESCRIPTION: Format the contents of a VIOT
684cfd1ed46SJung-uk Kim *
685cfd1ed46SJung-uk Kim ******************************************************************************/
686cfd1ed46SJung-uk Kim
687cfd1ed46SJung-uk Kim void
AcpiDmDumpViot(ACPI_TABLE_HEADER * Table)688cfd1ed46SJung-uk Kim AcpiDmDumpViot (
689cfd1ed46SJung-uk Kim ACPI_TABLE_HEADER *Table)
690cfd1ed46SJung-uk Kim {
691cfd1ed46SJung-uk Kim ACPI_STATUS Status;
692cfd1ed46SJung-uk Kim ACPI_TABLE_VIOT *Viot;
693cfd1ed46SJung-uk Kim ACPI_VIOT_HEADER *ViotHeader;
694cfd1ed46SJung-uk Kim UINT16 Length;
69597c0b5abSJung-uk Kim UINT32 Offset;
696cfd1ed46SJung-uk Kim ACPI_DMTABLE_INFO *InfoTable;
697cfd1ed46SJung-uk Kim
698cfd1ed46SJung-uk Kim /* Main table */
699cfd1ed46SJung-uk Kim
700cfd1ed46SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoViot);
701cfd1ed46SJung-uk Kim if (ACPI_FAILURE (Status))
702cfd1ed46SJung-uk Kim {
703cfd1ed46SJung-uk Kim return;
704cfd1ed46SJung-uk Kim }
705cfd1ed46SJung-uk Kim
706cfd1ed46SJung-uk Kim Viot = ACPI_CAST_PTR (ACPI_TABLE_VIOT, Table);
707cfd1ed46SJung-uk Kim
708cfd1ed46SJung-uk Kim Offset = Viot->NodeOffset;
709cfd1ed46SJung-uk Kim while (Offset < Table->Length)
710cfd1ed46SJung-uk Kim {
711cfd1ed46SJung-uk Kim /* Common subtable header */
712cfd1ed46SJung-uk Kim ViotHeader = ACPI_ADD_PTR (ACPI_VIOT_HEADER, Table, Offset);
713cfd1ed46SJung-uk Kim AcpiOsPrintf ("\n");
714cfd1ed46SJung-uk Kim
715cfd1ed46SJung-uk Kim Length = sizeof (ACPI_VIOT_HEADER);
716cfd1ed46SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, ViotHeader, Length,
717cfd1ed46SJung-uk Kim AcpiDmTableInfoViotHeader);
718cfd1ed46SJung-uk Kim if (ACPI_FAILURE (Status))
719cfd1ed46SJung-uk Kim {
720cfd1ed46SJung-uk Kim return;
721cfd1ed46SJung-uk Kim }
722cfd1ed46SJung-uk Kim
723cfd1ed46SJung-uk Kim Length = ViotHeader->Length;
724cfd1ed46SJung-uk Kim switch (ViotHeader->Type)
725cfd1ed46SJung-uk Kim {
726cfd1ed46SJung-uk Kim case ACPI_VIOT_NODE_PCI_RANGE:
727cfd1ed46SJung-uk Kim
728cfd1ed46SJung-uk Kim InfoTable = AcpiDmTableInfoViot1;
729cfd1ed46SJung-uk Kim break;
730cfd1ed46SJung-uk Kim
731cfd1ed46SJung-uk Kim case ACPI_VIOT_NODE_MMIO:
732cfd1ed46SJung-uk Kim
733cfd1ed46SJung-uk Kim InfoTable = AcpiDmTableInfoViot2;
734cfd1ed46SJung-uk Kim break;
735cfd1ed46SJung-uk Kim
736cfd1ed46SJung-uk Kim case ACPI_VIOT_NODE_VIRTIO_IOMMU_PCI:
737cfd1ed46SJung-uk Kim
738cfd1ed46SJung-uk Kim InfoTable = AcpiDmTableInfoViot3;
739cfd1ed46SJung-uk Kim break;
740cfd1ed46SJung-uk Kim
741cfd1ed46SJung-uk Kim case ACPI_VIOT_NODE_VIRTIO_IOMMU_MMIO:
742cfd1ed46SJung-uk Kim
743cfd1ed46SJung-uk Kim InfoTable = AcpiDmTableInfoViot4;
744cfd1ed46SJung-uk Kim break;
745cfd1ed46SJung-uk Kim
746cfd1ed46SJung-uk Kim default:
747cfd1ed46SJung-uk Kim
748cfd1ed46SJung-uk Kim AcpiOsPrintf ("\n*** Unknown VIOT node type 0x%X\n",
749cfd1ed46SJung-uk Kim ViotHeader->Type);
750cfd1ed46SJung-uk Kim
751cfd1ed46SJung-uk Kim /* Attempt to continue */
752cfd1ed46SJung-uk Kim
753cfd1ed46SJung-uk Kim if (!Length)
754cfd1ed46SJung-uk Kim {
755cfd1ed46SJung-uk Kim AcpiOsPrintf ("Invalid zero length VIOT node\n");
756cfd1ed46SJung-uk Kim return;
757cfd1ed46SJung-uk Kim }
758cfd1ed46SJung-uk Kim goto NextSubtable;
759cfd1ed46SJung-uk Kim }
760cfd1ed46SJung-uk Kim
761cfd1ed46SJung-uk Kim AcpiOsPrintf ("\n");
762cfd1ed46SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, ViotHeader, Length,
763cfd1ed46SJung-uk Kim InfoTable);
764cfd1ed46SJung-uk Kim if (ACPI_FAILURE (Status))
765cfd1ed46SJung-uk Kim {
766cfd1ed46SJung-uk Kim return;
767cfd1ed46SJung-uk Kim }
768cfd1ed46SJung-uk Kim
769cfd1ed46SJung-uk Kim NextSubtable:
770cfd1ed46SJung-uk Kim Offset += Length;
771cfd1ed46SJung-uk Kim }
772cfd1ed46SJung-uk Kim }
773cfd1ed46SJung-uk Kim
774cfd1ed46SJung-uk Kim
775cfd1ed46SJung-uk Kim /*******************************************************************************
776cfd1ed46SJung-uk Kim *
777ff879b07SJung-uk Kim * FUNCTION: AcpiDmDumpWdat
778ff879b07SJung-uk Kim *
779ff879b07SJung-uk Kim * PARAMETERS: Table - A WDAT table
780ff879b07SJung-uk Kim *
781ff879b07SJung-uk Kim * RETURN: None
782ff879b07SJung-uk Kim *
783ff879b07SJung-uk Kim * DESCRIPTION: Format the contents of a WDAT
784ff879b07SJung-uk Kim *
785ff879b07SJung-uk Kim ******************************************************************************/
786ff879b07SJung-uk Kim
787ff879b07SJung-uk Kim void
AcpiDmDumpWdat(ACPI_TABLE_HEADER * Table)788ff879b07SJung-uk Kim AcpiDmDumpWdat (
789ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
790ff879b07SJung-uk Kim {
791ff879b07SJung-uk Kim ACPI_STATUS Status;
792ff879b07SJung-uk Kim UINT32 Offset = sizeof (ACPI_TABLE_WDAT);
793ff879b07SJung-uk Kim ACPI_WDAT_ENTRY *Subtable;
794ff879b07SJung-uk Kim
795ff879b07SJung-uk Kim
796ff879b07SJung-uk Kim /* Main table */
797ff879b07SJung-uk Kim
798ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoWdat);
799ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
800ff879b07SJung-uk Kim {
801ff879b07SJung-uk Kim return;
802ff879b07SJung-uk Kim }
803ff879b07SJung-uk Kim
804ff879b07SJung-uk Kim /* Subtables */
805ff879b07SJung-uk Kim
806ff879b07SJung-uk Kim Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Table, Offset);
807ff879b07SJung-uk Kim while (Offset < Table->Length)
808ff879b07SJung-uk Kim {
809ff879b07SJung-uk Kim /* Common subtable header */
810ff879b07SJung-uk Kim
811ff879b07SJung-uk Kim AcpiOsPrintf ("\n");
812ff879b07SJung-uk Kim Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
813ff879b07SJung-uk Kim sizeof (ACPI_WDAT_ENTRY), AcpiDmTableInfoWdat0);
814ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
815ff879b07SJung-uk Kim {
816ff879b07SJung-uk Kim return;
817ff879b07SJung-uk Kim }
818ff879b07SJung-uk Kim
819ff879b07SJung-uk Kim /* Point to next subtable */
820ff879b07SJung-uk Kim
821ff879b07SJung-uk Kim Offset += sizeof (ACPI_WDAT_ENTRY);
822ff879b07SJung-uk Kim Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Subtable,
823ff879b07SJung-uk Kim sizeof (ACPI_WDAT_ENTRY));
824ff879b07SJung-uk Kim }
825ff879b07SJung-uk Kim }
826ff879b07SJung-uk Kim
827ff879b07SJung-uk Kim
828ff879b07SJung-uk Kim /*******************************************************************************
829ff879b07SJung-uk Kim *
830ff879b07SJung-uk Kim * FUNCTION: AcpiDmDumpWpbt
831ff879b07SJung-uk Kim *
832ff879b07SJung-uk Kim * PARAMETERS: Table - A WPBT table
833ff879b07SJung-uk Kim *
834ff879b07SJung-uk Kim * RETURN: None
835ff879b07SJung-uk Kim *
836ff879b07SJung-uk Kim * DESCRIPTION: Format the contents of a WPBT. This table type consists
837ff879b07SJung-uk Kim * of an open-ended arguments buffer at the end of the table.
838ff879b07SJung-uk Kim *
839ff879b07SJung-uk Kim ******************************************************************************/
840ff879b07SJung-uk Kim
841ff879b07SJung-uk Kim void
AcpiDmDumpWpbt(ACPI_TABLE_HEADER * Table)842ff879b07SJung-uk Kim AcpiDmDumpWpbt (
843ff879b07SJung-uk Kim ACPI_TABLE_HEADER *Table)
844ff879b07SJung-uk Kim {
845ff879b07SJung-uk Kim ACPI_STATUS Status;
846ff879b07SJung-uk Kim ACPI_TABLE_WPBT *Subtable;
847ff879b07SJung-uk Kim UINT16 ArgumentsLength;
848ff879b07SJung-uk Kim
849ff879b07SJung-uk Kim
850ff879b07SJung-uk Kim /* Dump the main table */
851ff879b07SJung-uk Kim
85297c0b5abSJung-uk Kim Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoWpbt);
853ff879b07SJung-uk Kim if (ACPI_FAILURE (Status))
854ff879b07SJung-uk Kim {
855ff879b07SJung-uk Kim return;
856ff879b07SJung-uk Kim }
857ff879b07SJung-uk Kim
858ff879b07SJung-uk Kim /* Extract the arguments buffer length from the main table */
859ff879b07SJung-uk Kim
860ff879b07SJung-uk Kim Subtable = ACPI_CAST_PTR (ACPI_TABLE_WPBT, Table);
861ff879b07SJung-uk Kim ArgumentsLength = Subtable->ArgumentsLength;
862ff879b07SJung-uk Kim
86397c0b5abSJung-uk Kim /* Dump the arguments buffer if present */
864ff879b07SJung-uk Kim
86597c0b5abSJung-uk Kim if (ArgumentsLength)
86697c0b5abSJung-uk Kim {
867ff879b07SJung-uk Kim (void) AcpiDmDumpTable (Table->Length, 0, Table, ArgumentsLength,
868ff879b07SJung-uk Kim AcpiDmTableInfoWpbt0);
869ff879b07SJung-uk Kim }
87097c0b5abSJung-uk Kim }
871