OSDN Git Service

klibc基本機能実装. ACPICAの準備
[vaneos/DivergeMirror.git] / drivers / acpi / components / disassembler / dmresrcs.c
1 /*******************************************************************************
2  *
3  * Module Name: dmresrcs.c - "Small" Resource Descriptor disassembly
4  *
5  ******************************************************************************/
6
7 /******************************************************************************
8  *
9  * 1. Copyright Notice
10  *
11  * Some or all of this work - Copyright (c) 1999 - 2015, Intel Corp.
12  * All rights reserved.
13  *
14  * 2. License
15  *
16  * 2.1. This is your license from Intel Corp. under its intellectual property
17  * rights. You may have additional license terms from the party that provided
18  * you this software, covering your right to use that party's intellectual
19  * property rights.
20  *
21  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
22  * copy of the source code appearing in this file ("Covered Code") an
23  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
24  * base code distributed originally by Intel ("Original Intel Code") to copy,
25  * make derivatives, distribute, use and display any portion of the Covered
26  * Code in any form, with the right to sublicense such rights; and
27  *
28  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
29  * license (with the right to sublicense), under only those claims of Intel
30  * patents that are infringed by the Original Intel Code, to make, use, sell,
31  * offer to sell, and import the Covered Code and derivative works thereof
32  * solely to the minimum extent necessary to exercise the above copyright
33  * license, and in no event shall the patent license extend to any additions
34  * to or modifications of the Original Intel Code. No other license or right
35  * is granted directly or by implication, estoppel or otherwise;
36  *
37  * The above copyright and patent license is granted only if the following
38  * conditions are met:
39  *
40  * 3. Conditions
41  *
42  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
43  * Redistribution of source code of any substantial portion of the Covered
44  * Code or modification with rights to further distribute source must include
45  * the above Copyright Notice, the above License, this list of Conditions,
46  * and the following Disclaimer and Export Compliance provision. In addition,
47  * Licensee must cause all Covered Code to which Licensee contributes to
48  * contain a file documenting the changes Licensee made to create that Covered
49  * Code and the date of any change. Licensee must include in that file the
50  * documentation of any changes made by any predecessor Licensee. Licensee
51  * must include a prominent statement that the modification is derived,
52  * directly or indirectly, from Original Intel Code.
53  *
54  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
55  * Redistribution of source code of any substantial portion of the Covered
56  * Code or modification without rights to further distribute source must
57  * include the following Disclaimer and Export Compliance provision in the
58  * documentation and/or other materials provided with distribution. In
59  * addition, Licensee may not authorize further sublicense of source of any
60  * portion of the Covered Code, and must include terms to the effect that the
61  * license from Licensee to its licensee is limited to the intellectual
62  * property embodied in the software Licensee provides to its licensee, and
63  * not to intellectual property embodied in modifications its licensee may
64  * make.
65  *
66  * 3.3. Redistribution of Executable. Redistribution in executable form of any
67  * substantial portion of the Covered Code or modification must reproduce the
68  * above Copyright Notice, and the following Disclaimer and Export Compliance
69  * provision in the documentation and/or other materials provided with the
70  * distribution.
71  *
72  * 3.4. Intel retains all right, title, and interest in and to the Original
73  * Intel Code.
74  *
75  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
76  * Intel shall be used in advertising or otherwise to promote the sale, use or
77  * other dealings in products derived from or relating to the Covered Code
78  * without prior written authorization from Intel.
79  *
80  * 4. Disclaimer and Export Compliance
81  *
82  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
83  * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
84  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
85  * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
86  * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
87  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
88  * PARTICULAR PURPOSE.
89  *
90  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
91  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
92  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
93  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
94  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
95  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
96  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
97  * LIMITED REMEDY.
98  *
99  * 4.3. Licensee shall not export, either directly or indirectly, any of this
100  * software or system incorporating such software without first obtaining any
101  * required license or other approval from the U. S. Department of Commerce or
102  * any other agency or department of the United States Government. In the
103  * event Licensee exports any such software from the United States or
104  * re-exports any such software from a foreign destination, Licensee shall
105  * ensure that the distribution and export/re-export of the software is in
106  * compliance with all laws, regulations, orders, or other restrictions of the
107  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
108  * any of its subsidiaries will export/re-export any technical data, process,
109  * software, or service, directly or indirectly, to any country for which the
110  * United States government or any agency thereof requires an export license,
111  * other governmental approval, or letter of assurance, without first obtaining
112  * such license, approval or letter.
113  *
114  *****************************************************************************/
115
116 #include "acpi.h"
117 #include "accommon.h"
118 #include "acdisasm.h"
119
120
121 #ifdef ACPI_DISASSEMBLER
122
123 #define _COMPONENT          ACPI_CA_DEBUGGER
124         ACPI_MODULE_NAME    ("dbresrcs")
125
126
127 /*******************************************************************************
128  *
129  * FUNCTION:    AcpiDmIrqDescriptor
130  *
131  * PARAMETERS:  Info                - Extra resource info
132  *              Resource            - Pointer to the resource descriptor
133  *              Length              - Length of the descriptor in bytes
134  *              Level               - Current source code indentation level
135  *
136  * RETURN:      None
137  *
138  * DESCRIPTION: Decode a IRQ descriptor, either Irq() or IrqNoFlags()
139  *
140  ******************************************************************************/
141
142 void
143 AcpiDmIrqDescriptor (
144     ACPI_OP_WALK_INFO       *Info,
145     AML_RESOURCE            *Resource,
146     UINT32                  Length,
147     UINT32                  Level)
148 {
149
150     AcpiDmIndent (Level);
151     AcpiOsPrintf ("%s (",
152         AcpiGbl_IrqDecode [ACPI_GET_1BIT_FLAG (Length)]);
153
154     /* Decode flags byte if present */
155
156     if (Length & 1)
157     {
158         AcpiOsPrintf ("%s, %s, %s, ",
159             AcpiGbl_HeDecode [ACPI_GET_1BIT_FLAG (Resource->Irq.Flags)],
160             AcpiGbl_LlDecode [ACPI_EXTRACT_1BIT_FLAG (Resource->Irq.Flags, 3)],
161             AcpiGbl_ShrDecode [ACPI_EXTRACT_2BIT_FLAG (Resource->Irq.Flags, 4)]);
162     }
163
164     /* Insert a descriptor name */
165
166     AcpiDmDescriptorName ();
167     AcpiOsPrintf (")\n");
168
169     AcpiDmIndent (Level + 1);
170     AcpiDmBitList (Resource->Irq.IrqMask);
171 }
172
173
174 /*******************************************************************************
175  *
176  * FUNCTION:    AcpiDmDmaDescriptor
177  *
178  * PARAMETERS:  Info                - Extra resource info
179  *              Resource            - Pointer to the resource descriptor
180  *              Length              - Length of the descriptor in bytes
181  *              Level               - Current source code indentation level
182  *
183  * RETURN:      None
184  *
185  * DESCRIPTION: Decode a DMA descriptor
186  *
187  ******************************************************************************/
188
189 void
190 AcpiDmDmaDescriptor (
191     ACPI_OP_WALK_INFO       *Info,
192     AML_RESOURCE            *Resource,
193     UINT32                  Length,
194     UINT32                  Level)
195 {
196
197     AcpiDmIndent (Level);
198     AcpiOsPrintf ("DMA (%s, %s, %s, ",
199         AcpiGbl_TypDecode [ACPI_EXTRACT_2BIT_FLAG (Resource->Dma.Flags, 5)],
200         AcpiGbl_BmDecode  [ACPI_EXTRACT_1BIT_FLAG (Resource->Dma.Flags, 2)],
201         AcpiGbl_SizDecode [ACPI_GET_2BIT_FLAG (Resource->Dma.Flags)]);
202
203     /* Insert a descriptor name */
204
205     AcpiDmDescriptorName ();
206     AcpiOsPrintf (")\n");
207
208     AcpiDmIndent (Level + 1);
209     AcpiDmBitList (Resource->Dma.DmaChannelMask);
210 }
211
212
213 /*******************************************************************************
214  *
215  * FUNCTION:    AcpiDmFixedDmaDescriptor
216  *
217  * PARAMETERS:  Info                - Extra resource info
218  *              Resource            - Pointer to the resource descriptor
219  *              Length              - Length of the descriptor in bytes
220  *              Level               - Current source code indentation level
221  *
222  * RETURN:      None
223  *
224  * DESCRIPTION: Decode a FixedDMA descriptor
225  *
226  ******************************************************************************/
227
228 void
229 AcpiDmFixedDmaDescriptor (
230     ACPI_OP_WALK_INFO       *Info,
231     AML_RESOURCE            *Resource,
232     UINT32                  Length,
233     UINT32                  Level)
234 {
235
236     AcpiDmIndent (Level);
237     AcpiOsPrintf ("FixedDMA (0x%4.4X, 0x%4.4X, ",
238         Resource->FixedDma.RequestLines,
239         Resource->FixedDma.Channels);
240
241     if (Resource->FixedDma.Width <= 5)
242     {
243         AcpiOsPrintf ("%s, ",
244             AcpiGbl_DtsDecode [Resource->FixedDma.Width]);
245     }
246     else
247     {
248         AcpiOsPrintf ("%X /* INVALID DMA WIDTH */, ", Resource->FixedDma.Width);
249     }
250
251     /* Insert a descriptor name */
252
253     AcpiDmDescriptorName ();
254     AcpiOsPrintf (")\n");
255 }
256
257
258 /*******************************************************************************
259  *
260  * FUNCTION:    AcpiDmIoDescriptor
261  *
262  * PARAMETERS:  Info                - Extra resource info
263  *              Resource            - Pointer to the resource descriptor
264  *              Length              - Length of the descriptor in bytes
265  *              Level               - Current source code indentation level
266  *
267  * RETURN:      None
268  *
269  * DESCRIPTION: Decode an IO descriptor
270  *
271  ******************************************************************************/
272
273 void
274 AcpiDmIoDescriptor (
275     ACPI_OP_WALK_INFO       *Info,
276     AML_RESOURCE            *Resource,
277     UINT32                  Length,
278     UINT32                  Level)
279 {
280
281     AcpiDmIndent (Level);
282     AcpiOsPrintf ("IO (%s,\n",
283         AcpiGbl_IoDecode [ACPI_GET_1BIT_FLAG (Resource->Io.Flags)]);
284
285     AcpiDmIndent (Level + 1);
286     AcpiDmDumpInteger16 (Resource->Io.Minimum, "Range Minimum");
287
288     AcpiDmIndent (Level + 1);
289     AcpiDmDumpInteger16 (Resource->Io.Maximum, "Range Maximum");
290
291     AcpiDmIndent (Level + 1);
292     AcpiDmDumpInteger8 (Resource->Io.Alignment, "Alignment");
293
294     AcpiDmIndent (Level + 1);
295     AcpiDmDumpInteger8 (Resource->Io.AddressLength, "Length");
296
297     /* Insert a descriptor name */
298
299     AcpiDmIndent (Level + 1);
300     AcpiDmDescriptorName ();
301     AcpiOsPrintf (")\n");
302 }
303
304
305 /*******************************************************************************
306  *
307  * FUNCTION:    AcpiDmFixedIoDescriptor
308  *
309  * PARAMETERS:  Info                - Extra resource info
310  *              Resource            - Pointer to the resource descriptor
311  *              Length              - Length of the descriptor in bytes
312  *              Level               - Current source code indentation level
313  *
314  * RETURN:      None
315  *
316  * DESCRIPTION: Decode a Fixed IO descriptor
317  *
318  ******************************************************************************/
319
320 void
321 AcpiDmFixedIoDescriptor (
322     ACPI_OP_WALK_INFO       *Info,
323     AML_RESOURCE            *Resource,
324     UINT32                  Length,
325     UINT32                  Level)
326 {
327
328     AcpiDmIndent (Level);
329     AcpiOsPrintf ("FixedIO (\n");
330
331     AcpiDmIndent (Level + 1);
332     AcpiDmDumpInteger16 (Resource->FixedIo.Address, "Address");
333
334     AcpiDmIndent (Level + 1);
335     AcpiDmDumpInteger8 (Resource->FixedIo.AddressLength, "Length");
336
337     /* Insert a descriptor name */
338
339     AcpiDmIndent (Level + 1);
340     AcpiDmDescriptorName ();
341     AcpiOsPrintf (")\n");
342 }
343
344
345 /*******************************************************************************
346  *
347  * FUNCTION:    AcpiDmStartDependentDescriptor
348  *
349  * PARAMETERS:  Info                - Extra resource info
350  *              Resource            - Pointer to the resource descriptor
351  *              Length              - Length of the descriptor in bytes
352  *              Level               - Current source code indentation level
353  *
354  * RETURN:      None
355  *
356  * DESCRIPTION: Decode a Start Dependendent functions descriptor
357  *
358  ******************************************************************************/
359
360 void
361 AcpiDmStartDependentDescriptor (
362     ACPI_OP_WALK_INFO       *Info,
363     AML_RESOURCE            *Resource,
364     UINT32                  Length,
365     UINT32                  Level)
366 {
367
368     AcpiDmIndent (Level);
369
370     if (Length & 1)
371     {
372         AcpiOsPrintf ("StartDependentFn (0x%2.2X, 0x%2.2X)\n",
373             (UINT32) ACPI_GET_2BIT_FLAG (Resource->StartDpf.Flags),
374             (UINT32) ACPI_EXTRACT_2BIT_FLAG (Resource->StartDpf.Flags, 2));
375     }
376     else
377     {
378         AcpiOsPrintf ("StartDependentFnNoPri ()\n");
379     }
380
381     AcpiDmIndent (Level);
382     AcpiOsPrintf ("{\n");
383 }
384
385
386 /*******************************************************************************
387  *
388  * FUNCTION:    AcpiDmEndDependentDescriptor
389  *
390  * PARAMETERS:  Info                - Extra resource info
391  *              Resource            - Pointer to the resource descriptor
392  *              Length              - Length of the descriptor in bytes
393  *              Level               - Current source code indentation level
394  *
395  * RETURN:      None
396  *
397  * DESCRIPTION: Decode an End Dependent functions descriptor
398  *
399  ******************************************************************************/
400
401 void
402 AcpiDmEndDependentDescriptor (
403     ACPI_OP_WALK_INFO       *Info,
404     AML_RESOURCE            *Resource,
405     UINT32                  Length,
406     UINT32                  Level)
407 {
408
409     AcpiDmIndent (Level);
410     AcpiOsPrintf ("}\n");
411     AcpiDmIndent (Level);
412     AcpiOsPrintf ("EndDependentFn ()\n");
413 }
414
415
416 /*******************************************************************************
417  *
418  * FUNCTION:    AcpiDmVendorSmallDescriptor
419  *
420  * PARAMETERS:  Info                - Extra resource info
421  *              Resource            - Pointer to the resource descriptor
422  *              Length              - Length of the descriptor in bytes
423  *              Level               - Current source code indentation level
424  *
425  * RETURN:      None
426  *
427  * DESCRIPTION: Decode a Vendor Small Descriptor
428  *
429  ******************************************************************************/
430
431 void
432 AcpiDmVendorSmallDescriptor (
433     ACPI_OP_WALK_INFO       *Info,
434     AML_RESOURCE            *Resource,
435     UINT32                  Length,
436     UINT32                  Level)
437 {
438
439     AcpiDmVendorCommon ("Short",
440         ACPI_ADD_PTR (UINT8, Resource, sizeof (AML_RESOURCE_SMALL_HEADER)),
441         Length, Level);
442 }
443
444 #endif