xref: /freebsd/sys/contrib/dev/acpica/components/resources/rsdumpinfo.c (revision efcc2a30547c400649a351e85e6cd97dab8f3817)
1*efcc2a30SJung-uk Kim /*******************************************************************************
2*efcc2a30SJung-uk Kim  *
3*efcc2a30SJung-uk Kim  * Module Name: rsdumpinfo - Tables used to display resource descriptors.
4*efcc2a30SJung-uk Kim  *
5*efcc2a30SJung-uk Kim  ******************************************************************************/
6*efcc2a30SJung-uk Kim 
7*efcc2a30SJung-uk Kim /*
8*efcc2a30SJung-uk Kim  * Copyright (C) 2000 - 2013, Intel Corp.
9*efcc2a30SJung-uk Kim  * All rights reserved.
10*efcc2a30SJung-uk Kim  *
11*efcc2a30SJung-uk Kim  * Redistribution and use in source and binary forms, with or without
12*efcc2a30SJung-uk Kim  * modification, are permitted provided that the following conditions
13*efcc2a30SJung-uk Kim  * are met:
14*efcc2a30SJung-uk Kim  * 1. Redistributions of source code must retain the above copyright
15*efcc2a30SJung-uk Kim  *    notice, this list of conditions, and the following disclaimer,
16*efcc2a30SJung-uk Kim  *    without modification.
17*efcc2a30SJung-uk Kim  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18*efcc2a30SJung-uk Kim  *    substantially similar to the "NO WARRANTY" disclaimer below
19*efcc2a30SJung-uk Kim  *    ("Disclaimer") and any redistribution must be conditioned upon
20*efcc2a30SJung-uk Kim  *    including a substantially similar Disclaimer requirement for further
21*efcc2a30SJung-uk Kim  *    binary redistribution.
22*efcc2a30SJung-uk Kim  * 3. Neither the names of the above-listed copyright holders nor the names
23*efcc2a30SJung-uk Kim  *    of any contributors may be used to endorse or promote products derived
24*efcc2a30SJung-uk Kim  *    from this software without specific prior written permission.
25*efcc2a30SJung-uk Kim  *
26*efcc2a30SJung-uk Kim  * Alternatively, this software may be distributed under the terms of the
27*efcc2a30SJung-uk Kim  * GNU General Public License ("GPL") version 2 as published by the Free
28*efcc2a30SJung-uk Kim  * Software Foundation.
29*efcc2a30SJung-uk Kim  *
30*efcc2a30SJung-uk Kim  * NO WARRANTY
31*efcc2a30SJung-uk Kim  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32*efcc2a30SJung-uk Kim  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33*efcc2a30SJung-uk Kim  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34*efcc2a30SJung-uk Kim  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35*efcc2a30SJung-uk Kim  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36*efcc2a30SJung-uk Kim  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37*efcc2a30SJung-uk Kim  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38*efcc2a30SJung-uk Kim  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39*efcc2a30SJung-uk Kim  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40*efcc2a30SJung-uk Kim  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41*efcc2a30SJung-uk Kim  * POSSIBILITY OF SUCH DAMAGES.
42*efcc2a30SJung-uk Kim  */
43*efcc2a30SJung-uk Kim 
44*efcc2a30SJung-uk Kim 
45*efcc2a30SJung-uk Kim #define __RSDUMPINFO_C__
46*efcc2a30SJung-uk Kim 
47*efcc2a30SJung-uk Kim #include <contrib/dev/acpica/include/acpi.h>
48*efcc2a30SJung-uk Kim #include <contrib/dev/acpica/include/accommon.h>
49*efcc2a30SJung-uk Kim #include <contrib/dev/acpica/include/acresrc.h>
50*efcc2a30SJung-uk Kim 
51*efcc2a30SJung-uk Kim #define _COMPONENT          ACPI_RESOURCES
52*efcc2a30SJung-uk Kim         ACPI_MODULE_NAME    ("rsdumpinfo")
53*efcc2a30SJung-uk Kim 
54*efcc2a30SJung-uk Kim 
55*efcc2a30SJung-uk Kim #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)
56*efcc2a30SJung-uk Kim 
57*efcc2a30SJung-uk Kim 
58*efcc2a30SJung-uk Kim #define ACPI_RSD_OFFSET(f)          (UINT8) ACPI_OFFSET (ACPI_RESOURCE_DATA,f)
59*efcc2a30SJung-uk Kim #define ACPI_PRT_OFFSET(f)          (UINT8) ACPI_OFFSET (ACPI_PCI_ROUTING_TABLE,f)
60*efcc2a30SJung-uk Kim #define ACPI_RSD_TABLE_SIZE(name)   (sizeof(name) / sizeof (ACPI_RSDUMP_INFO))
61*efcc2a30SJung-uk Kim 
62*efcc2a30SJung-uk Kim 
63*efcc2a30SJung-uk Kim /*******************************************************************************
64*efcc2a30SJung-uk Kim  *
65*efcc2a30SJung-uk Kim  * Resource Descriptor info tables
66*efcc2a30SJung-uk Kim  *
67*efcc2a30SJung-uk Kim  * Note: The first table entry must be a Title or Literal and must contain
68*efcc2a30SJung-uk Kim  * the table length (number of table entries)
69*efcc2a30SJung-uk Kim  *
70*efcc2a30SJung-uk Kim  ******************************************************************************/
71*efcc2a30SJung-uk Kim 
72*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpIrq[7] =
73*efcc2a30SJung-uk Kim {
74*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpIrq),                "IRQ",                      NULL},
75*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8 ,   ACPI_RSD_OFFSET (Irq.DescriptorLength),             "Descriptor Length",        NULL},
76*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Irq.Triggering),                   "Triggering",               AcpiGbl_HeDecode},
77*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Irq.Polarity),                     "Polarity",                 AcpiGbl_LlDecode},
78*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Irq.Sharable),                     "Sharing",                  AcpiGbl_ShrDecode},
79*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8 ,   ACPI_RSD_OFFSET (Irq.InterruptCount),               "Interrupt Count",          NULL},
80*efcc2a30SJung-uk Kim     {ACPI_RSD_SHORTLIST,ACPI_RSD_OFFSET (Irq.Interrupts[0]),                "Interrupt List",           NULL}
81*efcc2a30SJung-uk Kim };
82*efcc2a30SJung-uk Kim 
83*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpDma[6] =
84*efcc2a30SJung-uk Kim {
85*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpDma),                "DMA",                      NULL},
86*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Dma.Type),                         "Speed",                    AcpiGbl_TypDecode},
87*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Dma.BusMaster),                    "Mastering",                AcpiGbl_BmDecode},
88*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Dma.Transfer),                     "Transfer Type",            AcpiGbl_SizDecode},
89*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Dma.ChannelCount),                 "Channel Count",            NULL},
90*efcc2a30SJung-uk Kim     {ACPI_RSD_SHORTLIST,ACPI_RSD_OFFSET (Dma.Channels[0]),                  "Channel List",             NULL}
91*efcc2a30SJung-uk Kim };
92*efcc2a30SJung-uk Kim 
93*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpStartDpf[4] =
94*efcc2a30SJung-uk Kim {
95*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpStartDpf),           "Start-Dependent-Functions",NULL},
96*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8 ,   ACPI_RSD_OFFSET (StartDpf.DescriptorLength),        "Descriptor Length",        NULL},
97*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (StartDpf.CompatibilityPriority),   "Compatibility Priority",   AcpiGbl_ConfigDecode},
98*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (StartDpf.PerformanceRobustness),   "Performance/Robustness",   AcpiGbl_ConfigDecode}
99*efcc2a30SJung-uk Kim };
100*efcc2a30SJung-uk Kim 
101*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpEndDpf[1] =
102*efcc2a30SJung-uk Kim {
103*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpEndDpf),             "End-Dependent-Functions",  NULL}
104*efcc2a30SJung-uk Kim };
105*efcc2a30SJung-uk Kim 
106*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpIo[6] =
107*efcc2a30SJung-uk Kim {
108*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpIo),                 "I/O",                      NULL},
109*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Io.IoDecode),                      "Address Decoding",         AcpiGbl_IoDecode},
110*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Io.Minimum),                       "Address Minimum",          NULL},
111*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Io.Maximum),                       "Address Maximum",          NULL},
112*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Io.Alignment),                     "Alignment",                NULL},
113*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Io.AddressLength),                 "Address Length",           NULL}
114*efcc2a30SJung-uk Kim };
115*efcc2a30SJung-uk Kim 
116*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpFixedIo[3] =
117*efcc2a30SJung-uk Kim {
118*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpFixedIo),            "Fixed I/O",                NULL},
119*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (FixedIo.Address),                  "Address",                  NULL},
120*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (FixedIo.AddressLength),            "Address Length",           NULL}
121*efcc2a30SJung-uk Kim };
122*efcc2a30SJung-uk Kim 
123*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpVendor[3] =
124*efcc2a30SJung-uk Kim {
125*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpVendor),             "Vendor Specific",          NULL},
126*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Vendor.ByteLength),                "Length",                   NULL},
127*efcc2a30SJung-uk Kim     {ACPI_RSD_LONGLIST, ACPI_RSD_OFFSET (Vendor.ByteData[0]),               "Vendor Data",              NULL}
128*efcc2a30SJung-uk Kim };
129*efcc2a30SJung-uk Kim 
130*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpEndTag[1] =
131*efcc2a30SJung-uk Kim {
132*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpEndTag),             "EndTag",                   NULL}
133*efcc2a30SJung-uk Kim };
134*efcc2a30SJung-uk Kim 
135*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpMemory24[6] =
136*efcc2a30SJung-uk Kim {
137*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpMemory24),           "24-Bit Memory Range",      NULL},
138*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Memory24.WriteProtect),            "Write Protect",            AcpiGbl_RwDecode},
139*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.Minimum),                 "Address Minimum",          NULL},
140*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.Maximum),                 "Address Maximum",          NULL},
141*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.Alignment),               "Alignment",                NULL},
142*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Memory24.AddressLength),           "Address Length",           NULL}
143*efcc2a30SJung-uk Kim };
144*efcc2a30SJung-uk Kim 
145*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpMemory32[6] =
146*efcc2a30SJung-uk Kim {
147*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpMemory32),           "32-Bit Memory Range",      NULL},
148*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Memory32.WriteProtect),            "Write Protect",            AcpiGbl_RwDecode},
149*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.Minimum),                 "Address Minimum",          NULL},
150*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.Maximum),                 "Address Maximum",          NULL},
151*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.Alignment),               "Alignment",                NULL},
152*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Memory32.AddressLength),           "Address Length",           NULL}
153*efcc2a30SJung-uk Kim };
154*efcc2a30SJung-uk Kim 
155*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpFixedMemory32[4] =
156*efcc2a30SJung-uk Kim {
157*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpFixedMemory32),      "32-Bit Fixed Memory Range",NULL},
158*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (FixedMemory32.WriteProtect),       "Write Protect",            AcpiGbl_RwDecode},
159*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (FixedMemory32.Address),            "Address",                  NULL},
160*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (FixedMemory32.AddressLength),      "Address Length",           NULL}
161*efcc2a30SJung-uk Kim };
162*efcc2a30SJung-uk Kim 
163*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpAddress16[8] =
164*efcc2a30SJung-uk Kim {
165*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpAddress16),          "16-Bit WORD Address Space",NULL},
166*efcc2a30SJung-uk Kim     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
167*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.Granularity),            "Granularity",              NULL},
168*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.Minimum),                "Address Minimum",          NULL},
169*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.Maximum),                "Address Maximum",          NULL},
170*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.TranslationOffset),      "Translation Offset",       NULL},
171*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Address16.AddressLength),          "Address Length",           NULL},
172*efcc2a30SJung-uk Kim     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (Address16.ResourceSource),         NULL,                       NULL}
173*efcc2a30SJung-uk Kim };
174*efcc2a30SJung-uk Kim 
175*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpAddress32[8] =
176*efcc2a30SJung-uk Kim {
177*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpAddress32),         "32-Bit DWORD Address Space", NULL},
178*efcc2a30SJung-uk Kim     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
179*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.Granularity),            "Granularity",              NULL},
180*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.Minimum),                "Address Minimum",          NULL},
181*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.Maximum),                "Address Maximum",          NULL},
182*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.TranslationOffset),      "Translation Offset",       NULL},
183*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (Address32.AddressLength),          "Address Length",           NULL},
184*efcc2a30SJung-uk Kim     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (Address32.ResourceSource),         NULL,                       NULL}
185*efcc2a30SJung-uk Kim };
186*efcc2a30SJung-uk Kim 
187*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpAddress64[8] =
188*efcc2a30SJung-uk Kim {
189*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpAddress64),          "64-Bit QWORD Address Space", NULL},
190*efcc2a30SJung-uk Kim     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
191*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.Granularity),            "Granularity",              NULL},
192*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.Minimum),                "Address Minimum",          NULL},
193*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.Maximum),                "Address Maximum",          NULL},
194*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.TranslationOffset),      "Translation Offset",       NULL},
195*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (Address64.AddressLength),          "Address Length",           NULL},
196*efcc2a30SJung-uk Kim     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (Address64.ResourceSource),         NULL,                       NULL}
197*efcc2a30SJung-uk Kim };
198*efcc2a30SJung-uk Kim 
199*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpExtAddress64[8] =
200*efcc2a30SJung-uk Kim {
201*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpExtAddress64),       "64-Bit Extended Address Space", NULL},
202*efcc2a30SJung-uk Kim     {ACPI_RSD_ADDRESS,  0,                                                  NULL,                       NULL},
203*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.Granularity),         "Granularity",              NULL},
204*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.Minimum),             "Address Minimum",          NULL},
205*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.Maximum),             "Address Maximum",          NULL},
206*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.TranslationOffset),   "Translation Offset",       NULL},
207*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.AddressLength),       "Address Length",           NULL},
208*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (ExtAddress64.TypeSpecific),        "Type-Specific Attribute",  NULL}
209*efcc2a30SJung-uk Kim };
210*efcc2a30SJung-uk Kim 
211*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpExtIrq[8] =
212*efcc2a30SJung-uk Kim {
213*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpExtIrq),             "Extended IRQ",             NULL},
214*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.ProducerConsumer),     "Type",                     AcpiGbl_ConsumeDecode},
215*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.Triggering),           "Triggering",               AcpiGbl_HeDecode},
216*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.Polarity),             "Polarity",                 AcpiGbl_LlDecode},
217*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (ExtendedIrq.Sharable),             "Sharing",                  AcpiGbl_ShrDecode},
218*efcc2a30SJung-uk Kim     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (ExtendedIrq.ResourceSource),       NULL,                       NULL},
219*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (ExtendedIrq.InterruptCount),       "Interrupt Count",          NULL},
220*efcc2a30SJung-uk Kim     {ACPI_RSD_DWORDLIST,ACPI_RSD_OFFSET (ExtendedIrq.Interrupts[0]),        "Interrupt List",           NULL}
221*efcc2a30SJung-uk Kim };
222*efcc2a30SJung-uk Kim 
223*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpGenericReg[6] =
224*efcc2a30SJung-uk Kim {
225*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpGenericReg),         "Generic Register",         NULL},
226*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.SpaceId),               "Space ID",                 NULL},
227*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.BitWidth),              "Bit Width",                NULL},
228*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.BitOffset),             "Bit Offset",               NULL},
229*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (GenericReg.AccessSize),            "Access Size",              NULL},
230*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_RSD_OFFSET (GenericReg.Address),               "Address",                  NULL}
231*efcc2a30SJung-uk Kim };
232*efcc2a30SJung-uk Kim 
233*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpGpio[16] =
234*efcc2a30SJung-uk Kim {
235*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpGpio),               "GPIO",                     NULL},
236*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Gpio.RevisionId),                  "RevisionId",               NULL},
237*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Gpio.ConnectionType),              "ConnectionType",           AcpiGbl_CtDecode},
238*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Gpio.ProducerConsumer),            "ProducerConsumer",         AcpiGbl_ConsumeDecode},
239*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (Gpio.PinConfig),                   "PinConfig",                AcpiGbl_PpcDecode},
240*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Gpio.Sharable),                    "Sharing",                  AcpiGbl_ShrDecode},
241*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Gpio.IoRestriction),               "IoRestriction",            AcpiGbl_IorDecode},
242*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Gpio.Triggering),                  "Triggering",               AcpiGbl_HeDecode},
243*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Gpio.Polarity),                    "Polarity",                 AcpiGbl_LlDecode},
244*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Gpio.DriveStrength),               "DriveStrength",            NULL},
245*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Gpio.DebounceTimeout),             "DebounceTimeout",          NULL},
246*efcc2a30SJung-uk Kim     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (Gpio.ResourceSource),              "ResourceSource",           NULL},
247*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Gpio.PinTableLength),              "PinTableLength",           NULL},
248*efcc2a30SJung-uk Kim     {ACPI_RSD_WORDLIST, ACPI_RSD_OFFSET (Gpio.PinTable),                    "PinTable",                 NULL},
249*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (Gpio.VendorLength),                "VendorLength",             NULL},
250*efcc2a30SJung-uk Kim     {ACPI_RSD_SHORTLISTX,ACPI_RSD_OFFSET (Gpio.VendorData),                 "VendorData",               NULL},
251*efcc2a30SJung-uk Kim };
252*efcc2a30SJung-uk Kim 
253*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpFixedDma[4] =
254*efcc2a30SJung-uk Kim {
255*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpFixedDma),           "FixedDma",                 NULL},
256*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (FixedDma.RequestLines),            "RequestLines",             NULL},
257*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (FixedDma.Channels),                "Channels",                 NULL},
258*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (FixedDma.Width),                   "TransferWidth",            AcpiGbl_DtsDecode},
259*efcc2a30SJung-uk Kim };
260*efcc2a30SJung-uk Kim 
261*efcc2a30SJung-uk Kim #define ACPI_RS_DUMP_COMMON_SERIAL_BUS \
262*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (CommonSerialBus.RevisionId),       "RevisionId",               NULL}, \
263*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (CommonSerialBus.Type),             "Type",                     AcpiGbl_SbtDecode}, \
264*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (CommonSerialBus.ProducerConsumer), "ProducerConsumer",         AcpiGbl_ConsumeDecode}, \
265*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (CommonSerialBus.SlaveMode),        "SlaveMode",                AcpiGbl_SmDecode}, \
266*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (CommonSerialBus.TypeRevisionId),   "TypeRevisionId",           NULL}, \
267*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (CommonSerialBus.TypeDataLength),   "TypeDataLength",           NULL}, \
268*efcc2a30SJung-uk Kim     {ACPI_RSD_SOURCE,   ACPI_RSD_OFFSET (CommonSerialBus.ResourceSource),   "ResourceSource",           NULL}, \
269*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (CommonSerialBus.VendorLength),     "VendorLength",             NULL}, \
270*efcc2a30SJung-uk Kim     {ACPI_RSD_SHORTLISTX,ACPI_RSD_OFFSET (CommonSerialBus.VendorData),      "VendorData",               NULL},
271*efcc2a30SJung-uk Kim 
272*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpCommonSerialBus[10] =
273*efcc2a30SJung-uk Kim {
274*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpCommonSerialBus),    "Common Serial Bus",        NULL},
275*efcc2a30SJung-uk Kim     ACPI_RS_DUMP_COMMON_SERIAL_BUS
276*efcc2a30SJung-uk Kim };
277*efcc2a30SJung-uk Kim 
278*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpI2cSerialBus[13] =
279*efcc2a30SJung-uk Kim {
280*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpI2cSerialBus),       "I2C Serial Bus",           NULL},
281*efcc2a30SJung-uk Kim     ACPI_RS_DUMP_COMMON_SERIAL_BUS
282*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (I2cSerialBus.AccessMode),          "AccessMode",               AcpiGbl_AmDecode},
283*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (I2cSerialBus.ConnectionSpeed),     "ConnectionSpeed",          NULL},
284*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (I2cSerialBus.SlaveAddress),        "SlaveAddress",             NULL},
285*efcc2a30SJung-uk Kim };
286*efcc2a30SJung-uk Kim 
287*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpSpiSerialBus[17] =
288*efcc2a30SJung-uk Kim {
289*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpSpiSerialBus),       "Spi Serial Bus",           NULL},
290*efcc2a30SJung-uk Kim     ACPI_RS_DUMP_COMMON_SERIAL_BUS
291*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (SpiSerialBus.WireMode),            "WireMode",                 AcpiGbl_WmDecode},
292*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (SpiSerialBus.DevicePolarity),      "DevicePolarity",           AcpiGbl_DpDecode},
293*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (SpiSerialBus.DataBitLength),       "DataBitLength",            NULL},
294*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (SpiSerialBus.ClockPhase),          "ClockPhase",               AcpiGbl_CphDecode},
295*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (SpiSerialBus.ClockPolarity),       "ClockPolarity",            AcpiGbl_CpoDecode},
296*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (SpiSerialBus.DeviceSelection),     "DeviceSelection",          NULL},
297*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (SpiSerialBus.ConnectionSpeed),     "ConnectionSpeed",          NULL},
298*efcc2a30SJung-uk Kim };
299*efcc2a30SJung-uk Kim 
300*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpUartSerialBus[19] =
301*efcc2a30SJung-uk Kim {
302*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpUartSerialBus),       "Uart Serial Bus",         NULL},
303*efcc2a30SJung-uk Kim     ACPI_RS_DUMP_COMMON_SERIAL_BUS
304*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (UartSerialBus.FlowControl),         "FlowControl",             AcpiGbl_FcDecode},
305*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (UartSerialBus.StopBits),            "StopBits",                AcpiGbl_SbDecode},
306*efcc2a30SJung-uk Kim     {ACPI_RSD_3BITFLAG, ACPI_RSD_OFFSET (UartSerialBus.DataBits),            "DataBits",                AcpiGbl_BpbDecode},
307*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (UartSerialBus.Endian),              "Endian",                  AcpiGbl_EdDecode},
308*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (UartSerialBus.Parity),              "Parity",                  AcpiGbl_PtDecode},
309*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT8,    ACPI_RSD_OFFSET (UartSerialBus.LinesEnabled),        "LinesEnabled",            NULL},
310*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (UartSerialBus.RxFifoSize),          "RxFifoSize",              NULL},
311*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT16,   ACPI_RSD_OFFSET (UartSerialBus.TxFifoSize),          "TxFifoSize",              NULL},
312*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_RSD_OFFSET (UartSerialBus.DefaultBaudRate),     "ConnectionSpeed",         NULL},
313*efcc2a30SJung-uk Kim };
314*efcc2a30SJung-uk Kim 
315*efcc2a30SJung-uk Kim /*
316*efcc2a30SJung-uk Kim  * Tables used for common address descriptor flag fields
317*efcc2a30SJung-uk Kim  */
318*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpGeneralFlags[5] =
319*efcc2a30SJung-uk Kim {
320*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpGeneralFlags),       NULL,                       NULL},
321*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.ProducerConsumer),         "Consumer/Producer",        AcpiGbl_ConsumeDecode},
322*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Decode),                   "Address Decode",           AcpiGbl_DecDecode},
323*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.MinAddressFixed),          "Min Relocatability",       AcpiGbl_MinDecode},
324*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.MaxAddressFixed),          "Max Relocatability",       AcpiGbl_MaxDecode}
325*efcc2a30SJung-uk Kim };
326*efcc2a30SJung-uk Kim 
327*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpMemoryFlags[5] =
328*efcc2a30SJung-uk Kim {
329*efcc2a30SJung-uk Kim     {ACPI_RSD_LITERAL,  ACPI_RSD_TABLE_SIZE (AcpiRsDumpMemoryFlags),        "Resource Type",            (void *) "Memory Range"},
330*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.WriteProtect),    "Write Protect",            AcpiGbl_RwDecode},
331*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.Caching),         "Caching",                  AcpiGbl_MemDecode},
332*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.RangeType),       "Range Type",               AcpiGbl_MtpDecode},
333*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Mem.Translation),     "Translation",              AcpiGbl_TtpDecode}
334*efcc2a30SJung-uk Kim };
335*efcc2a30SJung-uk Kim 
336*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpIoFlags[4] =
337*efcc2a30SJung-uk Kim {
338*efcc2a30SJung-uk Kim     {ACPI_RSD_LITERAL,  ACPI_RSD_TABLE_SIZE (AcpiRsDumpIoFlags),            "Resource Type",            (void *) "I/O Range"},
339*efcc2a30SJung-uk Kim     {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET (Address.Info.Io.RangeType),        "Range Type",               AcpiGbl_RngDecode},
340*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Io.Translation),      "Translation",              AcpiGbl_TtpDecode},
341*efcc2a30SJung-uk Kim     {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (Address.Info.Io.TranslationType),  "Translation Type",         AcpiGbl_TrsDecode}
342*efcc2a30SJung-uk Kim };
343*efcc2a30SJung-uk Kim 
344*efcc2a30SJung-uk Kim 
345*efcc2a30SJung-uk Kim /*
346*efcc2a30SJung-uk Kim  * Table used to dump _PRT contents
347*efcc2a30SJung-uk Kim  */
348*efcc2a30SJung-uk Kim ACPI_RSDUMP_INFO        AcpiRsDumpPrt[5] =
349*efcc2a30SJung-uk Kim {
350*efcc2a30SJung-uk Kim     {ACPI_RSD_TITLE,    ACPI_RSD_TABLE_SIZE (AcpiRsDumpPrt),                NULL,                       NULL},
351*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT64,   ACPI_PRT_OFFSET (Address),                          "Address",                  NULL},
352*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_PRT_OFFSET (Pin),                              "Pin",                      NULL},
353*efcc2a30SJung-uk Kim     {ACPI_RSD_STRING,   ACPI_PRT_OFFSET (Source[0]),                        "Source",                   NULL},
354*efcc2a30SJung-uk Kim     {ACPI_RSD_UINT32,   ACPI_PRT_OFFSET (SourceIndex),                      "Source Index",             NULL}
355*efcc2a30SJung-uk Kim };
356*efcc2a30SJung-uk Kim 
357*efcc2a30SJung-uk Kim #endif
358