Home | History | Annotate | Line # | Download | only in resources
rsdump.c revision 1.1.1.2
      1      1.1  jruoho /*******************************************************************************
      2      1.1  jruoho  *
      3      1.1  jruoho  * Module Name: rsdump - Functions to display the resource structures.
      4      1.1  jruoho  *
      5      1.1  jruoho  ******************************************************************************/
      6      1.1  jruoho 
      7  1.1.1.2  jruoho /*
      8  1.1.1.2  jruoho  * Copyright (C) 2000 - 2011, Intel Corp.
      9      1.1  jruoho  * All rights reserved.
     10      1.1  jruoho  *
     11  1.1.1.2  jruoho  * Redistribution and use in source and binary forms, with or without
     12  1.1.1.2  jruoho  * modification, are permitted provided that the following conditions
     13  1.1.1.2  jruoho  * are met:
     14  1.1.1.2  jruoho  * 1. Redistributions of source code must retain the above copyright
     15  1.1.1.2  jruoho  *    notice, this list of conditions, and the following disclaimer,
     16  1.1.1.2  jruoho  *    without modification.
     17  1.1.1.2  jruoho  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
     18  1.1.1.2  jruoho  *    substantially similar to the "NO WARRANTY" disclaimer below
     19  1.1.1.2  jruoho  *    ("Disclaimer") and any redistribution must be conditioned upon
     20  1.1.1.2  jruoho  *    including a substantially similar Disclaimer requirement for further
     21  1.1.1.2  jruoho  *    binary redistribution.
     22  1.1.1.2  jruoho  * 3. Neither the names of the above-listed copyright holders nor the names
     23  1.1.1.2  jruoho  *    of any contributors may be used to endorse or promote products derived
     24  1.1.1.2  jruoho  *    from this software without specific prior written permission.
     25  1.1.1.2  jruoho  *
     26  1.1.1.2  jruoho  * Alternatively, this software may be distributed under the terms of the
     27  1.1.1.2  jruoho  * GNU General Public License ("GPL") version 2 as published by the Free
     28  1.1.1.2  jruoho  * Software Foundation.
     29  1.1.1.2  jruoho  *
     30  1.1.1.2  jruoho  * NO WARRANTY
     31  1.1.1.2  jruoho  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     32  1.1.1.2  jruoho  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     33  1.1.1.2  jruoho  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
     34  1.1.1.2  jruoho  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     35  1.1.1.2  jruoho  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     36  1.1.1.2  jruoho  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     37  1.1.1.2  jruoho  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     38  1.1.1.2  jruoho  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     39  1.1.1.2  jruoho  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     40  1.1.1.2  jruoho  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     41  1.1.1.2  jruoho  * POSSIBILITY OF SUCH DAMAGES.
     42  1.1.1.2  jruoho  */
     43      1.1  jruoho 
     44      1.1  jruoho 
     45      1.1  jruoho #define __RSDUMP_C__
     46      1.1  jruoho 
     47      1.1  jruoho #include "acpi.h"
     48      1.1  jruoho #include "accommon.h"
     49      1.1  jruoho #include "acresrc.h"
     50      1.1  jruoho 
     51      1.1  jruoho #define _COMPONENT          ACPI_RESOURCES
     52      1.1  jruoho         ACPI_MODULE_NAME    ("rsdump")
     53      1.1  jruoho 
     54      1.1  jruoho 
     55      1.1  jruoho #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)
     56      1.1  jruoho 
     57      1.1  jruoho /* Local prototypes */
     58      1.1  jruoho 
     59      1.1  jruoho static void
     60      1.1  jruoho AcpiRsOutString (
     61      1.1  jruoho     char                    *Title,
     62      1.1  jruoho     char                    *Value);
     63      1.1  jruoho 
     64      1.1  jruoho static void
     65      1.1  jruoho AcpiRsOutInteger8 (
     66      1.1  jruoho     char                    *Title,
     67      1.1  jruoho     UINT8                   Value);
     68      1.1  jruoho 
     69      1.1  jruoho static void
     70      1.1  jruoho AcpiRsOutInteger16 (
     71      1.1  jruoho     char                    *Title,
     72      1.1  jruoho     UINT16                  Value);
     73      1.1  jruoho 
     74      1.1  jruoho static void
     75      1.1  jruoho AcpiRsOutInteger32 (
     76      1.1  jruoho     char                    *Title,
     77      1.1  jruoho     UINT32                  Value);
     78      1.1  jruoho 
     79      1.1  jruoho static void
     80      1.1  jruoho AcpiRsOutInteger64 (
     81      1.1  jruoho     char                    *Title,
     82      1.1  jruoho     UINT64                  Value);
     83      1.1  jruoho 
     84      1.1  jruoho static void
     85      1.1  jruoho AcpiRsOutTitle (
     86      1.1  jruoho     char                    *Title);
     87      1.1  jruoho 
     88      1.1  jruoho static void
     89      1.1  jruoho AcpiRsDumpByteList (
     90      1.1  jruoho     UINT16                  Length,
     91      1.1  jruoho     UINT8                   *Data);
     92      1.1  jruoho 
     93      1.1  jruoho static void
     94      1.1  jruoho AcpiRsDumpDwordList (
     95      1.1  jruoho     UINT8                   Length,
     96      1.1  jruoho     UINT32                  *Data);
     97      1.1  jruoho 
     98      1.1  jruoho static void
     99      1.1  jruoho AcpiRsDumpShortByteList (
    100      1.1  jruoho     UINT8                  Length,
    101      1.1  jruoho     UINT8                  *Data);
    102      1.1  jruoho 
    103      1.1  jruoho static void
    104      1.1  jruoho AcpiRsDumpResourceSource (
    105      1.1  jruoho     ACPI_RESOURCE_SOURCE    *ResourceSource);
    106      1.1  jruoho 
    107      1.1  jruoho static void
    108      1.1  jruoho AcpiRsDumpAddressCommon (
    109      1.1  jruoho     ACPI_RESOURCE_DATA      *Resource);
    110      1.1  jruoho 
    111      1.1  jruoho static void
    112      1.1  jruoho AcpiRsDumpDescriptor (
    113      1.1  jruoho     void                    *Resource,
    114      1.1  jruoho     ACPI_RSDUMP_INFO *Table);
    115      1.1  jruoho 
    116      1.1  jruoho 
    117      1.1  jruoho #define ACPI_RSD_OFFSET(f)          (UINT8) ACPI_OFFSET (ACPI_RESOURCE_DATA,f)
    118      1.1  jruoho #define ACPI_PRT_OFFSET(f)          (UINT8) ACPI_OFFSET (ACPI_PCI_ROUTING_TABLE,f)
    119      1.1  jruoho #define ACPI_RSD_TABLE_SIZE(name)   (sizeof(name) / sizeof (ACPI_RSDUMP_INFO))
    120      1.1  jruoho 
    121      1.1  jruoho 
    122      1.1  jruoho /*******************************************************************************
    123      1.1  jruoho  *
    124      1.1  jruoho  * Resource Descriptor info tables
    125      1.1  jruoho  *
    126      1.1  jruoho  * Note: The first table entry must be a Title or Literal and must contain
    127      1.1  jruoho  * the table length (number of table entries)
    128      1.1  jruoho  *
    129      1.1  jruoho  ******************************************************************************/
    130      1.1  jruoho 
    131      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpIrq[7] =
    132      1.1  jruoho {
    133      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpIrq),                "IRQ",                      NULL},
    134      1.1  jruoho     {ACPI_RSD_UINT8 ,   ACPI_RSD_OFFSET (Irq.DescriptorLength),             "Descriptor Length",        NULL},
    135      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Irq.Triggering),                   "Triggering",               AcpiGbl_HeDecode},
    136      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Irq.Polarity),                     "Polarity",                 AcpiGbl_LlDecode},
    137      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Irq.Sharable),                     "Sharing",                  AcpiGbl_ShrDecode},
    138      1.1  jruoho     {ACPI_RSD_UINT8 ,   ACPI_RSD_OFFSET (Irq.InterruptCount),               "Interrupt Count",          NULL},
    139      1.1  jruoho     {ACPI_RSD_SHORTLIST,ACPI_RSD_OFFSET (Irq.Interrupts[0]),                "Interrupt List",           NULL}
    140      1.1  jruoho };
    141      1.1  jruoho 
    142      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpDma[6] =
    143      1.1  jruoho {
    144      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpDma),                "DMA",                      NULL},
    145      1.1  jruoho     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Dma.Type),                         "Speed",                    AcpiGbl_TypDecode},
    146      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Dma.BusMaster),                    "Mastering",                AcpiGbl_BmDecode},
    147      1.1  jruoho     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Dma.Transfer),                     "Transfer Type",            AcpiGbl_SizDecode},
    148      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Dma.ChannelCount),                 "Channel Count",            NULL},
    149      1.1  jruoho     {ACPI_RSD_SHORTLIST,ACPI_RSD_OFFSET (Dma.Channels[0]),                  "Channel List",             NULL}
    150      1.1  jruoho };
    151      1.1  jruoho 
    152      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpStartDpf[4] =
    153      1.1  jruoho {
    154      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpStartDpf),           "Start-Dependent-Functions",NULL},
    155      1.1  jruoho     {ACPI_RSD_UINT8 ,   ACPI_RSD_OFFSET (StartDpf.DescriptorLength),        "Descriptor Length",        NULL},
    156      1.1  jruoho     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (StartDpf.CompatibilityPriority),   "Compatibility Priority",   AcpiGbl_ConfigDecode},
    157      1.1  jruoho     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (StartDpf.PerformanceRobustness),   "Performance/Robustness",   AcpiGbl_ConfigDecode}
    158      1.1  jruoho };
    159      1.1  jruoho 
    160      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpEndDpf[1] =
    161      1.1  jruoho {
    162      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpEndDpf),             "End-Dependent-Functions",  NULL}
    163      1.1  jruoho };
    164      1.1  jruoho 
    165      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpIo[6] =
    166      1.1  jruoho {
    167      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpIo),                 "I/O",                      NULL},
    168      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Io.IoDecode),                      "Address Decoding",         AcpiGbl_IoDecode},
    169      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Io.Minimum),                       "Address Minimum",          NULL},
    170      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Io.Maximum),                       "Address Maximum",          NULL},
    171      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Io.Alignment),                     "Alignment",                NULL},
    172      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Io.AddressLength),                 "Address Length",           NULL}
    173      1.1  jruoho };
    174      1.1  jruoho 
    175      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpFixedIo[3] =
    176      1.1  jruoho {
    177      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpFixedIo),            "Fixed I/O",                NULL},
    178      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (FixedIo.Address),                  "Address",                  NULL},
    179      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (FixedIo.AddressLength),            "Address Length",           NULL}
    180      1.1  jruoho };
    181      1.1  jruoho 
    182      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpVendor[3] =
    183      1.1  jruoho {
    184      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpVendor),             "Vendor Specific",          NULL},
    185      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Vendor.ByteLength),                "Length",                   NULL},
    186      1.1  jruoho     {ACPI_RSD_LONGLIST, ACPI_RSD_OFFSET (Vendor.ByteData[0]),               "Vendor Data",              NULL}
    187      1.1  jruoho };
    188      1.1  jruoho 
    189      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpEndTag[1] =
    190      1.1  jruoho {
    191      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpEndTag),             "EndTag",                   NULL}
    192      1.1  jruoho };
    193      1.1  jruoho 
    194      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpMemory24[6] =
    195      1.1  jruoho {
    196      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpMemory24),           "24-Bit Memory Range",      NULL},
    197      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Memory24.WriteProtect),            "Write Protect",            AcpiGbl_RwDecode},
    198      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.Minimum),                 "Address Minimum",          NULL},
    199      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.Maximum),                 "Address Maximum",          NULL},
    200      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.Alignment),               "Alignment",                NULL},
    201      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.AddressLength),           "Address Length",           NULL}
    202      1.1  jruoho };
    203      1.1  jruoho 
    204      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpMemory32[6] =
    205      1.1  jruoho {
    206      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpMemory32),           "32-Bit Memory Range",      NULL},
    207      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Memory32.WriteProtect),            "Write Protect",            AcpiGbl_RwDecode},
    208      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.Minimum),                 "Address Minimum",          NULL},
    209      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.Maximum),                 "Address Maximum",          NULL},
    210      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.Alignment),               "Alignment",                NULL},
    211      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.AddressLength),           "Address Length",           NULL}
    212      1.1  jruoho };
    213      1.1  jruoho 
    214      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpFixedMemory32[4] =
    215      1.1  jruoho {
    216      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpFixedMemory32),      "32-Bit Fixed Memory Range",NULL},
    217      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (FixedMemory32.WriteProtect),       "Write Protect",            AcpiGbl_RwDecode},
    218      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (FixedMemory32.Address),            "Address",                  NULL},
    219      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (FixedMemory32.AddressLength),      "Address Length",           NULL}
    220      1.1  jruoho };
    221      1.1  jruoho 
    222      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpAddress16[8] =
    223      1.1  jruoho {
    224      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpAddress16),          "16-Bit WORD Address Space",NULL},
    225      1.1  jruoho     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
    226      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.Granularity),            "Granularity",              NULL},
    227      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.Minimum),                "Address Minimum",          NULL},
    228      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.Maximum),                "Address Maximum",          NULL},
    229      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.TranslationOffset),      "Translation Offset",       NULL},
    230      1.1  jruoho     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.AddressLength),          "Address Length",           NULL},
    231      1.1  jruoho     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (Address16.ResourceSource),         NULL,                       NULL}
    232      1.1  jruoho };
    233      1.1  jruoho 
    234      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpAddress32[8] =
    235      1.1  jruoho {
    236      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpAddress32),         "32-Bit DWORD Address Space", NULL},
    237      1.1  jruoho     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
    238      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.Granularity),            "Granularity",              NULL},
    239      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.Minimum),                "Address Minimum",          NULL},
    240      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.Maximum),                "Address Maximum",          NULL},
    241      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.TranslationOffset),      "Translation Offset",       NULL},
    242      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.AddressLength),          "Address Length",           NULL},
    243      1.1  jruoho     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (Address32.ResourceSource),         NULL,                       NULL}
    244      1.1  jruoho };
    245      1.1  jruoho 
    246      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpAddress64[8] =
    247      1.1  jruoho {
    248      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpAddress64),          "64-Bit QWORD Address Space", NULL},
    249      1.1  jruoho     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
    250      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.Granularity),            "Granularity",              NULL},
    251      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.Minimum),                "Address Minimum",          NULL},
    252      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.Maximum),                "Address Maximum",          NULL},
    253      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.TranslationOffset),      "Translation Offset",       NULL},
    254      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.AddressLength),          "Address Length",           NULL},
    255      1.1  jruoho     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (Address64.ResourceSource),         NULL,                       NULL}
    256      1.1  jruoho };
    257      1.1  jruoho 
    258      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpExtAddress64[8] =
    259      1.1  jruoho {
    260      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpExtAddress64),       "64-Bit Extended Address Space", NULL},
    261      1.1  jruoho     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
    262      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.Granularity),         "Granularity",              NULL},
    263      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.Minimum),             "Address Minimum",          NULL},
    264      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.Maximum),             "Address Maximum",          NULL},
    265      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.TranslationOffset),   "Translation Offset",       NULL},
    266      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.AddressLength),       "Address Length",           NULL},
    267      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.TypeSpecific),        "Type-Specific Attribute",  NULL}
    268      1.1  jruoho };
    269      1.1  jruoho 
    270      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpExtIrq[8] =
    271      1.1  jruoho {
    272      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpExtIrq),             "Extended IRQ",             NULL},
    273      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.ProducerConsumer),     "Type",                     AcpiGbl_ConsumeDecode},
    274      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.Triggering),           "Triggering",               AcpiGbl_HeDecode},
    275      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.Polarity),             "Polarity",                 AcpiGbl_LlDecode},
    276      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.Sharable),             "Sharing",                  AcpiGbl_ShrDecode},
    277      1.1  jruoho     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (ExtendedIrq.ResourceSource),       NULL,                       NULL},
    278      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (ExtendedIrq.InterruptCount),       "Interrupt Count",          NULL},
    279      1.1  jruoho     {ACPI_RSD_DWORDLIST,ACPI_RSD_OFFSET (ExtendedIrq.Interrupts[0]),        "Interrupt List",           NULL}
    280      1.1  jruoho };
    281      1.1  jruoho 
    282      1.1  jruoho ACPI_RSDUMP_INFO        AcpiRsDumpGenericReg[6] =
    283      1.1  jruoho {
    284      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpGenericReg),         "Generic Register",         NULL},
    285      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.SpaceId),               "Space ID",                 NULL},
    286      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.BitWidth),              "Bit Width",                NULL},
    287      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.BitOffset),             "Bit Offset",               NULL},
    288      1.1  jruoho     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.AccessSize),            "Access Size",              NULL},
    289      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (GenericReg.Address),               "Address",                  NULL}
    290      1.1  jruoho };
    291      1.1  jruoho 
    292      1.1  jruoho 
    293      1.1  jruoho /*
    294      1.1  jruoho  * Tables used for common address descriptor flag fields
    295      1.1  jruoho  */
    296      1.1  jruoho static ACPI_RSDUMP_INFO AcpiRsDumpGeneralFlags[5] =
    297      1.1  jruoho {
    298      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpGeneralFlags),       NULL,                       NULL},
    299      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.ProducerConsumer),         "Consumer/Producer",        AcpiGbl_ConsumeDecode},
    300      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Decode),                   "Address Decode",           AcpiGbl_DecDecode},
    301      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.MinAddressFixed),          "Min Relocatability",       AcpiGbl_MinDecode},
    302      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.MaxAddressFixed),          "Max Relocatability",       AcpiGbl_MaxDecode}
    303      1.1  jruoho };
    304      1.1  jruoho 
    305      1.1  jruoho static ACPI_RSDUMP_INFO AcpiRsDumpMemoryFlags[5] =
    306      1.1  jruoho {
    307      1.1  jruoho     {ACPI_RSD_LITERAL,  ACPI_RSD_TABLE_SIZE (AcpiRsDumpMemoryFlags),        "Resource Type",            (void *) "Memory Range"},
    308      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.WriteProtect),    "Write Protect",            AcpiGbl_RwDecode},
    309      1.1  jruoho     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.Caching),         "Caching",                  AcpiGbl_MemDecode},
    310      1.1  jruoho     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.RangeType),       "Range Type",               AcpiGbl_MtpDecode},
    311      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.Translation),     "Translation",              AcpiGbl_TtpDecode}
    312      1.1  jruoho };
    313      1.1  jruoho 
    314      1.1  jruoho static ACPI_RSDUMP_INFO AcpiRsDumpIoFlags[4] =
    315      1.1  jruoho {
    316      1.1  jruoho     {ACPI_RSD_LITERAL,  ACPI_RSD_TABLE_SIZE (AcpiRsDumpIoFlags),            "Resource Type",            (void *) "I/O Range"},
    317      1.1  jruoho     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Address.Info.Io.RangeType),        "Range Type",               AcpiGbl_RngDecode},
    318      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Io.Translation),      "Translation",              AcpiGbl_TtpDecode},
    319      1.1  jruoho     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Io.TranslationType),  "Translation Type",         AcpiGbl_TrsDecode}
    320      1.1  jruoho };
    321      1.1  jruoho 
    322      1.1  jruoho 
    323      1.1  jruoho /*
    324      1.1  jruoho  * Table used to dump _PRT contents
    325      1.1  jruoho  */
    326      1.1  jruoho static ACPI_RSDUMP_INFO   AcpiRsDumpPrt[5] =
    327      1.1  jruoho {
    328      1.1  jruoho     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpPrt),                NULL,                       NULL},
    329      1.1  jruoho     {ACPI_RSD_UINT64,   ACPI_PRT_OFFSET (Address),                          "Address",                  NULL},
    330      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_PRT_OFFSET (Pin),                              "Pin",                      NULL},
    331      1.1  jruoho     {ACPI_RSD_STRING,   ACPI_PRT_OFFSET (Source[0]),                        "Source",                   NULL},
    332      1.1  jruoho     {ACPI_RSD_UINT32,   ACPI_PRT_OFFSET (SourceIndex),                      "Source Index",             NULL}
    333      1.1  jruoho };
    334      1.1  jruoho 
    335      1.1  jruoho 
    336      1.1  jruoho /*******************************************************************************
    337      1.1  jruoho  *
    338      1.1  jruoho  * FUNCTION:    AcpiRsDumpDescriptor
    339      1.1  jruoho  *
    340      1.1  jruoho  * PARAMETERS:  Resource
    341      1.1  jruoho  *
    342      1.1  jruoho  * RETURN:      None
    343      1.1  jruoho  *
    344      1.1  jruoho  * DESCRIPTION:
    345      1.1  jruoho  *
    346      1.1  jruoho  ******************************************************************************/
    347      1.1  jruoho 
    348      1.1  jruoho static void
    349      1.1  jruoho AcpiRsDumpDescriptor (
    350      1.1  jruoho     void                    *Resource,
    351      1.1  jruoho     ACPI_RSDUMP_INFO        *Table)
    352      1.1  jruoho {
    353      1.1  jruoho     UINT8                   *Target = NULL;
    354      1.1  jruoho     UINT8                   *PreviousTarget;
    355      1.1  jruoho     char                    *Name;
    356      1.1  jruoho     UINT8                    Count;
    357      1.1  jruoho 
    358      1.1  jruoho 
    359      1.1  jruoho     /* First table entry must contain the table length (# of table entries) */
    360      1.1  jruoho 
    361      1.1  jruoho     Count = Table->Offset;
    362      1.1  jruoho 
    363      1.1  jruoho     while (Count)
    364      1.1  jruoho     {
    365      1.1  jruoho         PreviousTarget = Target;
    366      1.1  jruoho         Target = ACPI_ADD_PTR (UINT8, Resource, Table->Offset);
    367      1.1  jruoho         Name = Table->Name;
    368      1.1  jruoho 
    369      1.1  jruoho         switch (Table->Opcode)
    370      1.1  jruoho         {
    371      1.1  jruoho         case ACPI_RSD_TITLE:
    372      1.1  jruoho             /*
    373      1.1  jruoho              * Optional resource title
    374      1.1  jruoho              */
    375      1.1  jruoho             if (Table->Name)
    376      1.1  jruoho             {
    377      1.1  jruoho                 AcpiOsPrintf ("%s Resource\n", Name);
    378      1.1  jruoho             }
    379      1.1  jruoho             break;
    380      1.1  jruoho 
    381      1.1  jruoho         /* Strings */
    382      1.1  jruoho 
    383      1.1  jruoho         case ACPI_RSD_LITERAL:
    384      1.1  jruoho             AcpiRsOutString (Name, ACPI_CAST_PTR (char, Table->Pointer));
    385      1.1  jruoho             break;
    386      1.1  jruoho 
    387      1.1  jruoho         case ACPI_RSD_STRING:
    388      1.1  jruoho             AcpiRsOutString (Name, ACPI_CAST_PTR (char, Target));
    389      1.1  jruoho             break;
    390      1.1  jruoho 
    391      1.1  jruoho         /* Data items, 8/16/32/64 bit */
    392      1.1  jruoho 
    393      1.1  jruoho         case ACPI_RSD_UINT8:
    394      1.1  jruoho             AcpiRsOutInteger8 (Name, ACPI_GET8 (Target));
    395      1.1  jruoho             break;
    396      1.1  jruoho 
    397      1.1  jruoho         case ACPI_RSD_UINT16:
    398      1.1  jruoho             AcpiRsOutInteger16 (Name, ACPI_GET16 (Target));
    399      1.1  jruoho             break;
    400      1.1  jruoho 
    401      1.1  jruoho         case ACPI_RSD_UINT32:
    402      1.1  jruoho             AcpiRsOutInteger32 (Name, ACPI_GET32 (Target));
    403      1.1  jruoho             break;
    404      1.1  jruoho 
    405      1.1  jruoho         case ACPI_RSD_UINT64:
    406      1.1  jruoho             AcpiRsOutInteger64 (Name, ACPI_GET64 (Target));
    407      1.1  jruoho             break;
    408      1.1  jruoho 
    409      1.1  jruoho         /* Flags: 1-bit and 2-bit flags supported */
    410      1.1  jruoho 
    411      1.1  jruoho         case ACPI_RSD_1BITFLAG:
    412      1.1  jruoho             AcpiRsOutString (Name, ACPI_CAST_PTR (char,
    413      1.1  jruoho                 Table->Pointer [*Target & 0x01]));
    414      1.1  jruoho             break;
    415      1.1  jruoho 
    416      1.1  jruoho         case ACPI_RSD_2BITFLAG:
    417      1.1  jruoho             AcpiRsOutString (Name, ACPI_CAST_PTR (char,
    418      1.1  jruoho                 Table->Pointer [*Target & 0x03]));
    419      1.1  jruoho             break;
    420      1.1  jruoho 
    421      1.1  jruoho         case ACPI_RSD_SHORTLIST:
    422      1.1  jruoho             /*
    423      1.1  jruoho              * Short byte list (single line output) for DMA and IRQ resources
    424      1.1  jruoho              * Note: The list length is obtained from the previous table entry
    425      1.1  jruoho              */
    426      1.1  jruoho             if (PreviousTarget)
    427      1.1  jruoho             {
    428      1.1  jruoho                 AcpiRsOutTitle (Name);
    429      1.1  jruoho                 AcpiRsDumpShortByteList (*PreviousTarget, Target);
    430      1.1  jruoho             }
    431      1.1  jruoho             break;
    432      1.1  jruoho 
    433      1.1  jruoho         case ACPI_RSD_LONGLIST:
    434      1.1  jruoho             /*
    435      1.1  jruoho              * Long byte list for Vendor resource data
    436      1.1  jruoho              * Note: The list length is obtained from the previous table entry
    437      1.1  jruoho              */
    438      1.1  jruoho             if (PreviousTarget)
    439      1.1  jruoho             {
    440      1.1  jruoho                 AcpiRsDumpByteList (ACPI_GET16 (PreviousTarget), Target);
    441      1.1  jruoho             }
    442      1.1  jruoho             break;
    443      1.1  jruoho 
    444      1.1  jruoho         case ACPI_RSD_DWORDLIST:
    445      1.1  jruoho             /*
    446      1.1  jruoho              * Dword list for Extended Interrupt resources
    447      1.1  jruoho              * Note: The list length is obtained from the previous table entry
    448      1.1  jruoho              */
    449      1.1  jruoho             if (PreviousTarget)
    450      1.1  jruoho             {
    451      1.1  jruoho                 AcpiRsDumpDwordList (*PreviousTarget,
    452      1.1  jruoho                     ACPI_CAST_PTR (UINT32, Target));
    453      1.1  jruoho             }
    454      1.1  jruoho             break;
    455      1.1  jruoho 
    456      1.1  jruoho         case ACPI_RSD_ADDRESS:
    457      1.1  jruoho             /*
    458      1.1  jruoho              * Common flags for all Address resources
    459      1.1  jruoho              */
    460      1.1  jruoho             AcpiRsDumpAddressCommon (ACPI_CAST_PTR (ACPI_RESOURCE_DATA, Target));
    461      1.1  jruoho             break;
    462      1.1  jruoho 
    463      1.1  jruoho         case ACPI_RSD_SOURCE:
    464      1.1  jruoho             /*
    465      1.1  jruoho              * Optional ResourceSource for Address resources
    466      1.1  jruoho              */
    467      1.1  jruoho             AcpiRsDumpResourceSource (ACPI_CAST_PTR (ACPI_RESOURCE_SOURCE, Target));
    468      1.1  jruoho             break;
    469      1.1  jruoho 
    470      1.1  jruoho         default:
    471      1.1  jruoho             AcpiOsPrintf ("**** Invalid table opcode [%X] ****\n",
    472      1.1  jruoho                 Table->Opcode);
    473      1.1  jruoho             return;
    474      1.1  jruoho         }
    475      1.1  jruoho 
    476      1.1  jruoho         Table++;
    477      1.1  jruoho         Count--;
    478      1.1  jruoho     }
    479      1.1  jruoho }
    480      1.1  jruoho 
    481      1.1  jruoho 
    482      1.1  jruoho /*******************************************************************************
    483      1.1  jruoho  *
    484      1.1  jruoho  * FUNCTION:    AcpiRsDumpResourceSource
    485      1.1  jruoho  *
    486      1.1  jruoho  * PARAMETERS:  ResourceSource      - Pointer to a Resource Source struct
    487      1.1  jruoho  *
    488      1.1  jruoho  * RETURN:      None
    489      1.1  jruoho  *
    490      1.1  jruoho  * DESCRIPTION: Common routine for dumping the optional ResourceSource and the
    491      1.1  jruoho  *              corresponding ResourceSourceIndex.
    492      1.1  jruoho  *
    493      1.1  jruoho  ******************************************************************************/
    494      1.1  jruoho 
    495      1.1  jruoho static void
    496      1.1  jruoho AcpiRsDumpResourceSource (
    497      1.1  jruoho     ACPI_RESOURCE_SOURCE    *ResourceSource)
    498      1.1  jruoho {
    499      1.1  jruoho     ACPI_FUNCTION_ENTRY ();
    500      1.1  jruoho 
    501      1.1  jruoho 
    502      1.1  jruoho     if (ResourceSource->Index == 0xFF)
    503      1.1  jruoho     {
    504      1.1  jruoho         return;
    505      1.1  jruoho     }
    506      1.1  jruoho 
    507      1.1  jruoho     AcpiRsOutInteger8 ("Resource Source Index",
    508      1.1  jruoho         ResourceSource->Index);
    509      1.1  jruoho 
    510      1.1  jruoho     AcpiRsOutString ("Resource Source",
    511      1.1  jruoho         ResourceSource->StringPtr ?
    512      1.1  jruoho             ResourceSource->StringPtr : "[Not Specified]");
    513      1.1  jruoho }
    514      1.1  jruoho 
    515      1.1  jruoho 
    516      1.1  jruoho /*******************************************************************************
    517      1.1  jruoho  *
    518      1.1  jruoho  * FUNCTION:    AcpiRsDumpAddressCommon
    519      1.1  jruoho  *
    520      1.1  jruoho  * PARAMETERS:  Resource        - Pointer to an internal resource descriptor
    521      1.1  jruoho  *
    522      1.1  jruoho  * RETURN:      None
    523      1.1  jruoho  *
    524      1.1  jruoho  * DESCRIPTION: Dump the fields that are common to all Address resource
    525      1.1  jruoho  *              descriptors
    526      1.1  jruoho  *
    527      1.1  jruoho  ******************************************************************************/
    528      1.1  jruoho 
    529      1.1  jruoho static void
    530      1.1  jruoho AcpiRsDumpAddressCommon (
    531      1.1  jruoho     ACPI_RESOURCE_DATA      *Resource)
    532      1.1  jruoho {
    533      1.1  jruoho     ACPI_FUNCTION_ENTRY ();
    534      1.1  jruoho 
    535      1.1  jruoho 
    536      1.1  jruoho    /* Decode the type-specific flags */
    537      1.1  jruoho 
    538      1.1  jruoho     switch (Resource->Address.ResourceType)
    539      1.1  jruoho     {
    540      1.1  jruoho     case ACPI_MEMORY_RANGE:
    541      1.1  jruoho 
    542      1.1  jruoho         AcpiRsDumpDescriptor (Resource, AcpiRsDumpMemoryFlags);
    543      1.1  jruoho         break;
    544      1.1  jruoho 
    545      1.1  jruoho     case ACPI_IO_RANGE:
    546      1.1  jruoho 
    547      1.1  jruoho         AcpiRsDumpDescriptor (Resource, AcpiRsDumpIoFlags);
    548      1.1  jruoho         break;
    549      1.1  jruoho 
    550      1.1  jruoho     case ACPI_BUS_NUMBER_RANGE:
    551      1.1  jruoho 
    552      1.1  jruoho         AcpiRsOutString ("Resource Type", "Bus Number Range");
    553      1.1  jruoho         break;
    554      1.1  jruoho 
    555      1.1  jruoho     default:
    556      1.1  jruoho 
    557      1.1  jruoho         AcpiRsOutInteger8 ("Resource Type",
    558      1.1  jruoho             (UINT8) Resource->Address.ResourceType);
    559      1.1  jruoho         break;
    560      1.1  jruoho     }
    561      1.1  jruoho 
    562      1.1  jruoho     /* Decode the general flags */
    563      1.1  jruoho 
    564      1.1  jruoho     AcpiRsDumpDescriptor (Resource, AcpiRsDumpGeneralFlags);
    565      1.1  jruoho }
    566      1.1  jruoho 
    567      1.1  jruoho 
    568      1.1  jruoho /*******************************************************************************
    569      1.1  jruoho  *
    570      1.1  jruoho  * FUNCTION:    AcpiRsDumpResourceList
    571      1.1  jruoho  *
    572      1.1  jruoho  * PARAMETERS:  ResourceList        - Pointer to a resource descriptor list
    573      1.1  jruoho  *
    574      1.1  jruoho  * RETURN:      None
    575      1.1  jruoho  *
    576      1.1  jruoho  * DESCRIPTION: Dispatches the structure to the correct dump routine.
    577      1.1  jruoho  *
    578      1.1  jruoho  ******************************************************************************/
    579      1.1  jruoho 
    580      1.1  jruoho void
    581      1.1  jruoho AcpiRsDumpResourceList (
    582      1.1  jruoho     ACPI_RESOURCE           *ResourceList)
    583      1.1  jruoho {
    584      1.1  jruoho     UINT32                  Count = 0;
    585      1.1  jruoho     UINT32                  Type;
    586      1.1  jruoho 
    587      1.1  jruoho 
    588      1.1  jruoho     ACPI_FUNCTION_ENTRY ();
    589      1.1  jruoho 
    590      1.1  jruoho 
    591      1.1  jruoho     if (!(AcpiDbgLevel & ACPI_LV_RESOURCES) || !( _COMPONENT & AcpiDbgLayer))
    592      1.1  jruoho     {
    593      1.1  jruoho         return;
    594      1.1  jruoho     }
    595      1.1  jruoho 
    596      1.1  jruoho     /* Walk list and dump all resource descriptors (END_TAG terminates) */
    597      1.1  jruoho 
    598      1.1  jruoho     do
    599      1.1  jruoho     {
    600      1.1  jruoho         AcpiOsPrintf ("\n[%02X] ", Count);
    601      1.1  jruoho         Count++;
    602      1.1  jruoho 
    603      1.1  jruoho         /* Validate Type before dispatch */
    604      1.1  jruoho 
    605      1.1  jruoho         Type = ResourceList->Type;
    606      1.1  jruoho         if (Type > ACPI_RESOURCE_TYPE_MAX)
    607      1.1  jruoho         {
    608      1.1  jruoho             AcpiOsPrintf (
    609      1.1  jruoho                 "Invalid descriptor type (%X) in resource list\n",
    610      1.1  jruoho                 ResourceList->Type);
    611      1.1  jruoho             return;
    612      1.1  jruoho         }
    613      1.1  jruoho 
    614      1.1  jruoho         /* Dump the resource descriptor */
    615      1.1  jruoho 
    616      1.1  jruoho         AcpiRsDumpDescriptor (&ResourceList->Data,
    617      1.1  jruoho             AcpiGbl_DumpResourceDispatch[Type]);
    618      1.1  jruoho 
    619      1.1  jruoho         /* Point to the next resource structure */
    620      1.1  jruoho 
    621      1.1  jruoho         ResourceList = ACPI_ADD_PTR (ACPI_RESOURCE, ResourceList,
    622      1.1  jruoho                             ResourceList->Length);
    623      1.1  jruoho 
    624      1.1  jruoho         /* Exit when END_TAG descriptor is reached */
    625      1.1  jruoho 
    626      1.1  jruoho     } while (Type != ACPI_RESOURCE_TYPE_END_TAG);
    627      1.1  jruoho }
    628      1.1  jruoho 
    629      1.1  jruoho 
    630      1.1  jruoho /*******************************************************************************
    631      1.1  jruoho  *
    632      1.1  jruoho  * FUNCTION:    AcpiRsDumpIrqList
    633      1.1  jruoho  *
    634      1.1  jruoho  * PARAMETERS:  RouteTable      - Pointer to the routing table to dump.
    635      1.1  jruoho  *
    636      1.1  jruoho  * RETURN:      None
    637      1.1  jruoho  *
    638      1.1  jruoho  * DESCRIPTION: Print IRQ routing table
    639      1.1  jruoho  *
    640      1.1  jruoho  ******************************************************************************/
    641      1.1  jruoho 
    642      1.1  jruoho void
    643      1.1  jruoho AcpiRsDumpIrqList (
    644      1.1  jruoho     UINT8                   *RouteTable)
    645      1.1  jruoho {
    646      1.1  jruoho     ACPI_PCI_ROUTING_TABLE  *PrtElement;
    647      1.1  jruoho     UINT8                   Count;
    648      1.1  jruoho 
    649      1.1  jruoho 
    650      1.1  jruoho     ACPI_FUNCTION_ENTRY ();
    651      1.1  jruoho 
    652      1.1  jruoho 
    653      1.1  jruoho     if (!(AcpiDbgLevel & ACPI_LV_RESOURCES) || !( _COMPONENT & AcpiDbgLayer))
    654      1.1  jruoho     {
    655      1.1  jruoho         return;
    656      1.1  jruoho     }
    657      1.1  jruoho 
    658      1.1  jruoho     PrtElement = ACPI_CAST_PTR (ACPI_PCI_ROUTING_TABLE, RouteTable);
    659      1.1  jruoho 
    660      1.1  jruoho     /* Dump all table elements, Exit on zero length element */
    661      1.1  jruoho 
    662      1.1  jruoho     for (Count = 0; PrtElement->Length; Count++)
    663      1.1  jruoho     {
    664      1.1  jruoho         AcpiOsPrintf ("\n[%02X] PCI IRQ Routing Table Package\n", Count);
    665      1.1  jruoho         AcpiRsDumpDescriptor (PrtElement, AcpiRsDumpPrt);
    666      1.1  jruoho 
    667      1.1  jruoho         PrtElement = ACPI_ADD_PTR (ACPI_PCI_ROUTING_TABLE,
    668      1.1  jruoho                         PrtElement, PrtElement->Length);
    669      1.1  jruoho     }
    670      1.1  jruoho }
    671      1.1  jruoho 
    672      1.1  jruoho 
    673      1.1  jruoho /*******************************************************************************
    674      1.1  jruoho  *
    675      1.1  jruoho  * FUNCTION:    AcpiRsOut*
    676      1.1  jruoho  *
    677      1.1  jruoho  * PARAMETERS:  Title       - Name of the resource field
    678      1.1  jruoho  *              Value       - Value of the resource field
    679      1.1  jruoho  *
    680      1.1  jruoho  * RETURN:      None
    681      1.1  jruoho  *
    682      1.1  jruoho  * DESCRIPTION: Miscellaneous helper functions to consistently format the
    683      1.1  jruoho  *              output of the resource dump routines
    684      1.1  jruoho  *
    685      1.1  jruoho  ******************************************************************************/
    686      1.1  jruoho 
    687      1.1  jruoho static void
    688      1.1  jruoho AcpiRsOutString (
    689      1.1  jruoho     char                    *Title,
    690      1.1  jruoho     char                    *Value)
    691      1.1  jruoho {
    692      1.1  jruoho     AcpiOsPrintf ("%27s : %s", Title, Value);
    693      1.1  jruoho     if (!*Value)
    694      1.1  jruoho     {
    695      1.1  jruoho         AcpiOsPrintf ("[NULL NAMESTRING]");
    696      1.1  jruoho     }
    697      1.1  jruoho     AcpiOsPrintf ("\n");
    698      1.1  jruoho }
    699      1.1  jruoho 
    700      1.1  jruoho static void
    701      1.1  jruoho AcpiRsOutInteger8 (
    702      1.1  jruoho     char                    *Title,
    703      1.1  jruoho     UINT8                   Value)
    704      1.1  jruoho {
    705      1.1  jruoho     AcpiOsPrintf ("%27s : %2.2X\n", Title, Value);
    706      1.1  jruoho }
    707      1.1  jruoho 
    708      1.1  jruoho static void
    709      1.1  jruoho AcpiRsOutInteger16 (
    710      1.1  jruoho     char                    *Title,
    711      1.1  jruoho     UINT16                  Value)
    712      1.1  jruoho {
    713      1.1  jruoho     AcpiOsPrintf ("%27s : %4.4X\n", Title, Value);
    714      1.1  jruoho }
    715      1.1  jruoho 
    716      1.1  jruoho static void
    717      1.1  jruoho AcpiRsOutInteger32 (
    718      1.1  jruoho     char                    *Title,
    719      1.1  jruoho     UINT32                  Value)
    720      1.1  jruoho {
    721      1.1  jruoho     AcpiOsPrintf ("%27s : %8.8X\n", Title, Value);
    722      1.1  jruoho }
    723      1.1  jruoho 
    724      1.1  jruoho static void
    725      1.1  jruoho AcpiRsOutInteger64 (
    726      1.1  jruoho     char                    *Title,
    727      1.1  jruoho     UINT64                  Value)
    728      1.1  jruoho {
    729      1.1  jruoho     AcpiOsPrintf ("%27s : %8.8X%8.8X\n", Title,
    730      1.1  jruoho         ACPI_FORMAT_UINT64 (Value));
    731      1.1  jruoho }
    732      1.1  jruoho 
    733      1.1  jruoho static void
    734      1.1  jruoho AcpiRsOutTitle (
    735      1.1  jruoho     char                    *Title)
    736      1.1  jruoho {
    737      1.1  jruoho     AcpiOsPrintf ("%27s : ", Title);
    738      1.1  jruoho }
    739      1.1  jruoho 
    740      1.1  jruoho 
    741      1.1  jruoho /*******************************************************************************
    742      1.1  jruoho  *
    743      1.1  jruoho  * FUNCTION:    AcpiRsDump*List
    744      1.1  jruoho  *
    745      1.1  jruoho  * PARAMETERS:  Length      - Number of elements in the list
    746      1.1  jruoho  *              Data        - Start of the list
    747      1.1  jruoho  *
    748      1.1  jruoho  * RETURN:      None
    749      1.1  jruoho  *
    750      1.1  jruoho  * DESCRIPTION: Miscellaneous functions to dump lists of raw data
    751      1.1  jruoho  *
    752      1.1  jruoho  ******************************************************************************/
    753      1.1  jruoho 
    754      1.1  jruoho static void
    755      1.1  jruoho AcpiRsDumpByteList (
    756      1.1  jruoho     UINT16                  Length,
    757      1.1  jruoho     UINT8                   *Data)
    758      1.1  jruoho {
    759      1.1  jruoho     UINT8                   i;
    760      1.1  jruoho 
    761      1.1  jruoho 
    762      1.1  jruoho     for (i = 0; i < Length; i++)
    763      1.1  jruoho     {
    764      1.1  jruoho         AcpiOsPrintf ("%25s%2.2X : %2.2X\n",
    765      1.1  jruoho             "Byte", i, Data[i]);
    766      1.1  jruoho     }
    767      1.1  jruoho }
    768      1.1  jruoho 
    769      1.1  jruoho static void
    770      1.1  jruoho AcpiRsDumpShortByteList (
    771      1.1  jruoho     UINT8                  Length,
    772      1.1  jruoho     UINT8                  *Data)
    773      1.1  jruoho {
    774      1.1  jruoho     UINT8                   i;
    775      1.1  jruoho 
    776      1.1  jruoho 
    777      1.1  jruoho     for (i = 0; i < Length; i++)
    778      1.1  jruoho     {
    779      1.1  jruoho         AcpiOsPrintf ("%X ", Data[i]);
    780      1.1  jruoho     }
    781      1.1  jruoho     AcpiOsPrintf ("\n");
    782      1.1  jruoho }
    783      1.1  jruoho 
    784      1.1  jruoho static void
    785      1.1  jruoho AcpiRsDumpDwordList (
    786      1.1  jruoho     UINT8                   Length,
    787      1.1  jruoho     UINT32                  *Data)
    788      1.1  jruoho {
    789      1.1  jruoho     UINT8                   i;
    790      1.1  jruoho 
    791      1.1  jruoho 
    792      1.1  jruoho     for (i = 0; i < Length; i++)
    793      1.1  jruoho     {
    794      1.1  jruoho         AcpiOsPrintf ("%25s%2.2X : %8.8X\n",
    795      1.1  jruoho             "Dword", i, Data[i]);
    796      1.1  jruoho     }
    797      1.1  jruoho }
    798      1.1  jruoho 
    799      1.1  jruoho #endif
    800      1.1  jruoho 
    801