17bcb6cafSSascha Wildner /******************************************************************************
27bcb6cafSSascha Wildner  *
37bcb6cafSSascha Wildner  * Module Name: dmtbdump3 - Dump ACPI data tables that contain no AML code
47bcb6cafSSascha Wildner  *
57bcb6cafSSascha Wildner  *****************************************************************************/
67bcb6cafSSascha Wildner 
77bcb6cafSSascha Wildner /******************************************************************************
87bcb6cafSSascha Wildner  *
97bcb6cafSSascha Wildner  * 1. Copyright Notice
107bcb6cafSSascha Wildner  *
11383048acSSascha Wildner  * Some or all of this work - Copyright (c) 1999 - 2021, Intel Corp.
127bcb6cafSSascha Wildner  * All rights reserved.
137bcb6cafSSascha Wildner  *
147bcb6cafSSascha Wildner  * 2. License
157bcb6cafSSascha Wildner  *
167bcb6cafSSascha Wildner  * 2.1. This is your license from Intel Corp. under its intellectual property
177bcb6cafSSascha Wildner  * rights. You may have additional license terms from the party that provided
187bcb6cafSSascha Wildner  * you this software, covering your right to use that party's intellectual
197bcb6cafSSascha Wildner  * property rights.
207bcb6cafSSascha Wildner  *
217bcb6cafSSascha Wildner  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
227bcb6cafSSascha Wildner  * copy of the source code appearing in this file ("Covered Code") an
237bcb6cafSSascha Wildner  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
247bcb6cafSSascha Wildner  * base code distributed originally by Intel ("Original Intel Code") to copy,
257bcb6cafSSascha Wildner  * make derivatives, distribute, use and display any portion of the Covered
267bcb6cafSSascha Wildner  * Code in any form, with the right to sublicense such rights; and
277bcb6cafSSascha Wildner  *
287bcb6cafSSascha Wildner  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
297bcb6cafSSascha Wildner  * license (with the right to sublicense), under only those claims of Intel
307bcb6cafSSascha Wildner  * patents that are infringed by the Original Intel Code, to make, use, sell,
317bcb6cafSSascha Wildner  * offer to sell, and import the Covered Code and derivative works thereof
327bcb6cafSSascha Wildner  * solely to the minimum extent necessary to exercise the above copyright
337bcb6cafSSascha Wildner  * license, and in no event shall the patent license extend to any additions
347bcb6cafSSascha Wildner  * to or modifications of the Original Intel Code. No other license or right
357bcb6cafSSascha Wildner  * is granted directly or by implication, estoppel or otherwise;
367bcb6cafSSascha Wildner  *
377bcb6cafSSascha Wildner  * The above copyright and patent license is granted only if the following
387bcb6cafSSascha Wildner  * conditions are met:
397bcb6cafSSascha Wildner  *
407bcb6cafSSascha Wildner  * 3. Conditions
417bcb6cafSSascha Wildner  *
427bcb6cafSSascha Wildner  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
437bcb6cafSSascha Wildner  * Redistribution of source code of any substantial portion of the Covered
447bcb6cafSSascha Wildner  * Code or modification with rights to further distribute source must include
457bcb6cafSSascha Wildner  * the above Copyright Notice, the above License, this list of Conditions,
467bcb6cafSSascha Wildner  * and the following Disclaimer and Export Compliance provision. In addition,
477bcb6cafSSascha Wildner  * Licensee must cause all Covered Code to which Licensee contributes to
487bcb6cafSSascha Wildner  * contain a file documenting the changes Licensee made to create that Covered
497bcb6cafSSascha Wildner  * Code and the date of any change. Licensee must include in that file the
507bcb6cafSSascha Wildner  * documentation of any changes made by any predecessor Licensee. Licensee
517bcb6cafSSascha Wildner  * must include a prominent statement that the modification is derived,
527bcb6cafSSascha Wildner  * directly or indirectly, from Original Intel Code.
537bcb6cafSSascha Wildner  *
547bcb6cafSSascha Wildner  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
557bcb6cafSSascha Wildner  * Redistribution of source code of any substantial portion of the Covered
567bcb6cafSSascha Wildner  * Code or modification without rights to further distribute source must
577bcb6cafSSascha Wildner  * include the following Disclaimer and Export Compliance provision in the
587bcb6cafSSascha Wildner  * documentation and/or other materials provided with distribution. In
597bcb6cafSSascha Wildner  * addition, Licensee may not authorize further sublicense of source of any
607bcb6cafSSascha Wildner  * portion of the Covered Code, and must include terms to the effect that the
617bcb6cafSSascha Wildner  * license from Licensee to its licensee is limited to the intellectual
627bcb6cafSSascha Wildner  * property embodied in the software Licensee provides to its licensee, and
637bcb6cafSSascha Wildner  * not to intellectual property embodied in modifications its licensee may
647bcb6cafSSascha Wildner  * make.
657bcb6cafSSascha Wildner  *
667bcb6cafSSascha Wildner  * 3.3. Redistribution of Executable. Redistribution in executable form of any
677bcb6cafSSascha Wildner  * substantial portion of the Covered Code or modification must reproduce the
687bcb6cafSSascha Wildner  * above Copyright Notice, and the following Disclaimer and Export Compliance
697bcb6cafSSascha Wildner  * provision in the documentation and/or other materials provided with the
707bcb6cafSSascha Wildner  * distribution.
717bcb6cafSSascha Wildner  *
727bcb6cafSSascha Wildner  * 3.4. Intel retains all right, title, and interest in and to the Original
737bcb6cafSSascha Wildner  * Intel Code.
747bcb6cafSSascha Wildner  *
757bcb6cafSSascha Wildner  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
767bcb6cafSSascha Wildner  * Intel shall be used in advertising or otherwise to promote the sale, use or
777bcb6cafSSascha Wildner  * other dealings in products derived from or relating to the Covered Code
787bcb6cafSSascha Wildner  * without prior written authorization from Intel.
797bcb6cafSSascha Wildner  *
807bcb6cafSSascha Wildner  * 4. Disclaimer and Export Compliance
817bcb6cafSSascha Wildner  *
827bcb6cafSSascha Wildner  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
837bcb6cafSSascha Wildner  * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
847bcb6cafSSascha Wildner  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
857bcb6cafSSascha Wildner  * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
867bcb6cafSSascha Wildner  * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
877bcb6cafSSascha Wildner  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
887bcb6cafSSascha Wildner  * PARTICULAR PURPOSE.
897bcb6cafSSascha Wildner  *
907bcb6cafSSascha Wildner  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
917bcb6cafSSascha Wildner  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
927bcb6cafSSascha Wildner  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
937bcb6cafSSascha Wildner  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
947bcb6cafSSascha Wildner  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
957bcb6cafSSascha Wildner  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
967bcb6cafSSascha Wildner  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
977bcb6cafSSascha Wildner  * LIMITED REMEDY.
987bcb6cafSSascha Wildner  *
997bcb6cafSSascha Wildner  * 4.3. Licensee shall not export, either directly or indirectly, any of this
1007bcb6cafSSascha Wildner  * software or system incorporating such software without first obtaining any
1017bcb6cafSSascha Wildner  * required license or other approval from the U. S. Department of Commerce or
1027bcb6cafSSascha Wildner  * any other agency or department of the United States Government. In the
1037bcb6cafSSascha Wildner  * event Licensee exports any such software from the United States or
1047bcb6cafSSascha Wildner  * re-exports any such software from a foreign destination, Licensee shall
1057bcb6cafSSascha Wildner  * ensure that the distribution and export/re-export of the software is in
1067bcb6cafSSascha Wildner  * compliance with all laws, regulations, orders, or other restrictions of the
1077bcb6cafSSascha Wildner  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
1087bcb6cafSSascha Wildner  * any of its subsidiaries will export/re-export any technical data, process,
1097bcb6cafSSascha Wildner  * software, or service, directly or indirectly, to any country for which the
1107bcb6cafSSascha Wildner  * United States government or any agency thereof requires an export license,
1117bcb6cafSSascha Wildner  * other governmental approval, or letter of assurance, without first obtaining
1127bcb6cafSSascha Wildner  * such license, approval or letter.
1137bcb6cafSSascha Wildner  *
1147bcb6cafSSascha Wildner  *****************************************************************************
1157bcb6cafSSascha Wildner  *
1167bcb6cafSSascha Wildner  * Alternatively, you may choose to be licensed under the terms of the
1177bcb6cafSSascha Wildner  * following license:
1187bcb6cafSSascha Wildner  *
1197bcb6cafSSascha Wildner  * Redistribution and use in source and binary forms, with or without
1207bcb6cafSSascha Wildner  * modification, are permitted provided that the following conditions
1217bcb6cafSSascha Wildner  * are met:
1227bcb6cafSSascha Wildner  * 1. Redistributions of source code must retain the above copyright
1237bcb6cafSSascha Wildner  *    notice, this list of conditions, and the following disclaimer,
1247bcb6cafSSascha Wildner  *    without modification.
1257bcb6cafSSascha Wildner  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
1267bcb6cafSSascha Wildner  *    substantially similar to the "NO WARRANTY" disclaimer below
1277bcb6cafSSascha Wildner  *    ("Disclaimer") and any redistribution must be conditioned upon
1287bcb6cafSSascha Wildner  *    including a substantially similar Disclaimer requirement for further
1297bcb6cafSSascha Wildner  *    binary redistribution.
1307bcb6cafSSascha Wildner  * 3. Neither the names of the above-listed copyright holders nor the names
1317bcb6cafSSascha Wildner  *    of any contributors may be used to endorse or promote products derived
1327bcb6cafSSascha Wildner  *    from this software without specific prior written permission.
1337bcb6cafSSascha Wildner  *
1347bcb6cafSSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1357bcb6cafSSascha Wildner  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1367bcb6cafSSascha Wildner  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
1377bcb6cafSSascha Wildner  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
1387bcb6cafSSascha Wildner  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
1397bcb6cafSSascha Wildner  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
1407bcb6cafSSascha Wildner  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
1417bcb6cafSSascha Wildner  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
1427bcb6cafSSascha Wildner  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
1437bcb6cafSSascha Wildner  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
1447bcb6cafSSascha Wildner  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
1457bcb6cafSSascha Wildner  *
1467bcb6cafSSascha Wildner  * Alternatively, you may choose to be licensed under the terms of the
1477bcb6cafSSascha Wildner  * GNU General Public License ("GPL") version 2 as published by the Free
1487bcb6cafSSascha Wildner  * Software Foundation.
1497bcb6cafSSascha Wildner  *
1507bcb6cafSSascha Wildner  *****************************************************************************/
1517bcb6cafSSascha Wildner 
1527bcb6cafSSascha Wildner #include "acpi.h"
1537bcb6cafSSascha Wildner #include "accommon.h"
1547bcb6cafSSascha Wildner #include "acdisasm.h"
1557bcb6cafSSascha Wildner #include "actables.h"
1567bcb6cafSSascha Wildner 
1577bcb6cafSSascha Wildner /* This module used for application-level code only */
1587bcb6cafSSascha Wildner 
1597bcb6cafSSascha Wildner #define _COMPONENT          ACPI_CA_DISASSEMBLER
1607bcb6cafSSascha Wildner         ACPI_MODULE_NAME    ("dmtbdump3")
1617bcb6cafSSascha Wildner 
1627bcb6cafSSascha Wildner 
1637bcb6cafSSascha Wildner /*******************************************************************************
1647bcb6cafSSascha Wildner  *
1657bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpSlic
1667bcb6cafSSascha Wildner  *
1677bcb6cafSSascha Wildner  * PARAMETERS:  Table               - A SLIC table
1687bcb6cafSSascha Wildner  *
1697bcb6cafSSascha Wildner  * RETURN:      None
1707bcb6cafSSascha Wildner  *
1717bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a SLIC
1727bcb6cafSSascha Wildner  *
1737bcb6cafSSascha Wildner  ******************************************************************************/
1747bcb6cafSSascha Wildner 
1757bcb6cafSSascha Wildner void
AcpiDmDumpSlic(ACPI_TABLE_HEADER * Table)1767bcb6cafSSascha Wildner AcpiDmDumpSlic (
1777bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
1787bcb6cafSSascha Wildner {
1797bcb6cafSSascha Wildner 
1807bcb6cafSSascha Wildner     (void) AcpiDmDumpTable (Table->Length, sizeof (ACPI_TABLE_HEADER), Table,
1817bcb6cafSSascha Wildner         Table->Length - sizeof (*Table), AcpiDmTableInfoSlic);
1827bcb6cafSSascha Wildner }
1837bcb6cafSSascha Wildner 
1847bcb6cafSSascha Wildner 
1857bcb6cafSSascha Wildner /*******************************************************************************
1867bcb6cafSSascha Wildner  *
1877bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpSlit
1887bcb6cafSSascha Wildner  *
1897bcb6cafSSascha Wildner  * PARAMETERS:  Table               - An SLIT
1907bcb6cafSSascha Wildner  *
1917bcb6cafSSascha Wildner  * RETURN:      None
1927bcb6cafSSascha Wildner  *
1937bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a SLIT
1947bcb6cafSSascha Wildner  *
1957bcb6cafSSascha Wildner  ******************************************************************************/
1967bcb6cafSSascha Wildner 
1977bcb6cafSSascha Wildner void
AcpiDmDumpSlit(ACPI_TABLE_HEADER * Table)1987bcb6cafSSascha Wildner AcpiDmDumpSlit (
1997bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
2007bcb6cafSSascha Wildner {
2017bcb6cafSSascha Wildner     ACPI_STATUS             Status;
2027bcb6cafSSascha Wildner     UINT32                  Offset;
2037bcb6cafSSascha Wildner     UINT8                   *Row;
2047bcb6cafSSascha Wildner     UINT32                  Localities;
2057bcb6cafSSascha Wildner     UINT32                  i;
2067bcb6cafSSascha Wildner     UINT32                  j;
2077bcb6cafSSascha Wildner 
2087bcb6cafSSascha Wildner 
2097bcb6cafSSascha Wildner     /* Main table */
2107bcb6cafSSascha Wildner 
2117bcb6cafSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSlit);
2127bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
2137bcb6cafSSascha Wildner     {
2147bcb6cafSSascha Wildner         return;
2157bcb6cafSSascha Wildner     }
2167bcb6cafSSascha Wildner 
2177bcb6cafSSascha Wildner     /* Display the Locality NxN Matrix */
2187bcb6cafSSascha Wildner 
2197bcb6cafSSascha Wildner     Localities = (UINT32) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->LocalityCount;
2207bcb6cafSSascha Wildner     Offset = ACPI_OFFSET (ACPI_TABLE_SLIT, Entry[0]);
2217bcb6cafSSascha Wildner     Row = (UINT8 *) ACPI_CAST_PTR (ACPI_TABLE_SLIT, Table)->Entry;
2227bcb6cafSSascha Wildner 
2237bcb6cafSSascha Wildner     for (i = 0; i < Localities; i++)
2247bcb6cafSSascha Wildner     {
2257bcb6cafSSascha Wildner         /* Display one row of the matrix */
2267bcb6cafSSascha Wildner 
2277bcb6cafSSascha Wildner         AcpiDmLineHeader2 (Offset, Localities, "Locality", i);
2287bcb6cafSSascha Wildner         for  (j = 0; j < Localities; j++)
2297bcb6cafSSascha Wildner         {
2307bcb6cafSSascha Wildner             /* Check for beyond EOT */
2317bcb6cafSSascha Wildner 
2327bcb6cafSSascha Wildner             if (Offset >= Table->Length)
2337bcb6cafSSascha Wildner             {
2347bcb6cafSSascha Wildner                 AcpiOsPrintf (
2357bcb6cafSSascha Wildner                     "\n**** Not enough room in table for all localities\n");
2367bcb6cafSSascha Wildner                 return;
2377bcb6cafSSascha Wildner             }
2387bcb6cafSSascha Wildner 
2397bcb6cafSSascha Wildner             AcpiOsPrintf ("%2.2X", Row[j]);
2407bcb6cafSSascha Wildner             Offset++;
2417bcb6cafSSascha Wildner 
2427bcb6cafSSascha Wildner             /* Display up to 16 bytes per output row */
2437bcb6cafSSascha Wildner 
2447bcb6cafSSascha Wildner             if ((j+1) < Localities)
2457bcb6cafSSascha Wildner             {
2467bcb6cafSSascha Wildner                 AcpiOsPrintf (" ");
2477bcb6cafSSascha Wildner 
2487bcb6cafSSascha Wildner                 if (j && (((j+1) % 16) == 0))
2497bcb6cafSSascha Wildner                 {
2507bcb6cafSSascha Wildner                     AcpiOsPrintf ("\\\n"); /* With line continuation char */
2517bcb6cafSSascha Wildner                     AcpiDmLineHeader (Offset, 0, NULL);
2527bcb6cafSSascha Wildner                 }
2537bcb6cafSSascha Wildner             }
2547bcb6cafSSascha Wildner         }
2557bcb6cafSSascha Wildner 
2567bcb6cafSSascha Wildner         /* Point to next row */
2577bcb6cafSSascha Wildner 
2587bcb6cafSSascha Wildner         AcpiOsPrintf ("\n");
2597bcb6cafSSascha Wildner         Row += Localities;
2607bcb6cafSSascha Wildner     }
2617bcb6cafSSascha Wildner }
2627bcb6cafSSascha Wildner 
2637bcb6cafSSascha Wildner 
2647bcb6cafSSascha Wildner /*******************************************************************************
2657bcb6cafSSascha Wildner  *
2667bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpSrat
2677bcb6cafSSascha Wildner  *
2687bcb6cafSSascha Wildner  * PARAMETERS:  Table               - A SRAT table
2697bcb6cafSSascha Wildner  *
2707bcb6cafSSascha Wildner  * RETURN:      None
2717bcb6cafSSascha Wildner  *
2727bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a SRAT
2737bcb6cafSSascha Wildner  *
2747bcb6cafSSascha Wildner  ******************************************************************************/
2757bcb6cafSSascha Wildner 
2767bcb6cafSSascha Wildner void
AcpiDmDumpSrat(ACPI_TABLE_HEADER * Table)2777bcb6cafSSascha Wildner AcpiDmDumpSrat (
2787bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
2797bcb6cafSSascha Wildner {
2807bcb6cafSSascha Wildner     ACPI_STATUS             Status;
2817bcb6cafSSascha Wildner     UINT32                  Offset = sizeof (ACPI_TABLE_SRAT);
2827bcb6cafSSascha Wildner     ACPI_SUBTABLE_HEADER    *Subtable;
2837bcb6cafSSascha Wildner     ACPI_DMTABLE_INFO       *InfoTable;
2847bcb6cafSSascha Wildner 
2857bcb6cafSSascha Wildner 
2867bcb6cafSSascha Wildner     /* Main table */
2877bcb6cafSSascha Wildner 
2887bcb6cafSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoSrat);
2897bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
2907bcb6cafSSascha Wildner     {
2917bcb6cafSSascha Wildner         return;
2927bcb6cafSSascha Wildner     }
2937bcb6cafSSascha Wildner 
2947bcb6cafSSascha Wildner     /* Subtables */
2957bcb6cafSSascha Wildner 
2967bcb6cafSSascha Wildner     Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Table, Offset);
2977bcb6cafSSascha Wildner     while (Offset < Table->Length)
2987bcb6cafSSascha Wildner     {
2997bcb6cafSSascha Wildner         /* Common subtable header */
3007bcb6cafSSascha Wildner 
3017bcb6cafSSascha Wildner         AcpiOsPrintf ("\n");
3027bcb6cafSSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
3037bcb6cafSSascha Wildner             Subtable->Length, AcpiDmTableInfoSratHdr);
3047bcb6cafSSascha Wildner         if (ACPI_FAILURE (Status))
3057bcb6cafSSascha Wildner         {
3067bcb6cafSSascha Wildner             return;
3077bcb6cafSSascha Wildner         }
3087bcb6cafSSascha Wildner 
3097bcb6cafSSascha Wildner         switch (Subtable->Type)
3107bcb6cafSSascha Wildner         {
3117bcb6cafSSascha Wildner         case ACPI_SRAT_TYPE_CPU_AFFINITY:
3127bcb6cafSSascha Wildner 
3137bcb6cafSSascha Wildner             InfoTable = AcpiDmTableInfoSrat0;
3147bcb6cafSSascha Wildner             break;
3157bcb6cafSSascha Wildner 
3167bcb6cafSSascha Wildner         case ACPI_SRAT_TYPE_MEMORY_AFFINITY:
3177bcb6cafSSascha Wildner 
3187bcb6cafSSascha Wildner             InfoTable = AcpiDmTableInfoSrat1;
3197bcb6cafSSascha Wildner             break;
3207bcb6cafSSascha Wildner 
3217bcb6cafSSascha Wildner         case ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY:
3227bcb6cafSSascha Wildner 
3237bcb6cafSSascha Wildner             InfoTable = AcpiDmTableInfoSrat2;
3247bcb6cafSSascha Wildner             break;
3257bcb6cafSSascha Wildner 
3267bcb6cafSSascha Wildner         case ACPI_SRAT_TYPE_GICC_AFFINITY:
3277bcb6cafSSascha Wildner 
3287bcb6cafSSascha Wildner             InfoTable = AcpiDmTableInfoSrat3;
3297bcb6cafSSascha Wildner             break;
3307bcb6cafSSascha Wildner 
3317bcb6cafSSascha Wildner         case ACPI_SRAT_TYPE_GIC_ITS_AFFINITY:
3327bcb6cafSSascha Wildner 
3337bcb6cafSSascha Wildner             InfoTable = AcpiDmTableInfoSrat4;
3347bcb6cafSSascha Wildner             break;
3357bcb6cafSSascha Wildner 
33600ffa116SSascha Wildner         case ACPI_SRAT_TYPE_GENERIC_AFFINITY:
33700ffa116SSascha Wildner 
33800ffa116SSascha Wildner             InfoTable = AcpiDmTableInfoSrat5;
33900ffa116SSascha Wildner             break;
34000ffa116SSascha Wildner 
341*84fe3360SSascha Wildner         case ACPI_SRAT_TYPE_GENERIC_PORT_AFFINITY:
342*84fe3360SSascha Wildner 
343*84fe3360SSascha Wildner             InfoTable = AcpiDmTableInfoSrat6;
344*84fe3360SSascha Wildner             break;
345*84fe3360SSascha Wildner 
3467bcb6cafSSascha Wildner         default:
3477bcb6cafSSascha Wildner             AcpiOsPrintf ("\n**** Unknown SRAT subtable type 0x%X\n",
3487bcb6cafSSascha Wildner                 Subtable->Type);
3497bcb6cafSSascha Wildner 
3507bcb6cafSSascha Wildner             /* Attempt to continue */
3517bcb6cafSSascha Wildner 
3527bcb6cafSSascha Wildner             if (!Subtable->Length)
3537bcb6cafSSascha Wildner             {
3547bcb6cafSSascha Wildner                 AcpiOsPrintf ("Invalid zero length subtable\n");
3557bcb6cafSSascha Wildner                 return;
3567bcb6cafSSascha Wildner             }
3577bcb6cafSSascha Wildner             goto NextSubtable;
3587bcb6cafSSascha Wildner         }
3597bcb6cafSSascha Wildner 
3607bcb6cafSSascha Wildner         AcpiOsPrintf ("\n");
3617bcb6cafSSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
3627bcb6cafSSascha Wildner             Subtable->Length, InfoTable);
3637bcb6cafSSascha Wildner         if (ACPI_FAILURE (Status))
3647bcb6cafSSascha Wildner         {
3657bcb6cafSSascha Wildner             return;
3667bcb6cafSSascha Wildner         }
3677bcb6cafSSascha Wildner 
3687bcb6cafSSascha Wildner NextSubtable:
3697bcb6cafSSascha Wildner         /* Point to next subtable */
3707bcb6cafSSascha Wildner 
3717bcb6cafSSascha Wildner         Offset += Subtable->Length;
3727bcb6cafSSascha Wildner         Subtable = ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Subtable,
3737bcb6cafSSascha Wildner             Subtable->Length);
3747bcb6cafSSascha Wildner     }
3757bcb6cafSSascha Wildner }
3767bcb6cafSSascha Wildner 
3777bcb6cafSSascha Wildner 
3787bcb6cafSSascha Wildner /*******************************************************************************
3797bcb6cafSSascha Wildner  *
3807bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpStao
3817bcb6cafSSascha Wildner  *
3827bcb6cafSSascha Wildner  * PARAMETERS:  Table               - A STAO table
3837bcb6cafSSascha Wildner  *
3847bcb6cafSSascha Wildner  * RETURN:      None
3857bcb6cafSSascha Wildner  *
3867bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a STAO. This is a variable-length
3877bcb6cafSSascha Wildner  *              table that contains an open-ended number of ASCII strings
3887bcb6cafSSascha Wildner  *              at the end of the table.
3897bcb6cafSSascha Wildner  *
3907bcb6cafSSascha Wildner  ******************************************************************************/
3917bcb6cafSSascha Wildner 
3927bcb6cafSSascha Wildner void
AcpiDmDumpStao(ACPI_TABLE_HEADER * Table)3937bcb6cafSSascha Wildner AcpiDmDumpStao (
3947bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
3957bcb6cafSSascha Wildner {
3967bcb6cafSSascha Wildner     ACPI_STATUS             Status;
3977bcb6cafSSascha Wildner     char                    *Namepath;
3987bcb6cafSSascha Wildner     UINT32                  Length = Table->Length;
3997bcb6cafSSascha Wildner     UINT32                  StringLength;
4007bcb6cafSSascha Wildner     UINT32                  Offset = sizeof (ACPI_TABLE_STAO);
4017bcb6cafSSascha Wildner 
4027bcb6cafSSascha Wildner 
4037bcb6cafSSascha Wildner     /* Main table */
4047bcb6cafSSascha Wildner 
4057bcb6cafSSascha Wildner     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoStao);
4067bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
4077bcb6cafSSascha Wildner     {
4087bcb6cafSSascha Wildner         return;
4097bcb6cafSSascha Wildner     }
4107bcb6cafSSascha Wildner 
4117bcb6cafSSascha Wildner     /* The rest of the table consists of Namepath strings */
4127bcb6cafSSascha Wildner 
4137bcb6cafSSascha Wildner     while (Offset < Table->Length)
4147bcb6cafSSascha Wildner     {
4157bcb6cafSSascha Wildner         Namepath = ACPI_ADD_PTR (char, Table, Offset);
4167bcb6cafSSascha Wildner         StringLength = strlen (Namepath) + 1;
4177bcb6cafSSascha Wildner 
418e5412f1eSSascha Wildner         AcpiDmLineHeader (Offset, StringLength, "Namepath");
4197bcb6cafSSascha Wildner         AcpiOsPrintf ("\"%s\"\n", Namepath);
4207bcb6cafSSascha Wildner 
4217bcb6cafSSascha Wildner         /* Point to next namepath */
4227bcb6cafSSascha Wildner 
4237bcb6cafSSascha Wildner         Offset += StringLength;
4247bcb6cafSSascha Wildner     }
4257bcb6cafSSascha Wildner }
4267bcb6cafSSascha Wildner 
4277bcb6cafSSascha Wildner 
4287bcb6cafSSascha Wildner /*******************************************************************************
4297bcb6cafSSascha Wildner  *
4304898bea4SSascha Wildner  * FUNCTION:    AcpiDmDumpSvkl
4314898bea4SSascha Wildner  *
4324898bea4SSascha Wildner  * PARAMETERS:  Table               - A SVKL table
4334898bea4SSascha Wildner  *
4344898bea4SSascha Wildner  * RETURN:      None
4354898bea4SSascha Wildner  *
4364898bea4SSascha Wildner  * DESCRIPTION: Format the contents of a SVKL. This is a variable-length
4374898bea4SSascha Wildner  *              table that contains an open-ended number of key subtables at
4384898bea4SSascha Wildner  *              the end of the header.
4394898bea4SSascha Wildner  *
4404898bea4SSascha Wildner  * NOTES: SVKL is essentially a flat table, with a small main table and
4414898bea4SSascha Wildner  *          a variable number of a single type of subtable.
4424898bea4SSascha Wildner  *
4434898bea4SSascha Wildner  ******************************************************************************/
4444898bea4SSascha Wildner 
4454898bea4SSascha Wildner void
AcpiDmDumpSvkl(ACPI_TABLE_HEADER * Table)4464898bea4SSascha Wildner AcpiDmDumpSvkl (
4474898bea4SSascha Wildner     ACPI_TABLE_HEADER       *Table)
4484898bea4SSascha Wildner {
4494898bea4SSascha Wildner     ACPI_STATUS             Status;
4504898bea4SSascha Wildner     UINT32                  Length = Table->Length;
4514898bea4SSascha Wildner     UINT32                  Offset = sizeof (ACPI_TABLE_SVKL);
4524898bea4SSascha Wildner     ACPI_SVKL_KEY           *Subtable;
4534898bea4SSascha Wildner 
4544898bea4SSascha Wildner 
4554898bea4SSascha Wildner     /* Main table */
4564898bea4SSascha Wildner 
4574898bea4SSascha Wildner     Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoSvkl);
4584898bea4SSascha Wildner     if (ACPI_FAILURE (Status))
4594898bea4SSascha Wildner     {
4604898bea4SSascha Wildner         return;
4614898bea4SSascha Wildner     }
4624898bea4SSascha Wildner 
4634898bea4SSascha Wildner     /* The rest of the table consists of subtables (single type) */
4644898bea4SSascha Wildner 
4654898bea4SSascha Wildner     Subtable = ACPI_ADD_PTR (ACPI_SVKL_KEY, Table, Offset);
4664898bea4SSascha Wildner     while (Offset < Table->Length)
4674898bea4SSascha Wildner     {
4684898bea4SSascha Wildner         /* Dump the subtable */
4694898bea4SSascha Wildner 
4704898bea4SSascha Wildner         AcpiOsPrintf ("\n");
4714898bea4SSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
4724898bea4SSascha Wildner             sizeof (ACPI_SVKL_KEY), AcpiDmTableInfoSvkl0);
4734898bea4SSascha Wildner         if (ACPI_FAILURE (Status))
4744898bea4SSascha Wildner         {
4754898bea4SSascha Wildner             return;
4764898bea4SSascha Wildner         }
4774898bea4SSascha Wildner 
4784898bea4SSascha Wildner         /* Point to next subtable */
4794898bea4SSascha Wildner 
4804898bea4SSascha Wildner         Offset += sizeof (ACPI_SVKL_KEY);
4814898bea4SSascha Wildner         Subtable = ACPI_ADD_PTR (ACPI_SVKL_KEY, Subtable,
4824898bea4SSascha Wildner             sizeof (ACPI_SVKL_KEY));
4834898bea4SSascha Wildner     }
4844898bea4SSascha Wildner }
4854898bea4SSascha Wildner 
4864898bea4SSascha Wildner 
4874898bea4SSascha Wildner /*******************************************************************************
4884898bea4SSascha Wildner  *
4897bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpTcpa
4907bcb6cafSSascha Wildner  *
4917bcb6cafSSascha Wildner  * PARAMETERS:  Table               - A TCPA table
4927bcb6cafSSascha Wildner  *
4937bcb6cafSSascha Wildner  * RETURN:      None
4947bcb6cafSSascha Wildner  *
4957bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a TCPA.
4967bcb6cafSSascha Wildner  *
4977bcb6cafSSascha Wildner  * NOTE:        There are two versions of the table with the same signature:
4987bcb6cafSSascha Wildner  *              the client version and the server version. The common
4997bcb6cafSSascha Wildner  *              PlatformClass field is used to differentiate the two types of
5007bcb6cafSSascha Wildner  *              tables.
5017bcb6cafSSascha Wildner  *
5027bcb6cafSSascha Wildner  ******************************************************************************/
5037bcb6cafSSascha Wildner 
5047bcb6cafSSascha Wildner void
AcpiDmDumpTcpa(ACPI_TABLE_HEADER * Table)5057bcb6cafSSascha Wildner AcpiDmDumpTcpa (
5067bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
5077bcb6cafSSascha Wildner {
5087bcb6cafSSascha Wildner     UINT32                  Offset = sizeof (ACPI_TABLE_TCPA_HDR);
5097bcb6cafSSascha Wildner     ACPI_TABLE_TCPA_HDR     *CommonHeader = ACPI_CAST_PTR (
5107bcb6cafSSascha Wildner                                 ACPI_TABLE_TCPA_HDR, Table);
5117bcb6cafSSascha Wildner     ACPI_TABLE_TCPA_HDR     *Subtable = ACPI_ADD_PTR (
5127bcb6cafSSascha Wildner                                 ACPI_TABLE_TCPA_HDR, Table, Offset);
5137bcb6cafSSascha Wildner     ACPI_STATUS             Status;
5147bcb6cafSSascha Wildner 
5157bcb6cafSSascha Wildner 
5167bcb6cafSSascha Wildner     /* Main table */
5177bcb6cafSSascha Wildner 
5187bcb6cafSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table,
5197bcb6cafSSascha Wildner         0, AcpiDmTableInfoTcpaHdr);
5207bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
5217bcb6cafSSascha Wildner     {
5227bcb6cafSSascha Wildner         return;
5237bcb6cafSSascha Wildner     }
5247bcb6cafSSascha Wildner 
5257bcb6cafSSascha Wildner     /*
5267bcb6cafSSascha Wildner      * Examine the PlatformClass field to determine the table type.
5277bcb6cafSSascha Wildner      * Either a client or server table. Only one.
5287bcb6cafSSascha Wildner      */
5297bcb6cafSSascha Wildner     switch (CommonHeader->PlatformClass)
5307bcb6cafSSascha Wildner     {
5317bcb6cafSSascha Wildner     case ACPI_TCPA_CLIENT_TABLE:
5327bcb6cafSSascha Wildner 
5337bcb6cafSSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
5347bcb6cafSSascha Wildner             Table->Length - Offset, AcpiDmTableInfoTcpaClient);
5357bcb6cafSSascha Wildner         break;
5367bcb6cafSSascha Wildner 
5377bcb6cafSSascha Wildner     case ACPI_TCPA_SERVER_TABLE:
5387bcb6cafSSascha Wildner 
5397bcb6cafSSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
5407bcb6cafSSascha Wildner             Table->Length - Offset, AcpiDmTableInfoTcpaServer);
5417bcb6cafSSascha Wildner         break;
5427bcb6cafSSascha Wildner 
5437bcb6cafSSascha Wildner     default:
5447bcb6cafSSascha Wildner 
5457bcb6cafSSascha Wildner         AcpiOsPrintf ("\n**** Unknown TCPA Platform Class 0x%X\n",
5467bcb6cafSSascha Wildner             CommonHeader->PlatformClass);
5477bcb6cafSSascha Wildner         Status = AE_ERROR;
5487bcb6cafSSascha Wildner         break;
5497bcb6cafSSascha Wildner     }
5507bcb6cafSSascha Wildner 
5517bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
5527bcb6cafSSascha Wildner     {
5537bcb6cafSSascha Wildner         AcpiOsPrintf ("\n**** Cannot disassemble TCPA table\n");
5547bcb6cafSSascha Wildner     }
5557bcb6cafSSascha Wildner }
5567bcb6cafSSascha Wildner 
5577bcb6cafSSascha Wildner 
5587bcb6cafSSascha Wildner /*******************************************************************************
5597bcb6cafSSascha Wildner  *
5607bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpTpm2
5617bcb6cafSSascha Wildner  *
5627bcb6cafSSascha Wildner  * PARAMETERS:  Table               - A TPM2 table
5637bcb6cafSSascha Wildner  *
5647bcb6cafSSascha Wildner  * RETURN:      None
5657bcb6cafSSascha Wildner  *
5667bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a TPM2.
5677bcb6cafSSascha Wildner  *
5687bcb6cafSSascha Wildner  ******************************************************************************/
5694898bea4SSascha Wildner 
5706721db86SSascha Wildner static void
AcpiDmDumpTpm2Rev3(ACPI_TABLE_HEADER * Table)5716721db86SSascha Wildner AcpiDmDumpTpm2Rev3 (
5726721db86SSascha Wildner     ACPI_TABLE_HEADER       *Table)
5736721db86SSascha Wildner {
5746721db86SSascha Wildner     UINT32                  Offset = sizeof (ACPI_TABLE_TPM23);
5756721db86SSascha Wildner     ACPI_TABLE_TPM23        *CommonHeader = ACPI_CAST_PTR (ACPI_TABLE_TPM23, Table);
5766721db86SSascha Wildner     ACPI_TPM23_TRAILER      *Subtable = ACPI_ADD_PTR (ACPI_TPM23_TRAILER, Table, Offset);
5776721db86SSascha Wildner     ACPI_STATUS             Status;
5786721db86SSascha Wildner 
5796721db86SSascha Wildner 
5806721db86SSascha Wildner     /* Main table */
5816721db86SSascha Wildner 
5826721db86SSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoTpm23);
5836721db86SSascha Wildner     if (ACPI_FAILURE (Status))
5846721db86SSascha Wildner     {
5856721db86SSascha Wildner         return;
5866721db86SSascha Wildner     }
5876721db86SSascha Wildner 
5886721db86SSascha Wildner     /* Optional subtable if start method is ACPI start method */
5896721db86SSascha Wildner 
5906721db86SSascha Wildner     switch (CommonHeader->StartMethod)
5916721db86SSascha Wildner     {
5926721db86SSascha Wildner     case ACPI_TPM23_ACPI_START_METHOD:
5936721db86SSascha Wildner 
594e5412f1eSSascha Wildner         (void) AcpiDmDumpTable (Table->Length, Offset, Subtable,
5956721db86SSascha Wildner             Table->Length - Offset, AcpiDmTableInfoTpm23a);
5966721db86SSascha Wildner         break;
5976721db86SSascha Wildner 
5986721db86SSascha Wildner     default:
5996721db86SSascha Wildner         break;
6006721db86SSascha Wildner     }
6016721db86SSascha Wildner }
6026721db86SSascha Wildner 
6036721db86SSascha Wildner 
6046721db86SSascha Wildner /*******************************************************************************
6056721db86SSascha Wildner  *
6066721db86SSascha Wildner  * FUNCTION:    AcpiDmDumpTpm2
6076721db86SSascha Wildner  *
6086721db86SSascha Wildner  * PARAMETERS:  Table               - A TPM2 table
6096721db86SSascha Wildner  *
6106721db86SSascha Wildner  * RETURN:      None
6116721db86SSascha Wildner  *
6126721db86SSascha Wildner  * DESCRIPTION: Format the contents of a TPM2.
6136721db86SSascha Wildner  *
6146721db86SSascha Wildner  ******************************************************************************/
6157bcb6cafSSascha Wildner 
6167bcb6cafSSascha Wildner void
AcpiDmDumpTpm2(ACPI_TABLE_HEADER * Table)6177bcb6cafSSascha Wildner AcpiDmDumpTpm2 (
6187bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
6197bcb6cafSSascha Wildner {
6207bcb6cafSSascha Wildner     UINT32                  Offset = sizeof (ACPI_TABLE_TPM2);
6217bcb6cafSSascha Wildner     ACPI_TABLE_TPM2         *CommonHeader = ACPI_CAST_PTR (ACPI_TABLE_TPM2, Table);
6227bcb6cafSSascha Wildner     ACPI_TPM2_TRAILER       *Subtable = ACPI_ADD_PTR (ACPI_TPM2_TRAILER, Table, Offset);
6237bcb6cafSSascha Wildner     ACPI_TPM2_ARM_SMC       *ArmSubtable;
6247bcb6cafSSascha Wildner     ACPI_STATUS             Status;
6257bcb6cafSSascha Wildner 
6267bcb6cafSSascha Wildner 
6276721db86SSascha Wildner     if (Table->Revision == 3)
6286721db86SSascha Wildner     {
6296721db86SSascha Wildner         AcpiDmDumpTpm2Rev3(Table);
6306721db86SSascha Wildner         return;
6316721db86SSascha Wildner     }
6326721db86SSascha Wildner 
6337bcb6cafSSascha Wildner     /* Main table */
6347bcb6cafSSascha Wildner 
6357bcb6cafSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoTpm2);
6366721db86SSascha Wildner 
6377bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
6387bcb6cafSSascha Wildner     {
6397bcb6cafSSascha Wildner         return;
6407bcb6cafSSascha Wildner     }
6417bcb6cafSSascha Wildner 
6427bcb6cafSSascha Wildner     AcpiOsPrintf ("\n");
6437bcb6cafSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
6447bcb6cafSSascha Wildner         Table->Length - Offset, AcpiDmTableInfoTpm2a);
6457bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
6467bcb6cafSSascha Wildner     {
6477bcb6cafSSascha Wildner         return;
6487bcb6cafSSascha Wildner     }
6497bcb6cafSSascha Wildner 
6507bcb6cafSSascha Wildner     switch (CommonHeader->StartMethod)
6517bcb6cafSSascha Wildner     {
6527bcb6cafSSascha Wildner     case ACPI_TPM2_COMMAND_BUFFER_WITH_ARM_SMC:
6537bcb6cafSSascha Wildner 
6547bcb6cafSSascha Wildner         ArmSubtable = ACPI_ADD_PTR (ACPI_TPM2_ARM_SMC, Subtable,
6557bcb6cafSSascha Wildner             sizeof (ACPI_TPM2_TRAILER));
6567bcb6cafSSascha Wildner         Offset += sizeof (ACPI_TPM2_TRAILER);
6577bcb6cafSSascha Wildner 
6587bcb6cafSSascha Wildner         AcpiOsPrintf ("\n");
659e5412f1eSSascha Wildner         (void) AcpiDmDumpTable (Table->Length, Offset, ArmSubtable,
6607bcb6cafSSascha Wildner             Table->Length - Offset, AcpiDmTableInfoTpm211);
6617bcb6cafSSascha Wildner         break;
6627bcb6cafSSascha Wildner 
6637bcb6cafSSascha Wildner     default:
6647bcb6cafSSascha Wildner         break;
6657bcb6cafSSascha Wildner     }
6667bcb6cafSSascha Wildner }
6677bcb6cafSSascha Wildner 
6687bcb6cafSSascha Wildner 
6697bcb6cafSSascha Wildner /*******************************************************************************
6707bcb6cafSSascha Wildner  *
67101d5d5dfSSascha Wildner  * FUNCTION:    AcpiDmDumpViot
67201d5d5dfSSascha Wildner  *
67301d5d5dfSSascha Wildner  * PARAMETERS:  Table               - A VIOT table
67401d5d5dfSSascha Wildner  *
67501d5d5dfSSascha Wildner  * RETURN:      None
67601d5d5dfSSascha Wildner  *
67701d5d5dfSSascha Wildner  * DESCRIPTION: Format the contents of a VIOT
67801d5d5dfSSascha Wildner  *
67901d5d5dfSSascha Wildner  ******************************************************************************/
68001d5d5dfSSascha Wildner 
68101d5d5dfSSascha Wildner void
AcpiDmDumpViot(ACPI_TABLE_HEADER * Table)68201d5d5dfSSascha Wildner AcpiDmDumpViot (
68301d5d5dfSSascha Wildner     ACPI_TABLE_HEADER       *Table)
68401d5d5dfSSascha Wildner {
68501d5d5dfSSascha Wildner     ACPI_STATUS             Status;
68601d5d5dfSSascha Wildner     ACPI_TABLE_VIOT         *Viot;
68701d5d5dfSSascha Wildner     ACPI_VIOT_HEADER        *ViotHeader;
68801d5d5dfSSascha Wildner     UINT16                  Length;
6890672a19bSSascha Wildner     UINT32                  Offset;
69001d5d5dfSSascha Wildner     ACPI_DMTABLE_INFO       *InfoTable;
69101d5d5dfSSascha Wildner 
69201d5d5dfSSascha Wildner     /* Main table */
69301d5d5dfSSascha Wildner 
69401d5d5dfSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoViot);
69501d5d5dfSSascha Wildner     if (ACPI_FAILURE (Status))
69601d5d5dfSSascha Wildner     {
69701d5d5dfSSascha Wildner         return;
69801d5d5dfSSascha Wildner     }
69901d5d5dfSSascha Wildner 
70001d5d5dfSSascha Wildner     Viot = ACPI_CAST_PTR (ACPI_TABLE_VIOT, Table);
70101d5d5dfSSascha Wildner 
70201d5d5dfSSascha Wildner     Offset = Viot->NodeOffset;
70301d5d5dfSSascha Wildner     while (Offset < Table->Length)
70401d5d5dfSSascha Wildner     {
70501d5d5dfSSascha Wildner         /* Common subtable header */
70601d5d5dfSSascha Wildner         ViotHeader = ACPI_ADD_PTR (ACPI_VIOT_HEADER, Table, Offset);
70701d5d5dfSSascha Wildner         AcpiOsPrintf ("\n");
70801d5d5dfSSascha Wildner 
70901d5d5dfSSascha Wildner         Length = sizeof (ACPI_VIOT_HEADER);
71001d5d5dfSSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, ViotHeader, Length,
71101d5d5dfSSascha Wildner             AcpiDmTableInfoViotHeader);
71201d5d5dfSSascha Wildner         if (ACPI_FAILURE (Status))
71301d5d5dfSSascha Wildner         {
71401d5d5dfSSascha Wildner             return;
71501d5d5dfSSascha Wildner         }
71601d5d5dfSSascha Wildner 
71701d5d5dfSSascha Wildner         Length = ViotHeader->Length;
71801d5d5dfSSascha Wildner         switch (ViotHeader->Type)
71901d5d5dfSSascha Wildner         {
72001d5d5dfSSascha Wildner         case ACPI_VIOT_NODE_PCI_RANGE:
72101d5d5dfSSascha Wildner 
72201d5d5dfSSascha Wildner             InfoTable = AcpiDmTableInfoViot1;
72301d5d5dfSSascha Wildner             break;
72401d5d5dfSSascha Wildner 
72501d5d5dfSSascha Wildner         case ACPI_VIOT_NODE_MMIO:
72601d5d5dfSSascha Wildner 
72701d5d5dfSSascha Wildner             InfoTable = AcpiDmTableInfoViot2;
72801d5d5dfSSascha Wildner             break;
72901d5d5dfSSascha Wildner 
73001d5d5dfSSascha Wildner         case ACPI_VIOT_NODE_VIRTIO_IOMMU_PCI:
73101d5d5dfSSascha Wildner 
73201d5d5dfSSascha Wildner             InfoTable = AcpiDmTableInfoViot3;
73301d5d5dfSSascha Wildner             break;
73401d5d5dfSSascha Wildner 
73501d5d5dfSSascha Wildner         case ACPI_VIOT_NODE_VIRTIO_IOMMU_MMIO:
73601d5d5dfSSascha Wildner 
73701d5d5dfSSascha Wildner             InfoTable = AcpiDmTableInfoViot4;
73801d5d5dfSSascha Wildner             break;
73901d5d5dfSSascha Wildner 
74001d5d5dfSSascha Wildner         default:
74101d5d5dfSSascha Wildner 
74201d5d5dfSSascha Wildner             AcpiOsPrintf ("\n*** Unknown VIOT node type 0x%X\n",
74301d5d5dfSSascha Wildner                 ViotHeader->Type);
74401d5d5dfSSascha Wildner 
74501d5d5dfSSascha Wildner             /* Attempt to continue */
74601d5d5dfSSascha Wildner 
74701d5d5dfSSascha Wildner             if (!Length)
74801d5d5dfSSascha Wildner             {
74901d5d5dfSSascha Wildner                 AcpiOsPrintf ("Invalid zero length VIOT node\n");
75001d5d5dfSSascha Wildner                 return;
75101d5d5dfSSascha Wildner             }
75201d5d5dfSSascha Wildner             goto NextSubtable;
75301d5d5dfSSascha Wildner         }
75401d5d5dfSSascha Wildner 
75501d5d5dfSSascha Wildner         AcpiOsPrintf ("\n");
75601d5d5dfSSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, ViotHeader, Length,
75701d5d5dfSSascha Wildner             InfoTable);
75801d5d5dfSSascha Wildner         if (ACPI_FAILURE (Status))
75901d5d5dfSSascha Wildner         {
76001d5d5dfSSascha Wildner             return;
76101d5d5dfSSascha Wildner         }
76201d5d5dfSSascha Wildner 
76301d5d5dfSSascha Wildner NextSubtable:
76401d5d5dfSSascha Wildner         Offset += Length;
76501d5d5dfSSascha Wildner     }
76601d5d5dfSSascha Wildner }
76701d5d5dfSSascha Wildner 
76801d5d5dfSSascha Wildner 
76901d5d5dfSSascha Wildner /*******************************************************************************
77001d5d5dfSSascha Wildner  *
7717bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpWdat
7727bcb6cafSSascha Wildner  *
7737bcb6cafSSascha Wildner  * PARAMETERS:  Table               - A WDAT table
7747bcb6cafSSascha Wildner  *
7757bcb6cafSSascha Wildner  * RETURN:      None
7767bcb6cafSSascha Wildner  *
7777bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a WDAT
7787bcb6cafSSascha Wildner  *
7797bcb6cafSSascha Wildner  ******************************************************************************/
7807bcb6cafSSascha Wildner 
7817bcb6cafSSascha Wildner void
AcpiDmDumpWdat(ACPI_TABLE_HEADER * Table)7827bcb6cafSSascha Wildner AcpiDmDumpWdat (
7837bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
7847bcb6cafSSascha Wildner {
7857bcb6cafSSascha Wildner     ACPI_STATUS             Status;
7867bcb6cafSSascha Wildner     UINT32                  Offset = sizeof (ACPI_TABLE_WDAT);
7877bcb6cafSSascha Wildner     ACPI_WDAT_ENTRY         *Subtable;
7887bcb6cafSSascha Wildner 
7897bcb6cafSSascha Wildner 
7907bcb6cafSSascha Wildner     /* Main table */
7917bcb6cafSSascha Wildner 
7927bcb6cafSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoWdat);
7937bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
7947bcb6cafSSascha Wildner     {
7957bcb6cafSSascha Wildner         return;
7967bcb6cafSSascha Wildner     }
7977bcb6cafSSascha Wildner 
7987bcb6cafSSascha Wildner     /* Subtables */
7997bcb6cafSSascha Wildner 
8007bcb6cafSSascha Wildner     Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Table, Offset);
8017bcb6cafSSascha Wildner     while (Offset < Table->Length)
8027bcb6cafSSascha Wildner     {
8037bcb6cafSSascha Wildner         /* Common subtable header */
8047bcb6cafSSascha Wildner 
8057bcb6cafSSascha Wildner         AcpiOsPrintf ("\n");
8067bcb6cafSSascha Wildner         Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
8077bcb6cafSSascha Wildner             sizeof (ACPI_WDAT_ENTRY), AcpiDmTableInfoWdat0);
8087bcb6cafSSascha Wildner         if (ACPI_FAILURE (Status))
8097bcb6cafSSascha Wildner         {
8107bcb6cafSSascha Wildner             return;
8117bcb6cafSSascha Wildner         }
8127bcb6cafSSascha Wildner 
8137bcb6cafSSascha Wildner         /* Point to next subtable */
8147bcb6cafSSascha Wildner 
8157bcb6cafSSascha Wildner         Offset += sizeof (ACPI_WDAT_ENTRY);
8167bcb6cafSSascha Wildner         Subtable = ACPI_ADD_PTR (ACPI_WDAT_ENTRY, Subtable,
8177bcb6cafSSascha Wildner             sizeof (ACPI_WDAT_ENTRY));
8187bcb6cafSSascha Wildner     }
8197bcb6cafSSascha Wildner }
8207bcb6cafSSascha Wildner 
8217bcb6cafSSascha Wildner 
8227bcb6cafSSascha Wildner /*******************************************************************************
8237bcb6cafSSascha Wildner  *
8247bcb6cafSSascha Wildner  * FUNCTION:    AcpiDmDumpWpbt
8257bcb6cafSSascha Wildner  *
8267bcb6cafSSascha Wildner  * PARAMETERS:  Table               - A WPBT table
8277bcb6cafSSascha Wildner  *
8287bcb6cafSSascha Wildner  * RETURN:      None
8297bcb6cafSSascha Wildner  *
8307bcb6cafSSascha Wildner  * DESCRIPTION: Format the contents of a WPBT. This table type consists
8317bcb6cafSSascha Wildner  *              of an open-ended arguments buffer at the end of the table.
8327bcb6cafSSascha Wildner  *
8337bcb6cafSSascha Wildner  ******************************************************************************/
8347bcb6cafSSascha Wildner 
8357bcb6cafSSascha Wildner void
AcpiDmDumpWpbt(ACPI_TABLE_HEADER * Table)8367bcb6cafSSascha Wildner AcpiDmDumpWpbt (
8377bcb6cafSSascha Wildner     ACPI_TABLE_HEADER       *Table)
8387bcb6cafSSascha Wildner {
8397bcb6cafSSascha Wildner     ACPI_STATUS             Status;
8407bcb6cafSSascha Wildner     ACPI_TABLE_WPBT         *Subtable;
8417bcb6cafSSascha Wildner     UINT16                  ArgumentsLength;
8427bcb6cafSSascha Wildner 
8437bcb6cafSSascha Wildner 
8447bcb6cafSSascha Wildner     /* Dump the main table */
8457bcb6cafSSascha Wildner 
8460672a19bSSascha Wildner     Status = AcpiDmDumpTable (Table->Length, 0, Table, 0, AcpiDmTableInfoWpbt);
8477bcb6cafSSascha Wildner     if (ACPI_FAILURE (Status))
8487bcb6cafSSascha Wildner     {
8497bcb6cafSSascha Wildner         return;
8507bcb6cafSSascha Wildner     }
8517bcb6cafSSascha Wildner 
8527bcb6cafSSascha Wildner     /* Extract the arguments buffer length from the main table */
8537bcb6cafSSascha Wildner 
8547bcb6cafSSascha Wildner     Subtable = ACPI_CAST_PTR (ACPI_TABLE_WPBT, Table);
8557bcb6cafSSascha Wildner     ArgumentsLength = Subtable->ArgumentsLength;
8567bcb6cafSSascha Wildner 
8570672a19bSSascha Wildner     /* Dump the arguments buffer if present */
8587bcb6cafSSascha Wildner 
8590672a19bSSascha Wildner     if (ArgumentsLength)
8600672a19bSSascha Wildner     {
8617bcb6cafSSascha Wildner         (void) AcpiDmDumpTable (Table->Length, 0, Table, ArgumentsLength,
8627bcb6cafSSascha Wildner             AcpiDmTableInfoWpbt0);
8637bcb6cafSSascha Wildner     }
8640672a19bSSascha Wildner }
865