xref: /freebsd/sys/contrib/dev/acpica/common/dmtbdump3.c (revision ff879b07996ba2a08ddcc37091c2636f1be8354c)
1*ff879b07SJung-uk Kim /******************************************************************************
2*ff879b07SJung-uk Kim  *
3*ff879b07SJung-uk Kim  * Module Name: dmtbdump3 - Dump ACPI data tables that contain no AML code
4*ff879b07SJung-uk Kim  *
5*ff879b07SJung-uk Kim  *****************************************************************************/
6*ff879b07SJung-uk Kim 
7*ff879b07SJung-uk Kim /******************************************************************************
8*ff879b07SJung-uk Kim  *
9*ff879b07SJung-uk Kim  * 1. Copyright Notice
10*ff879b07SJung-uk Kim  *
11*ff879b07SJung-uk Kim  * Some or all of this work - Copyright (c) 1999 - 2018, Intel Corp.
12*ff879b07SJung-uk Kim  * All rights reserved.
13*ff879b07SJung-uk Kim  *
14*ff879b07SJung-uk Kim  * 2. License
15*ff879b07SJung-uk Kim  *
16*ff879b07SJung-uk Kim  * 2.1. This is your license from Intel Corp. under its intellectual property
17*ff879b07SJung-uk Kim  * rights. You may have additional license terms from the party that provided
18*ff879b07SJung-uk Kim  * you this software, covering your right to use that party's intellectual
19*ff879b07SJung-uk Kim  * property rights.
20*ff879b07SJung-uk Kim  *
21*ff879b07SJung-uk Kim  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
22*ff879b07SJung-uk Kim  * copy of the source code appearing in this file ("Covered Code") an
23*ff879b07SJung-uk Kim  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
24*ff879b07SJung-uk Kim  * base code distributed originally by Intel ("Original Intel Code") to copy,
25*ff879b07SJung-uk Kim  * make derivatives, distribute, use and display any portion of the Covered
26*ff879b07SJung-uk Kim  * Code in any form, with the right to sublicense such rights; and
27*ff879b07SJung-uk Kim  *
28*ff879b07SJung-uk Kim  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
29*ff879b07SJung-uk Kim  * license (with the right to sublicense), under only those claims of Intel
30*ff879b07SJung-uk Kim  * patents that are infringed by the Original Intel Code, to make, use, sell,
31*ff879b07SJung-uk Kim  * offer to sell, and import the Covered Code and derivative works thereof
32*ff879b07SJung-uk Kim  * solely to the minimum extent necessary to exercise the above copyright
33*ff879b07SJung-uk Kim  * license, and in no event shall the patent license extend to any additions
34*ff879b07SJung-uk Kim  * to or modifications of the Original Intel Code. No other license or right
35*ff879b07SJung-uk Kim  * is granted directly or by implication, estoppel or otherwise;
36*ff879b07SJung-uk Kim  *
37*ff879b07SJung-uk Kim  * The above copyright and patent license is granted only if the following
38*ff879b07SJung-uk Kim  * conditions are met:
39*ff879b07SJung-uk Kim  *
40*ff879b07SJung-uk Kim  * 3. Conditions
41*ff879b07SJung-uk Kim  *
42*ff879b07SJung-uk Kim  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
43*ff879b07SJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
44*ff879b07SJung-uk Kim  * Code or modification with rights to further distribute source must include
45*ff879b07SJung-uk Kim  * the above Copyright Notice, the above License, this list of Conditions,
46*ff879b07SJung-uk Kim  * and the following Disclaimer and Export Compliance provision. In addition,
47*ff879b07SJung-uk Kim  * Licensee must cause all Covered Code to which Licensee contributes to
48*ff879b07SJung-uk Kim  * contain a file documenting the changes Licensee made to create that Covered
49*ff879b07SJung-uk Kim  * Code and the date of any change. Licensee must include in that file the
50*ff879b07SJung-uk Kim  * documentation of any changes made by any predecessor Licensee. Licensee
51*ff879b07SJung-uk Kim  * must include a prominent statement that the modification is derived,
52*ff879b07SJung-uk Kim  * directly or indirectly, from Original Intel Code.
53*ff879b07SJung-uk Kim  *
54*ff879b07SJung-uk Kim  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
55*ff879b07SJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
56*ff879b07SJung-uk Kim  * Code or modification without rights to further distribute source must
57*ff879b07SJung-uk Kim  * include the following Disclaimer and Export Compliance provision in the
58*ff879b07SJung-uk Kim  * documentation and/or other materials provided with distribution. In
59*ff879b07SJung-uk Kim  * addition, Licensee may not authorize further sublicense of source of any
60*ff879b07SJung-uk Kim  * portion of the Covered Code, and must include terms to the effect that the
61*ff879b07SJung-uk Kim  * license from Licensee to its licensee is limited to the intellectual
62*ff879b07SJung-uk Kim  * property embodied in the software Licensee provides to its licensee, and
63*ff879b07SJung-uk Kim  * not to intellectual property embodied in modifications its licensee may
64*ff879b07SJung-uk Kim  * make.
65*ff879b07SJung-uk Kim  *
66*ff879b07SJung-uk Kim  * 3.3. Redistribution of Executable. Redistribution in executable form of any
67*ff879b07SJung-uk Kim  * substantial portion of the Covered Code or modification must reproduce the
68*ff879b07SJung-uk Kim  * above Copyright Notice, and the following Disclaimer and Export Compliance
69*ff879b07SJung-uk Kim  * provision in the documentation and/or other materials provided with the
70*ff879b07SJung-uk Kim  * distribution.
71*ff879b07SJung-uk Kim  *
72*ff879b07SJung-uk Kim  * 3.4. Intel retains all right, title, and interest in and to the Original
73*ff879b07SJung-uk Kim  * Intel Code.
74*ff879b07SJung-uk Kim  *
75*ff879b07SJung-uk Kim  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
76*ff879b07SJung-uk Kim  * Intel shall be used in advertising or otherwise to promote the sale, use or
77*ff879b07SJung-uk Kim  * other dealings in products derived from or relating to the Covered Code
78*ff879b07SJung-uk Kim  * without prior written authorization from Intel.
79*ff879b07SJung-uk Kim  *
80*ff879b07SJung-uk Kim  * 4. Disclaimer and Export Compliance
81*ff879b07SJung-uk Kim  *
82*ff879b07SJung-uk Kim  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
83*ff879b07SJung-uk Kim  * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
84*ff879b07SJung-uk Kim  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
85*ff879b07SJung-uk Kim  * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
86*ff879b07SJung-uk Kim  * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
87*ff879b07SJung-uk Kim  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
88*ff879b07SJung-uk Kim  * PARTICULAR PURPOSE.
89*ff879b07SJung-uk Kim  *
90*ff879b07SJung-uk Kim  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
91*ff879b07SJung-uk Kim  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
92*ff879b07SJung-uk Kim  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
93*ff879b07SJung-uk Kim  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
94*ff879b07SJung-uk Kim  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
95*ff879b07SJung-uk Kim  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
96*ff879b07SJung-uk Kim  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
97*ff879b07SJung-uk Kim  * LIMITED REMEDY.
98*ff879b07SJung-uk Kim  *
99*ff879b07SJung-uk Kim  * 4.3. Licensee shall not export, either directly or indirectly, any of this
100*ff879b07SJung-uk Kim  * software or system incorporating such software without first obtaining any
101*ff879b07SJung-uk Kim  * required license or other approval from the U. S. Department of Commerce or
102*ff879b07SJung-uk Kim  * any other agency or department of the United States Government. In the
103*ff879b07SJung-uk Kim  * event Licensee exports any such software from the United States or
104*ff879b07SJung-uk Kim  * re-exports any such software from a foreign destination, Licensee shall
105*ff879b07SJung-uk Kim  * ensure that the distribution and export/re-export of the software is in
106*ff879b07SJung-uk Kim  * compliance with all laws, regulations, orders, or other restrictions of the
107*ff879b07SJung-uk Kim  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
108*ff879b07SJung-uk Kim  * any of its subsidiaries will export/re-export any technical data, process,
109*ff879b07SJung-uk Kim  * software, or service, directly or indirectly, to any country for which the
110*ff879b07SJung-uk Kim  * United States government or any agency thereof requires an export license,
111*ff879b07SJung-uk Kim  * other governmental approval, or letter of assurance, without first obtaining
112*ff879b07SJung-uk Kim  * such license, approval or letter.
113*ff879b07SJung-uk Kim  *
114*ff879b07SJung-uk Kim  *****************************************************************************
115*ff879b07SJung-uk Kim  *
116*ff879b07SJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
117*ff879b07SJung-uk Kim  * following license:
118*ff879b07SJung-uk Kim  *
119*ff879b07SJung-uk Kim  * Redistribution and use in source and binary forms, with or without
120*ff879b07SJung-uk Kim  * modification, are permitted provided that the following conditions
121*ff879b07SJung-uk Kim  * are met:
122*ff879b07SJung-uk Kim  * 1. Redistributions of source code must retain the above copyright
123*ff879b07SJung-uk Kim  *    notice, this list of conditions, and the following disclaimer,
124*ff879b07SJung-uk Kim  *    without modification.
125*ff879b07SJung-uk Kim  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
126*ff879b07SJung-uk Kim  *    substantially similar to the "NO WARRANTY" disclaimer below
127*ff879b07SJung-uk Kim  *    ("Disclaimer") and any redistribution must be conditioned upon
128*ff879b07SJung-uk Kim  *    including a substantially similar Disclaimer requirement for further
129*ff879b07SJung-uk Kim  *    binary redistribution.
130*ff879b07SJung-uk Kim  * 3. Neither the names of the above-listed copyright holders nor the names
131*ff879b07SJung-uk Kim  *    of any contributors may be used to endorse or promote products derived
132*ff879b07SJung-uk Kim  *    from this software without specific prior written permission.
133*ff879b07SJung-uk Kim  *
134*ff879b07SJung-uk Kim  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
135*ff879b07SJung-uk Kim  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
136*ff879b07SJung-uk Kim  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
137*ff879b07SJung-uk Kim  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
138*ff879b07SJung-uk Kim  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
139*ff879b07SJung-uk Kim  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
140*ff879b07SJung-uk Kim  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
141*ff879b07SJung-uk Kim  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
142*ff879b07SJung-uk Kim  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
143*ff879b07SJung-uk Kim  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
144*ff879b07SJung-uk Kim  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
145*ff879b07SJung-uk Kim  *
146*ff879b07SJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
147*ff879b07SJung-uk Kim  * GNU General Public License ("GPL") version 2 as published by the Free
148*ff879b07SJung-uk Kim  * Software Foundation.
149*ff879b07SJung-uk Kim  *
150*ff879b07SJung-uk Kim  *****************************************************************************/
151*ff879b07SJung-uk Kim 
152*ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/acpi.h>
153*ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/accommon.h>
154*ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/acdisasm.h>
155*ff879b07SJung-uk Kim #include <contrib/dev/acpica/include/actables.h>
156*ff879b07SJung-uk Kim 
157*ff879b07SJung-uk Kim /* This module used for application-level code only */
158*ff879b07SJung-uk Kim 
159*ff879b07SJung-uk Kim #define _COMPONENT          ACPI_CA_DISASSEMBLER
160*ff879b07SJung-uk Kim         ACPI_MODULE_NAME    ("dmtbdump3")
161*ff879b07SJung-uk Kim 
162*ff879b07SJung-uk Kim 
163*ff879b07SJung-uk Kim /*******************************************************************************
164*ff879b07SJung-uk Kim  *
165*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpSlic
166*ff879b07SJung-uk Kim  *
167*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A SLIC table
168*ff879b07SJung-uk Kim  *
169*ff879b07SJung-uk Kim  * RETURN:      None
170*ff879b07SJung-uk Kim  *
171*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a SLIC
172*ff879b07SJung-uk Kim  *
173*ff879b07SJung-uk Kim  ******************************************************************************/
174*ff879b07SJung-uk Kim 
175*ff879b07SJung-uk Kim void
176*ff879b07SJung-uk Kim AcpiDmDumpSlic (
177*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
178*ff879b07SJung-uk Kim {
179*ff879b07SJung-uk Kim 
180*ff879b07SJung-uk Kim     (void) AcpiDmDumpTable (Table->Length, sizeof (ACPI_TABLE_HEADER), Table,
181*ff879b07SJung-uk Kim         Table->Length - sizeof (*Table), AcpiDmTableInfoSlic);
182*ff879b07SJung-uk Kim }
183*ff879b07SJung-uk Kim 
184*ff879b07SJung-uk Kim 
185*ff879b07SJung-uk Kim /*******************************************************************************
186*ff879b07SJung-uk Kim  *
187*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpSlit
188*ff879b07SJung-uk Kim  *
189*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - An SLIT
190*ff879b07SJung-uk Kim  *
191*ff879b07SJung-uk Kim  * RETURN:      None
192*ff879b07SJung-uk Kim  *
193*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a SLIT
194*ff879b07SJung-uk Kim  *
195*ff879b07SJung-uk Kim  ******************************************************************************/
196*ff879b07SJung-uk Kim 
197*ff879b07SJung-uk Kim void
198*ff879b07SJung-uk Kim AcpiDmDumpSlit (
199*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
200*ff879b07SJung-uk Kim {
201*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
202*ff879b07SJung-uk Kim     UINT32                  Offset;
203*ff879b07SJung-uk Kim     UINT8                   *Row;
204*ff879b07SJung-uk Kim     UINT32                  Localities;
205*ff879b07SJung-uk Kim     UINT32                  i;
206*ff879b07SJung-uk Kim     UINT32                  j;
207*ff879b07SJung-uk Kim 
208*ff879b07SJung-uk Kim 
209*ff879b07SJung-uk Kim     /* Main table */
210*ff879b07SJung-uk Kim 
211*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSlit);
212*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
213*ff879b07SJung-uk Kim     {
214*ff879b07SJung-uk Kim         return;
215*ff879b07SJung-uk Kim     }
216*ff879b07SJung-uk Kim 
217*ff879b07SJung-uk Kim     /* Display the Locality NxN Matrix */
218*ff879b07SJung-uk Kim 
219*ff879b07SJung-uk Kim     Localities = (UINT32) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->LocalityCount;
220*ff879b07SJung-uk Kim     Offset = ACPI_OFFSET (ACPI_TABLE_SLIT, Entry[0]);
221*ff879b07SJung-uk Kim     Row = (UINT8 *) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->Entry;
222*ff879b07SJung-uk Kim 
223*ff879b07SJung-uk Kim     for (i = 0; i < Localities; i++)
224*ff879b07SJung-uk Kim     {
225*ff879b07SJung-uk Kim         /* Display one row of the matrix */
226*ff879b07SJung-uk Kim 
227*ff879b07SJung-uk Kim         AcpiDmLineHeader2 (Offset, Localities, "Locality", i);
228*ff879b07SJung-uk Kim         for  (j = 0; j < Localities; j++)
229*ff879b07SJung-uk Kim         {
230*ff879b07SJung-uk Kim             /* Check for beyond EOT */
231*ff879b07SJung-uk Kim 
232*ff879b07SJung-uk Kim             if (Offset >= Table->Length)
233*ff879b07SJung-uk Kim             {
234*ff879b07SJung-uk Kim                 AcpiOsPrintf (
235*ff879b07SJung-uk Kim                     "\n**** Not enough room in table for all localities\n");
236*ff879b07SJung-uk Kim                 return;
237*ff879b07SJung-uk Kim             }
238*ff879b07SJung-uk Kim 
239*ff879b07SJung-uk Kim             AcpiOsPrintf ("%2.2X", Row[j]);
240*ff879b07SJung-uk Kim             Offset++;
241*ff879b07SJung-uk Kim 
242*ff879b07SJung-uk Kim             /* Display up to 16 bytes per output row */
243*ff879b07SJung-uk Kim 
244*ff879b07SJung-uk Kim             if ((j+1) < Localities)
245*ff879b07SJung-uk Kim             {
246*ff879b07SJung-uk Kim                 AcpiOsPrintf (" ");
247*ff879b07SJung-uk Kim 
248*ff879b07SJung-uk Kim                 if (j && (((j+1) % 16) == 0))
249*ff879b07SJung-uk Kim                 {
250*ff879b07SJung-uk Kim                     AcpiOsPrintf ("\\\n"); /* With line continuation char */
251*ff879b07SJung-uk Kim                     AcpiDmLineHeader (Offset, 0, NULL);
252*ff879b07SJung-uk Kim                 }
253*ff879b07SJung-uk Kim             }
254*ff879b07SJung-uk Kim         }
255*ff879b07SJung-uk Kim 
256*ff879b07SJung-uk Kim         /* Point to next row */
257*ff879b07SJung-uk Kim 
258*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
259*ff879b07SJung-uk Kim         Row += Localities;
260*ff879b07SJung-uk Kim     }
261*ff879b07SJung-uk Kim }
262*ff879b07SJung-uk Kim 
263*ff879b07SJung-uk Kim 
264*ff879b07SJung-uk Kim /*******************************************************************************
265*ff879b07SJung-uk Kim  *
266*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpSrat
267*ff879b07SJung-uk Kim  *
268*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A SRAT table
269*ff879b07SJung-uk Kim  *
270*ff879b07SJung-uk Kim  * RETURN:      None
271*ff879b07SJung-uk Kim  *
272*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a SRAT
273*ff879b07SJung-uk Kim  *
274*ff879b07SJung-uk Kim  ******************************************************************************/
275*ff879b07SJung-uk Kim 
276*ff879b07SJung-uk Kim void
277*ff879b07SJung-uk Kim AcpiDmDumpSrat (
278*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
279*ff879b07SJung-uk Kim {
280*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
281*ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_SRAT);
282*ff879b07SJung-uk Kim     ACPI_SUBTABLE_HEADER    *Subtable;
283*ff879b07SJung-uk Kim     ACPI_DMTABLE_INFO       *InfoTable;
284*ff879b07SJung-uk Kim 
285*ff879b07SJung-uk Kim 
286*ff879b07SJung-uk Kim     /* Main table */
287*ff879b07SJung-uk Kim 
288*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSrat);
289*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
290*ff879b07SJung-uk Kim     {
291*ff879b07SJung-uk Kim         return;
292*ff879b07SJung-uk Kim     }
293*ff879b07SJung-uk Kim 
294*ff879b07SJung-uk Kim     /* Subtables */
295*ff879b07SJung-uk Kim 
296*ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Table, Offset);
297*ff879b07SJung-uk Kim     while (Offset < Table->Length)
298*ff879b07SJung-uk Kim     {
299*ff879b07SJung-uk Kim         /* Common subtable header */
300*ff879b07SJung-uk Kim 
301*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
302*ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
303*ff879b07SJung-uk Kim             Subtable->Length, AcpiDmTableInfoSratHdr);
304*ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
305*ff879b07SJung-uk Kim         {
306*ff879b07SJung-uk Kim             return;
307*ff879b07SJung-uk Kim         }
308*ff879b07SJung-uk Kim 
309*ff879b07SJung-uk Kim         switch (Subtable->Type)
310*ff879b07SJung-uk Kim         {
311*ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_CPU_AFFINITY:
312*ff879b07SJung-uk Kim 
313*ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat0;
314*ff879b07SJung-uk Kim             break;
315*ff879b07SJung-uk Kim 
316*ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_MEMORY_AFFINITY:
317*ff879b07SJung-uk Kim 
318*ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat1;
319*ff879b07SJung-uk Kim             break;
320*ff879b07SJung-uk Kim 
321*ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY:
322*ff879b07SJung-uk Kim 
323*ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat2;
324*ff879b07SJung-uk Kim             break;
325*ff879b07SJung-uk Kim 
326*ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_GICC_AFFINITY:
327*ff879b07SJung-uk Kim 
328*ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat3;
329*ff879b07SJung-uk Kim             break;
330*ff879b07SJung-uk Kim 
331*ff879b07SJung-uk Kim         case ACPI_SRAT_TYPE_GIC_ITS_AFFINITY:
332*ff879b07SJung-uk Kim 
333*ff879b07SJung-uk Kim             InfoTable = AcpiDmTableInfoSrat4;
334*ff879b07SJung-uk Kim             break;
335*ff879b07SJung-uk Kim 
336*ff879b07SJung-uk Kim         default:
337*ff879b07SJung-uk Kim             AcpiOsPrintf ("\n**** Unknown SRAT subtable type 0x%X\n",
338*ff879b07SJung-uk Kim                 Subtable->Type);
339*ff879b07SJung-uk Kim 
340*ff879b07SJung-uk Kim             /* Attempt to continue */
341*ff879b07SJung-uk Kim 
342*ff879b07SJung-uk Kim             if (!Subtable->Length)
343*ff879b07SJung-uk Kim             {
344*ff879b07SJung-uk Kim                 AcpiOsPrintf ("Invalid zero length subtable\n");
345*ff879b07SJung-uk Kim                 return;
346*ff879b07SJung-uk Kim             }
347*ff879b07SJung-uk Kim             goto NextSubtable;
348*ff879b07SJung-uk Kim         }
349*ff879b07SJung-uk Kim 
350*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
351*ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
352*ff879b07SJung-uk Kim             Subtable->Length, InfoTable);
353*ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
354*ff879b07SJung-uk Kim         {
355*ff879b07SJung-uk Kim             return;
356*ff879b07SJung-uk Kim         }
357*ff879b07SJung-uk Kim 
358*ff879b07SJung-uk Kim NextSubtable:
359*ff879b07SJung-uk Kim         /* Point to next subtable */
360*ff879b07SJung-uk Kim 
361*ff879b07SJung-uk Kim         Offset += Subtable->Length;
362*ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Subtable,
363*ff879b07SJung-uk Kim             Subtable->Length);
364*ff879b07SJung-uk Kim     }
365*ff879b07SJung-uk Kim }
366*ff879b07SJung-uk Kim 
367*ff879b07SJung-uk Kim 
368*ff879b07SJung-uk Kim /*******************************************************************************
369*ff879b07SJung-uk Kim  *
370*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpStao
371*ff879b07SJung-uk Kim  *
372*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A STAO table
373*ff879b07SJung-uk Kim  *
374*ff879b07SJung-uk Kim  * RETURN:      None
375*ff879b07SJung-uk Kim  *
376*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a STAO. This is a variable-length
377*ff879b07SJung-uk Kim  *              table that contains an open-ended number of ASCII strings
378*ff879b07SJung-uk Kim  *              at the end of the table.
379*ff879b07SJung-uk Kim  *
380*ff879b07SJung-uk Kim  ******************************************************************************/
381*ff879b07SJung-uk Kim 
382*ff879b07SJung-uk Kim void
383*ff879b07SJung-uk Kim AcpiDmDumpStao (
384*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
385*ff879b07SJung-uk Kim {
386*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
387*ff879b07SJung-uk Kim     char                    *Namepath;
388*ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
389*ff879b07SJung-uk Kim     UINT32                  StringLength;
390*ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_STAO);
391*ff879b07SJung-uk Kim 
392*ff879b07SJung-uk Kim 
393*ff879b07SJung-uk Kim     /* Main table */
394*ff879b07SJung-uk Kim 
395*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoStao);
396*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
397*ff879b07SJung-uk Kim     {
398*ff879b07SJung-uk Kim         return;
399*ff879b07SJung-uk Kim     }
400*ff879b07SJung-uk Kim 
401*ff879b07SJung-uk Kim     /* The rest of the table consists of Namepath strings */
402*ff879b07SJung-uk Kim 
403*ff879b07SJung-uk Kim     while (Offset < Table->Length)
404*ff879b07SJung-uk Kim     {
405*ff879b07SJung-uk Kim         Namepath = ACPI_ADD_PTR (char, Table, Offset);
406*ff879b07SJung-uk Kim         StringLength = strlen (Namepath) + 1;
407*ff879b07SJung-uk Kim 
408*ff879b07SJung-uk Kim         AcpiDmLineHeader (Offset, StringLength, "Namestring");
409*ff879b07SJung-uk Kim         AcpiOsPrintf ("\"%s\"\n", Namepath);
410*ff879b07SJung-uk Kim 
411*ff879b07SJung-uk Kim         /* Point to next namepath */
412*ff879b07SJung-uk Kim 
413*ff879b07SJung-uk Kim         Offset += StringLength;
414*ff879b07SJung-uk Kim     }
415*ff879b07SJung-uk Kim }
416*ff879b07SJung-uk Kim 
417*ff879b07SJung-uk Kim 
418*ff879b07SJung-uk Kim /*******************************************************************************
419*ff879b07SJung-uk Kim  *
420*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpTcpa
421*ff879b07SJung-uk Kim  *
422*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A TCPA table
423*ff879b07SJung-uk Kim  *
424*ff879b07SJung-uk Kim  * RETURN:      None
425*ff879b07SJung-uk Kim  *
426*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a TCPA.
427*ff879b07SJung-uk Kim  *
428*ff879b07SJung-uk Kim  * NOTE:        There are two versions of the table with the same signature:
429*ff879b07SJung-uk Kim  *              the client version and the server version. The common
430*ff879b07SJung-uk Kim  *              PlatformClass field is used to differentiate the two types of
431*ff879b07SJung-uk Kim  *              tables.
432*ff879b07SJung-uk Kim  *
433*ff879b07SJung-uk Kim  ******************************************************************************/
434*ff879b07SJung-uk Kim 
435*ff879b07SJung-uk Kim void
436*ff879b07SJung-uk Kim AcpiDmDumpTcpa (
437*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
438*ff879b07SJung-uk Kim {
439*ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_TCPA_HDR);
440*ff879b07SJung-uk Kim     ACPI_TABLE_TCPA_HDR     *CommonHeader = ACPI_CAST_PTR (
441*ff879b07SJung-uk Kim                                 ACPI_TABLE_TCPA_HDR, Table);
442*ff879b07SJung-uk Kim     ACPI_TABLE_TCPA_HDR     *Subtable = ACPI_ADD_PTR (
443*ff879b07SJung-uk Kim                                 ACPI_TABLE_TCPA_HDR, Table, Offset);
444*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
445*ff879b07SJung-uk Kim 
446*ff879b07SJung-uk Kim 
447*ff879b07SJung-uk Kim     /* Main table */
448*ff879b07SJung-uk Kim 
449*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table,
450*ff879b07SJung-uk Kim         0, AcpiDmTableInfoTcpaHdr);
451*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
452*ff879b07SJung-uk Kim     {
453*ff879b07SJung-uk Kim         return;
454*ff879b07SJung-uk Kim     }
455*ff879b07SJung-uk Kim 
456*ff879b07SJung-uk Kim     /*
457*ff879b07SJung-uk Kim      * Examine the PlatformClass field to determine the table type.
458*ff879b07SJung-uk Kim      * Either a client or server table. Only one.
459*ff879b07SJung-uk Kim      */
460*ff879b07SJung-uk Kim     switch (CommonHeader->PlatformClass)
461*ff879b07SJung-uk Kim     {
462*ff879b07SJung-uk Kim     case ACPI_TCPA_CLIENT_TABLE:
463*ff879b07SJung-uk Kim 
464*ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
465*ff879b07SJung-uk Kim             Table->Length - Offset, AcpiDmTableInfoTcpaClient);
466*ff879b07SJung-uk Kim         break;
467*ff879b07SJung-uk Kim 
468*ff879b07SJung-uk Kim     case ACPI_TCPA_SERVER_TABLE:
469*ff879b07SJung-uk Kim 
470*ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
471*ff879b07SJung-uk Kim             Table->Length - Offset, AcpiDmTableInfoTcpaServer);
472*ff879b07SJung-uk Kim         break;
473*ff879b07SJung-uk Kim 
474*ff879b07SJung-uk Kim     default:
475*ff879b07SJung-uk Kim 
476*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n**** Unknown TCPA Platform Class 0x%X\n",
477*ff879b07SJung-uk Kim             CommonHeader->PlatformClass);
478*ff879b07SJung-uk Kim         Status = AE_ERROR;
479*ff879b07SJung-uk Kim         break;
480*ff879b07SJung-uk Kim     }
481*ff879b07SJung-uk Kim 
482*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
483*ff879b07SJung-uk Kim     {
484*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n**** Cannot disassemble TCPA table\n");
485*ff879b07SJung-uk Kim     }
486*ff879b07SJung-uk Kim }
487*ff879b07SJung-uk Kim 
488*ff879b07SJung-uk Kim 
489*ff879b07SJung-uk Kim /*******************************************************************************
490*ff879b07SJung-uk Kim  *
491*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpTpm2
492*ff879b07SJung-uk Kim  *
493*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A TPM2 table
494*ff879b07SJung-uk Kim  *
495*ff879b07SJung-uk Kim  * RETURN:      None
496*ff879b07SJung-uk Kim  *
497*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a TPM2.
498*ff879b07SJung-uk Kim  *
499*ff879b07SJung-uk Kim  ******************************************************************************/
500*ff879b07SJung-uk Kim 
501*ff879b07SJung-uk Kim void
502*ff879b07SJung-uk Kim AcpiDmDumpTpm2 (
503*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
504*ff879b07SJung-uk Kim {
505*ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_TPM2);
506*ff879b07SJung-uk Kim     ACPI_TABLE_TPM2         *CommonHeader = ACPI_CAST_PTR (ACPI_TABLE_TPM2, Table);
507*ff879b07SJung-uk Kim     ACPI_TPM2_TRAILER       *Subtable = ACPI_ADD_PTR (ACPI_TPM2_TRAILER, Table, Offset);
508*ff879b07SJung-uk Kim     ACPI_TPM2_ARM_SMC       *ArmSubtable;
509*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
510*ff879b07SJung-uk Kim 
511*ff879b07SJung-uk Kim 
512*ff879b07SJung-uk Kim     /* Main table */
513*ff879b07SJung-uk Kim 
514*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoTpm2);
515*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
516*ff879b07SJung-uk Kim     {
517*ff879b07SJung-uk Kim         return;
518*ff879b07SJung-uk Kim     }
519*ff879b07SJung-uk Kim 
520*ff879b07SJung-uk Kim     AcpiOsPrintf ("\n");
521*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
522*ff879b07SJung-uk Kim         Table->Length - Offset, AcpiDmTableInfoTpm2a);
523*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
524*ff879b07SJung-uk Kim     {
525*ff879b07SJung-uk Kim         return;
526*ff879b07SJung-uk Kim     }
527*ff879b07SJung-uk Kim 
528*ff879b07SJung-uk Kim     switch (CommonHeader->StartMethod)
529*ff879b07SJung-uk Kim     {
530*ff879b07SJung-uk Kim     case ACPI_TPM2_COMMAND_BUFFER_WITH_ARM_SMC:
531*ff879b07SJung-uk Kim 
532*ff879b07SJung-uk Kim         ArmSubtable = ACPI_ADD_PTR (ACPI_TPM2_ARM_SMC, Subtable,
533*ff879b07SJung-uk Kim             sizeof (ACPI_TPM2_TRAILER));
534*ff879b07SJung-uk Kim         Offset += sizeof (ACPI_TPM2_TRAILER);
535*ff879b07SJung-uk Kim 
536*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
537*ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, ArmSubtable,
538*ff879b07SJung-uk Kim             Table->Length - Offset, AcpiDmTableInfoTpm211);
539*ff879b07SJung-uk Kim         break;
540*ff879b07SJung-uk Kim 
541*ff879b07SJung-uk Kim     default:
542*ff879b07SJung-uk Kim         break;
543*ff879b07SJung-uk Kim     }
544*ff879b07SJung-uk Kim }
545*ff879b07SJung-uk Kim 
546*ff879b07SJung-uk Kim 
547*ff879b07SJung-uk Kim /*******************************************************************************
548*ff879b07SJung-uk Kim  *
549*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpVrtc
550*ff879b07SJung-uk Kim  *
551*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A VRTC table
552*ff879b07SJung-uk Kim  *
553*ff879b07SJung-uk Kim  * RETURN:      None
554*ff879b07SJung-uk Kim  *
555*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a VRTC
556*ff879b07SJung-uk Kim  *
557*ff879b07SJung-uk Kim  ******************************************************************************/
558*ff879b07SJung-uk Kim 
559*ff879b07SJung-uk Kim void
560*ff879b07SJung-uk Kim AcpiDmDumpVrtc (
561*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
562*ff879b07SJung-uk Kim {
563*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
564*ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_VRTC);
565*ff879b07SJung-uk Kim     ACPI_VRTC_ENTRY         *Subtable;
566*ff879b07SJung-uk Kim 
567*ff879b07SJung-uk Kim 
568*ff879b07SJung-uk Kim     /* Main table */
569*ff879b07SJung-uk Kim 
570*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoVrtc);
571*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
572*ff879b07SJung-uk Kim     {
573*ff879b07SJung-uk Kim         return;
574*ff879b07SJung-uk Kim     }
575*ff879b07SJung-uk Kim 
576*ff879b07SJung-uk Kim     /* Subtables */
577*ff879b07SJung-uk Kim 
578*ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_VRTC_ENTRY, Table, Offset);
579*ff879b07SJung-uk Kim     while (Offset < Table->Length)
580*ff879b07SJung-uk Kim     {
581*ff879b07SJung-uk Kim         /* Common subtable header */
582*ff879b07SJung-uk Kim 
583*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
584*ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
585*ff879b07SJung-uk Kim             sizeof (ACPI_VRTC_ENTRY), AcpiDmTableInfoVrtc0);
586*ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
587*ff879b07SJung-uk Kim         {
588*ff879b07SJung-uk Kim             return;
589*ff879b07SJung-uk Kim         }
590*ff879b07SJung-uk Kim 
591*ff879b07SJung-uk Kim         /* Point to next subtable */
592*ff879b07SJung-uk Kim 
593*ff879b07SJung-uk Kim         Offset += sizeof (ACPI_VRTC_ENTRY);
594*ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_VRTC_ENTRY, Subtable,
595*ff879b07SJung-uk Kim             sizeof (ACPI_VRTC_ENTRY));
596*ff879b07SJung-uk Kim     }
597*ff879b07SJung-uk Kim }
598*ff879b07SJung-uk Kim 
599*ff879b07SJung-uk Kim 
600*ff879b07SJung-uk Kim /*******************************************************************************
601*ff879b07SJung-uk Kim  *
602*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpWdat
603*ff879b07SJung-uk Kim  *
604*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A WDAT table
605*ff879b07SJung-uk Kim  *
606*ff879b07SJung-uk Kim  * RETURN:      None
607*ff879b07SJung-uk Kim  *
608*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a WDAT
609*ff879b07SJung-uk Kim  *
610*ff879b07SJung-uk Kim  ******************************************************************************/
611*ff879b07SJung-uk Kim 
612*ff879b07SJung-uk Kim void
613*ff879b07SJung-uk Kim AcpiDmDumpWdat (
614*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
615*ff879b07SJung-uk Kim {
616*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
617*ff879b07SJung-uk Kim     UINT32                  Offset = sizeof (ACPI_TABLE_WDAT);
618*ff879b07SJung-uk Kim     ACPI_WDAT_ENTRY         *Subtable;
619*ff879b07SJung-uk Kim 
620*ff879b07SJung-uk Kim 
621*ff879b07SJung-uk Kim     /* Main table */
622*ff879b07SJung-uk Kim 
623*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoWdat);
624*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
625*ff879b07SJung-uk Kim     {
626*ff879b07SJung-uk Kim         return;
627*ff879b07SJung-uk Kim     }
628*ff879b07SJung-uk Kim 
629*ff879b07SJung-uk Kim     /* Subtables */
630*ff879b07SJung-uk Kim 
631*ff879b07SJung-uk Kim     Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Table, Offset);
632*ff879b07SJung-uk Kim     while (Offset < Table->Length)
633*ff879b07SJung-uk Kim     {
634*ff879b07SJung-uk Kim         /* Common subtable header */
635*ff879b07SJung-uk Kim 
636*ff879b07SJung-uk Kim         AcpiOsPrintf ("\n");
637*ff879b07SJung-uk Kim         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
638*ff879b07SJung-uk Kim             sizeof (ACPI_WDAT_ENTRY), AcpiDmTableInfoWdat0);
639*ff879b07SJung-uk Kim         if (ACPI_FAILURE (Status))
640*ff879b07SJung-uk Kim         {
641*ff879b07SJung-uk Kim             return;
642*ff879b07SJung-uk Kim         }
643*ff879b07SJung-uk Kim 
644*ff879b07SJung-uk Kim         /* Point to next subtable */
645*ff879b07SJung-uk Kim 
646*ff879b07SJung-uk Kim         Offset += sizeof (ACPI_WDAT_ENTRY);
647*ff879b07SJung-uk Kim         Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Subtable,
648*ff879b07SJung-uk Kim             sizeof (ACPI_WDAT_ENTRY));
649*ff879b07SJung-uk Kim     }
650*ff879b07SJung-uk Kim }
651*ff879b07SJung-uk Kim 
652*ff879b07SJung-uk Kim 
653*ff879b07SJung-uk Kim /*******************************************************************************
654*ff879b07SJung-uk Kim  *
655*ff879b07SJung-uk Kim  * FUNCTION:    AcpiDmDumpWpbt
656*ff879b07SJung-uk Kim  *
657*ff879b07SJung-uk Kim  * PARAMETERS:  Table               - A WPBT table
658*ff879b07SJung-uk Kim  *
659*ff879b07SJung-uk Kim  * RETURN:      None
660*ff879b07SJung-uk Kim  *
661*ff879b07SJung-uk Kim  * DESCRIPTION: Format the contents of a WPBT. This table type consists
662*ff879b07SJung-uk Kim  *              of an open-ended arguments buffer at the end of the table.
663*ff879b07SJung-uk Kim  *
664*ff879b07SJung-uk Kim  ******************************************************************************/
665*ff879b07SJung-uk Kim 
666*ff879b07SJung-uk Kim void
667*ff879b07SJung-uk Kim AcpiDmDumpWpbt (
668*ff879b07SJung-uk Kim     ACPI_TABLE_HEADER       *Table)
669*ff879b07SJung-uk Kim {
670*ff879b07SJung-uk Kim     ACPI_STATUS             Status;
671*ff879b07SJung-uk Kim     ACPI_TABLE_WPBT         *Subtable;
672*ff879b07SJung-uk Kim     UINT32                  Length = Table->Length;
673*ff879b07SJung-uk Kim     UINT16                  ArgumentsLength;
674*ff879b07SJung-uk Kim 
675*ff879b07SJung-uk Kim 
676*ff879b07SJung-uk Kim     /* Dump the main table */
677*ff879b07SJung-uk Kim 
678*ff879b07SJung-uk Kim     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoWpbt);
679*ff879b07SJung-uk Kim     if (ACPI_FAILURE (Status))
680*ff879b07SJung-uk Kim     {
681*ff879b07SJung-uk Kim         return;
682*ff879b07SJung-uk Kim     }
683*ff879b07SJung-uk Kim 
684*ff879b07SJung-uk Kim     /* Extract the arguments buffer length from the main table */
685*ff879b07SJung-uk Kim 
686*ff879b07SJung-uk Kim     Subtable = ACPI_CAST_PTR (ACPI_TABLE_WPBT, Table);
687*ff879b07SJung-uk Kim     ArgumentsLength = Subtable->ArgumentsLength;
688*ff879b07SJung-uk Kim 
689*ff879b07SJung-uk Kim     /* Dump the arguments buffer */
690*ff879b07SJung-uk Kim 
691*ff879b07SJung-uk Kim     (void) AcpiDmDumpTable (Table->Length, 0, Table, ArgumentsLength,
692*ff879b07SJung-uk Kim         AcpiDmTableInfoWpbt0);
693*ff879b07SJung-uk Kim }
694