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