rsdump.c revision 1.8 1 1.1 jruoho /*******************************************************************************
2 1.1 jruoho *
3 1.6 christos * Module Name: rsdump - AML debugger support for resource structures.
4 1.1 jruoho *
5 1.1 jruoho ******************************************************************************/
6 1.1 jruoho
7 1.3 jruoho /*
8 1.7 christos * Copyright (C) 2000 - 2016, Intel Corp.
9 1.1 jruoho * All rights reserved.
10 1.1 jruoho *
11 1.3 jruoho * Redistribution and use in source and binary forms, with or without
12 1.3 jruoho * modification, are permitted provided that the following conditions
13 1.3 jruoho * are met:
14 1.3 jruoho * 1. Redistributions of source code must retain the above copyright
15 1.3 jruoho * notice, this list of conditions, and the following disclaimer,
16 1.3 jruoho * without modification.
17 1.3 jruoho * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18 1.3 jruoho * substantially similar to the "NO WARRANTY" disclaimer below
19 1.3 jruoho * ("Disclaimer") and any redistribution must be conditioned upon
20 1.3 jruoho * including a substantially similar Disclaimer requirement for further
21 1.3 jruoho * binary redistribution.
22 1.3 jruoho * 3. Neither the names of the above-listed copyright holders nor the names
23 1.3 jruoho * of any contributors may be used to endorse or promote products derived
24 1.3 jruoho * from this software without specific prior written permission.
25 1.3 jruoho *
26 1.3 jruoho * Alternatively, this software may be distributed under the terms of the
27 1.3 jruoho * GNU General Public License ("GPL") version 2 as published by the Free
28 1.3 jruoho * Software Foundation.
29 1.3 jruoho *
30 1.3 jruoho * NO WARRANTY
31 1.3 jruoho * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32 1.3 jruoho * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33 1.3 jruoho * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34 1.3 jruoho * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35 1.3 jruoho * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 1.3 jruoho * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37 1.3 jruoho * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38 1.3 jruoho * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39 1.3 jruoho * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40 1.3 jruoho * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41 1.3 jruoho * POSSIBILITY OF SUCH DAMAGES.
42 1.3 jruoho */
43 1.1 jruoho
44 1.1 jruoho #include "acpi.h"
45 1.1 jruoho #include "accommon.h"
46 1.1 jruoho #include "acresrc.h"
47 1.1 jruoho
48 1.1 jruoho #define _COMPONENT ACPI_RESOURCES
49 1.1 jruoho ACPI_MODULE_NAME ("rsdump")
50 1.1 jruoho
51 1.6 christos /*
52 1.6 christos * All functions in this module are used by the AML Debugger only
53 1.6 christos */
54 1.1 jruoho
55 1.1 jruoho /* Local prototypes */
56 1.1 jruoho
57 1.1 jruoho static void
58 1.1 jruoho AcpiRsOutString (
59 1.2 jruoho const char *Title,
60 1.2 jruoho const char *Value);
61 1.1 jruoho
62 1.1 jruoho static void
63 1.1 jruoho AcpiRsOutInteger8 (
64 1.2 jruoho const char *Title,
65 1.1 jruoho UINT8 Value);
66 1.1 jruoho
67 1.1 jruoho static void
68 1.1 jruoho AcpiRsOutInteger16 (
69 1.2 jruoho const char *Title,
70 1.1 jruoho UINT16 Value);
71 1.1 jruoho
72 1.1 jruoho static void
73 1.1 jruoho AcpiRsOutInteger32 (
74 1.2 jruoho const char *Title,
75 1.1 jruoho UINT32 Value);
76 1.1 jruoho
77 1.1 jruoho static void
78 1.1 jruoho AcpiRsOutInteger64 (
79 1.2 jruoho const char *Title,
80 1.1 jruoho UINT64 Value);
81 1.1 jruoho
82 1.1 jruoho static void
83 1.1 jruoho AcpiRsOutTitle (
84 1.2 jruoho const char *Title);
85 1.1 jruoho
86 1.1 jruoho static void
87 1.1 jruoho AcpiRsDumpByteList (
88 1.1 jruoho UINT16 Length,
89 1.1 jruoho UINT8 *Data);
90 1.1 jruoho
91 1.1 jruoho static void
92 1.4 christos AcpiRsDumpWordList (
93 1.6 christos UINT16 Length,
94 1.6 christos UINT16 *Data);
95 1.4 christos
96 1.4 christos static void
97 1.1 jruoho AcpiRsDumpDwordList (
98 1.1 jruoho UINT8 Length,
99 1.1 jruoho UINT32 *Data);
100 1.1 jruoho
101 1.1 jruoho static void
102 1.1 jruoho AcpiRsDumpShortByteList (
103 1.6 christos UINT8 Length,
104 1.6 christos UINT8 *Data);
105 1.1 jruoho
106 1.1 jruoho static void
107 1.1 jruoho AcpiRsDumpResourceSource (
108 1.1 jruoho ACPI_RESOURCE_SOURCE *ResourceSource);
109 1.1 jruoho
110 1.1 jruoho static void
111 1.1 jruoho AcpiRsDumpAddressCommon (
112 1.1 jruoho ACPI_RESOURCE_DATA *Resource);
113 1.1 jruoho
114 1.1 jruoho static void
115 1.1 jruoho AcpiRsDumpDescriptor (
116 1.1 jruoho void *Resource,
117 1.6 christos ACPI_RSDUMP_INFO *Table);
118 1.6 christos
119 1.6 christos
120 1.6 christos /*******************************************************************************
121 1.6 christos *
122 1.6 christos * FUNCTION: AcpiRsDumpResourceList
123 1.6 christos *
124 1.6 christos * PARAMETERS: ResourceList - Pointer to a resource descriptor list
125 1.6 christos *
126 1.6 christos * RETURN: None
127 1.6 christos *
128 1.6 christos * DESCRIPTION: Dispatches the structure to the correct dump routine.
129 1.6 christos *
130 1.6 christos ******************************************************************************/
131 1.6 christos
132 1.6 christos void
133 1.6 christos AcpiRsDumpResourceList (
134 1.6 christos ACPI_RESOURCE *ResourceList)
135 1.6 christos {
136 1.6 christos UINT32 Count = 0;
137 1.6 christos UINT32 Type;
138 1.6 christos
139 1.6 christos
140 1.6 christos ACPI_FUNCTION_ENTRY ();
141 1.6 christos
142 1.6 christos
143 1.6 christos /* Check if debug output enabled */
144 1.6 christos
145 1.6 christos if (!ACPI_IS_DEBUG_ENABLED (ACPI_LV_RESOURCES, _COMPONENT))
146 1.6 christos {
147 1.6 christos return;
148 1.6 christos }
149 1.6 christos
150 1.6 christos /* Walk list and dump all resource descriptors (END_TAG terminates) */
151 1.6 christos
152 1.6 christos do
153 1.6 christos {
154 1.6 christos AcpiOsPrintf ("\n[%02X] ", Count);
155 1.6 christos Count++;
156 1.6 christos
157 1.6 christos /* Validate Type before dispatch */
158 1.6 christos
159 1.6 christos Type = ResourceList->Type;
160 1.6 christos if (Type > ACPI_RESOURCE_TYPE_MAX)
161 1.6 christos {
162 1.6 christos AcpiOsPrintf (
163 1.6 christos "Invalid descriptor type (%X) in resource list\n",
164 1.6 christos ResourceList->Type);
165 1.6 christos return;
166 1.6 christos }
167 1.6 christos
168 1.6 christos /* Sanity check the length. It must not be zero, or we loop forever */
169 1.6 christos
170 1.6 christos if (!ResourceList->Length)
171 1.6 christos {
172 1.6 christos AcpiOsPrintf (
173 1.6 christos "Invalid zero length descriptor in resource list\n");
174 1.6 christos return;
175 1.6 christos }
176 1.6 christos
177 1.6 christos /* Dump the resource descriptor */
178 1.6 christos
179 1.6 christos if (Type == ACPI_RESOURCE_TYPE_SERIAL_BUS)
180 1.6 christos {
181 1.6 christos AcpiRsDumpDescriptor (&ResourceList->Data,
182 1.6 christos AcpiGbl_DumpSerialBusDispatch[
183 1.6 christos ResourceList->Data.CommonSerialBus.Type]);
184 1.6 christos }
185 1.6 christos else
186 1.6 christos {
187 1.6 christos AcpiRsDumpDescriptor (&ResourceList->Data,
188 1.6 christos AcpiGbl_DumpResourceDispatch[Type]);
189 1.6 christos }
190 1.6 christos
191 1.6 christos /* Point to the next resource structure */
192 1.6 christos
193 1.6 christos ResourceList = ACPI_NEXT_RESOURCE (ResourceList);
194 1.6 christos
195 1.6 christos /* Exit when END_TAG descriptor is reached */
196 1.6 christos
197 1.6 christos } while (Type != ACPI_RESOURCE_TYPE_END_TAG);
198 1.6 christos }
199 1.6 christos
200 1.6 christos
201 1.6 christos /*******************************************************************************
202 1.6 christos *
203 1.6 christos * FUNCTION: AcpiRsDumpIrqList
204 1.6 christos *
205 1.6 christos * PARAMETERS: RouteTable - Pointer to the routing table to dump.
206 1.6 christos *
207 1.6 christos * RETURN: None
208 1.6 christos *
209 1.6 christos * DESCRIPTION: Print IRQ routing table
210 1.6 christos *
211 1.6 christos ******************************************************************************/
212 1.6 christos
213 1.6 christos void
214 1.6 christos AcpiRsDumpIrqList (
215 1.6 christos UINT8 *RouteTable)
216 1.6 christos {
217 1.6 christos ACPI_PCI_ROUTING_TABLE *PrtElement;
218 1.6 christos UINT8 Count;
219 1.6 christos
220 1.6 christos
221 1.6 christos ACPI_FUNCTION_ENTRY ();
222 1.6 christos
223 1.6 christos
224 1.6 christos /* Check if debug output enabled */
225 1.6 christos
226 1.6 christos if (!ACPI_IS_DEBUG_ENABLED (ACPI_LV_RESOURCES, _COMPONENT))
227 1.6 christos {
228 1.6 christos return;
229 1.6 christos }
230 1.6 christos
231 1.6 christos PrtElement = ACPI_CAST_PTR (ACPI_PCI_ROUTING_TABLE, RouteTable);
232 1.6 christos
233 1.6 christos /* Dump all table elements, Exit on zero length element */
234 1.6 christos
235 1.6 christos for (Count = 0; PrtElement->Length; Count++)
236 1.6 christos {
237 1.6 christos AcpiOsPrintf ("\n[%02X] PCI IRQ Routing Table Package\n", Count);
238 1.6 christos AcpiRsDumpDescriptor (PrtElement, AcpiRsDumpPrt);
239 1.6 christos
240 1.6 christos PrtElement = ACPI_ADD_PTR (ACPI_PCI_ROUTING_TABLE,
241 1.6 christos PrtElement, PrtElement->Length);
242 1.6 christos }
243 1.6 christos }
244 1.1 jruoho
245 1.1 jruoho
246 1.1 jruoho /*******************************************************************************
247 1.1 jruoho *
248 1.1 jruoho * FUNCTION: AcpiRsDumpDescriptor
249 1.1 jruoho *
250 1.4 christos * PARAMETERS: Resource - Buffer containing the resource
251 1.4 christos * Table - Table entry to decode the resource
252 1.1 jruoho *
253 1.1 jruoho * RETURN: None
254 1.1 jruoho *
255 1.4 christos * DESCRIPTION: Dump a resource descriptor based on a dump table entry.
256 1.1 jruoho *
257 1.1 jruoho ******************************************************************************/
258 1.1 jruoho
259 1.1 jruoho static void
260 1.1 jruoho AcpiRsDumpDescriptor (
261 1.1 jruoho void *Resource,
262 1.1 jruoho ACPI_RSDUMP_INFO *Table)
263 1.1 jruoho {
264 1.1 jruoho UINT8 *Target = NULL;
265 1.1 jruoho UINT8 *PreviousTarget;
266 1.2 jruoho const char *Name;
267 1.8 christos UINT8 Count;
268 1.1 jruoho
269 1.1 jruoho
270 1.1 jruoho /* First table entry must contain the table length (# of table entries) */
271 1.1 jruoho
272 1.1 jruoho Count = Table->Offset;
273 1.1 jruoho
274 1.1 jruoho while (Count)
275 1.1 jruoho {
276 1.1 jruoho PreviousTarget = Target;
277 1.1 jruoho Target = ACPI_ADD_PTR (UINT8, Resource, Table->Offset);
278 1.1 jruoho Name = Table->Name;
279 1.1 jruoho
280 1.1 jruoho switch (Table->Opcode)
281 1.1 jruoho {
282 1.1 jruoho case ACPI_RSD_TITLE:
283 1.1 jruoho /*
284 1.1 jruoho * Optional resource title
285 1.1 jruoho */
286 1.1 jruoho if (Table->Name)
287 1.1 jruoho {
288 1.1 jruoho AcpiOsPrintf ("%s Resource\n", Name);
289 1.1 jruoho }
290 1.1 jruoho break;
291 1.1 jruoho
292 1.1 jruoho /* Strings */
293 1.1 jruoho
294 1.1 jruoho case ACPI_RSD_LITERAL:
295 1.4 christos
296 1.1 jruoho AcpiRsOutString (Name, ACPI_CAST_PTR (char, Table->Pointer));
297 1.1 jruoho break;
298 1.1 jruoho
299 1.1 jruoho case ACPI_RSD_STRING:
300 1.4 christos
301 1.1 jruoho AcpiRsOutString (Name, ACPI_CAST_PTR (char, Target));
302 1.1 jruoho break;
303 1.1 jruoho
304 1.1 jruoho /* Data items, 8/16/32/64 bit */
305 1.1 jruoho
306 1.1 jruoho case ACPI_RSD_UINT8:
307 1.4 christos
308 1.4 christos if (Table->Pointer)
309 1.4 christos {
310 1.8 christos AcpiRsOutString (Name, Table->Pointer [*Target]);
311 1.4 christos }
312 1.4 christos else
313 1.4 christos {
314 1.4 christos AcpiRsOutInteger8 (Name, ACPI_GET8 (Target));
315 1.4 christos }
316 1.1 jruoho break;
317 1.1 jruoho
318 1.1 jruoho case ACPI_RSD_UINT16:
319 1.4 christos
320 1.1 jruoho AcpiRsOutInteger16 (Name, ACPI_GET16 (Target));
321 1.1 jruoho break;
322 1.1 jruoho
323 1.1 jruoho case ACPI_RSD_UINT32:
324 1.4 christos
325 1.1 jruoho AcpiRsOutInteger32 (Name, ACPI_GET32 (Target));
326 1.1 jruoho break;
327 1.1 jruoho
328 1.1 jruoho case ACPI_RSD_UINT64:
329 1.4 christos
330 1.1 jruoho AcpiRsOutInteger64 (Name, ACPI_GET64 (Target));
331 1.1 jruoho break;
332 1.1 jruoho
333 1.1 jruoho /* Flags: 1-bit and 2-bit flags supported */
334 1.1 jruoho
335 1.1 jruoho case ACPI_RSD_1BITFLAG:
336 1.4 christos
337 1.8 christos AcpiRsOutString (Name, Table->Pointer [*Target & 0x01]);
338 1.1 jruoho break;
339 1.1 jruoho
340 1.1 jruoho case ACPI_RSD_2BITFLAG:
341 1.4 christos
342 1.8 christos AcpiRsOutString (Name, Table->Pointer [*Target & 0x03]);
343 1.1 jruoho break;
344 1.1 jruoho
345 1.4 christos case ACPI_RSD_3BITFLAG:
346 1.4 christos
347 1.8 christos AcpiRsOutString (Name, Table->Pointer [*Target & 0x07]);
348 1.4 christos break;
349 1.4 christos
350 1.1 jruoho case ACPI_RSD_SHORTLIST:
351 1.1 jruoho /*
352 1.1 jruoho * Short byte list (single line output) for DMA and IRQ resources
353 1.1 jruoho * Note: The list length is obtained from the previous table entry
354 1.1 jruoho */
355 1.1 jruoho if (PreviousTarget)
356 1.1 jruoho {
357 1.1 jruoho AcpiRsOutTitle (Name);
358 1.1 jruoho AcpiRsDumpShortByteList (*PreviousTarget, Target);
359 1.1 jruoho }
360 1.1 jruoho break;
361 1.1 jruoho
362 1.4 christos case ACPI_RSD_SHORTLISTX:
363 1.4 christos /*
364 1.4 christos * Short byte list (single line output) for GPIO vendor data
365 1.4 christos * Note: The list length is obtained from the previous table entry
366 1.4 christos */
367 1.4 christos if (PreviousTarget)
368 1.4 christos {
369 1.4 christos AcpiRsOutTitle (Name);
370 1.4 christos AcpiRsDumpShortByteList (*PreviousTarget,
371 1.4 christos *(ACPI_CAST_INDIRECT_PTR (UINT8, Target)));
372 1.4 christos }
373 1.4 christos break;
374 1.4 christos
375 1.1 jruoho case ACPI_RSD_LONGLIST:
376 1.1 jruoho /*
377 1.1 jruoho * Long byte list for Vendor resource data
378 1.1 jruoho * Note: The list length is obtained from the previous table entry
379 1.1 jruoho */
380 1.1 jruoho if (PreviousTarget)
381 1.1 jruoho {
382 1.1 jruoho AcpiRsDumpByteList (ACPI_GET16 (PreviousTarget), Target);
383 1.1 jruoho }
384 1.1 jruoho break;
385 1.1 jruoho
386 1.1 jruoho case ACPI_RSD_DWORDLIST:
387 1.1 jruoho /*
388 1.1 jruoho * Dword list for Extended Interrupt resources
389 1.1 jruoho * Note: The list length is obtained from the previous table entry
390 1.1 jruoho */
391 1.1 jruoho if (PreviousTarget)
392 1.1 jruoho {
393 1.1 jruoho AcpiRsDumpDwordList (*PreviousTarget,
394 1.1 jruoho ACPI_CAST_PTR (UINT32, Target));
395 1.1 jruoho }
396 1.1 jruoho break;
397 1.1 jruoho
398 1.4 christos case ACPI_RSD_WORDLIST:
399 1.4 christos /*
400 1.4 christos * Word list for GPIO Pin Table
401 1.4 christos * Note: The list length is obtained from the previous table entry
402 1.4 christos */
403 1.4 christos if (PreviousTarget)
404 1.4 christos {
405 1.4 christos AcpiRsDumpWordList (*PreviousTarget,
406 1.4 christos *(ACPI_CAST_INDIRECT_PTR (UINT16, Target)));
407 1.4 christos }
408 1.4 christos break;
409 1.4 christos
410 1.1 jruoho case ACPI_RSD_ADDRESS:
411 1.1 jruoho /*
412 1.1 jruoho * Common flags for all Address resources
413 1.1 jruoho */
414 1.6 christos AcpiRsDumpAddressCommon (ACPI_CAST_PTR (
415 1.6 christos ACPI_RESOURCE_DATA, Target));
416 1.1 jruoho break;
417 1.1 jruoho
418 1.1 jruoho case ACPI_RSD_SOURCE:
419 1.1 jruoho /*
420 1.1 jruoho * Optional ResourceSource for Address resources
421 1.1 jruoho */
422 1.6 christos AcpiRsDumpResourceSource (ACPI_CAST_PTR (
423 1.6 christos ACPI_RESOURCE_SOURCE, Target));
424 1.1 jruoho break;
425 1.1 jruoho
426 1.1 jruoho default:
427 1.4 christos
428 1.1 jruoho AcpiOsPrintf ("**** Invalid table opcode [%X] ****\n",
429 1.1 jruoho Table->Opcode);
430 1.1 jruoho return;
431 1.1 jruoho }
432 1.1 jruoho
433 1.1 jruoho Table++;
434 1.1 jruoho Count--;
435 1.1 jruoho }
436 1.1 jruoho }
437 1.1 jruoho
438 1.1 jruoho
439 1.1 jruoho /*******************************************************************************
440 1.1 jruoho *
441 1.1 jruoho * FUNCTION: AcpiRsDumpResourceSource
442 1.1 jruoho *
443 1.1 jruoho * PARAMETERS: ResourceSource - Pointer to a Resource Source struct
444 1.1 jruoho *
445 1.1 jruoho * RETURN: None
446 1.1 jruoho *
447 1.1 jruoho * DESCRIPTION: Common routine for dumping the optional ResourceSource and the
448 1.1 jruoho * corresponding ResourceSourceIndex.
449 1.1 jruoho *
450 1.1 jruoho ******************************************************************************/
451 1.1 jruoho
452 1.1 jruoho static void
453 1.1 jruoho AcpiRsDumpResourceSource (
454 1.1 jruoho ACPI_RESOURCE_SOURCE *ResourceSource)
455 1.1 jruoho {
456 1.1 jruoho ACPI_FUNCTION_ENTRY ();
457 1.1 jruoho
458 1.1 jruoho
459 1.1 jruoho if (ResourceSource->Index == 0xFF)
460 1.1 jruoho {
461 1.1 jruoho return;
462 1.1 jruoho }
463 1.1 jruoho
464 1.1 jruoho AcpiRsOutInteger8 ("Resource Source Index",
465 1.1 jruoho ResourceSource->Index);
466 1.1 jruoho
467 1.1 jruoho AcpiRsOutString ("Resource Source",
468 1.1 jruoho ResourceSource->StringPtr ?
469 1.1 jruoho ResourceSource->StringPtr : "[Not Specified]");
470 1.1 jruoho }
471 1.1 jruoho
472 1.1 jruoho
473 1.1 jruoho /*******************************************************************************
474 1.1 jruoho *
475 1.1 jruoho * FUNCTION: AcpiRsDumpAddressCommon
476 1.1 jruoho *
477 1.1 jruoho * PARAMETERS: Resource - Pointer to an internal resource descriptor
478 1.1 jruoho *
479 1.1 jruoho * RETURN: None
480 1.1 jruoho *
481 1.1 jruoho * DESCRIPTION: Dump the fields that are common to all Address resource
482 1.1 jruoho * descriptors
483 1.1 jruoho *
484 1.1 jruoho ******************************************************************************/
485 1.1 jruoho
486 1.1 jruoho static void
487 1.1 jruoho AcpiRsDumpAddressCommon (
488 1.1 jruoho ACPI_RESOURCE_DATA *Resource)
489 1.1 jruoho {
490 1.1 jruoho ACPI_FUNCTION_ENTRY ();
491 1.1 jruoho
492 1.1 jruoho
493 1.1 jruoho /* Decode the type-specific flags */
494 1.1 jruoho
495 1.1 jruoho switch (Resource->Address.ResourceType)
496 1.1 jruoho {
497 1.1 jruoho case ACPI_MEMORY_RANGE:
498 1.1 jruoho
499 1.1 jruoho AcpiRsDumpDescriptor (Resource, AcpiRsDumpMemoryFlags);
500 1.1 jruoho break;
501 1.1 jruoho
502 1.1 jruoho case ACPI_IO_RANGE:
503 1.1 jruoho
504 1.1 jruoho AcpiRsDumpDescriptor (Resource, AcpiRsDumpIoFlags);
505 1.1 jruoho break;
506 1.1 jruoho
507 1.1 jruoho case ACPI_BUS_NUMBER_RANGE:
508 1.1 jruoho
509 1.1 jruoho AcpiRsOutString ("Resource Type", "Bus Number Range");
510 1.1 jruoho break;
511 1.1 jruoho
512 1.1 jruoho default:
513 1.1 jruoho
514 1.1 jruoho AcpiRsOutInteger8 ("Resource Type",
515 1.1 jruoho (UINT8) Resource->Address.ResourceType);
516 1.1 jruoho break;
517 1.1 jruoho }
518 1.1 jruoho
519 1.1 jruoho /* Decode the general flags */
520 1.1 jruoho
521 1.1 jruoho AcpiRsDumpDescriptor (Resource, AcpiRsDumpGeneralFlags);
522 1.1 jruoho }
523 1.1 jruoho
524 1.1 jruoho
525 1.1 jruoho /*******************************************************************************
526 1.1 jruoho *
527 1.1 jruoho * FUNCTION: AcpiRsOut*
528 1.1 jruoho *
529 1.1 jruoho * PARAMETERS: Title - Name of the resource field
530 1.1 jruoho * Value - Value of the resource field
531 1.1 jruoho *
532 1.1 jruoho * RETURN: None
533 1.1 jruoho *
534 1.1 jruoho * DESCRIPTION: Miscellaneous helper functions to consistently format the
535 1.1 jruoho * output of the resource dump routines
536 1.1 jruoho *
537 1.1 jruoho ******************************************************************************/
538 1.1 jruoho
539 1.1 jruoho static void
540 1.1 jruoho AcpiRsOutString (
541 1.2 jruoho const char *Title,
542 1.2 jruoho const char *Value)
543 1.1 jruoho {
544 1.7 christos
545 1.1 jruoho AcpiOsPrintf ("%27s : %s", Title, Value);
546 1.1 jruoho if (!*Value)
547 1.1 jruoho {
548 1.1 jruoho AcpiOsPrintf ("[NULL NAMESTRING]");
549 1.1 jruoho }
550 1.1 jruoho AcpiOsPrintf ("\n");
551 1.1 jruoho }
552 1.1 jruoho
553 1.1 jruoho static void
554 1.1 jruoho AcpiRsOutInteger8 (
555 1.2 jruoho const char *Title,
556 1.1 jruoho UINT8 Value)
557 1.1 jruoho {
558 1.1 jruoho AcpiOsPrintf ("%27s : %2.2X\n", Title, Value);
559 1.1 jruoho }
560 1.1 jruoho
561 1.1 jruoho static void
562 1.1 jruoho AcpiRsOutInteger16 (
563 1.2 jruoho const char *Title,
564 1.1 jruoho UINT16 Value)
565 1.1 jruoho {
566 1.7 christos
567 1.1 jruoho AcpiOsPrintf ("%27s : %4.4X\n", Title, Value);
568 1.1 jruoho }
569 1.1 jruoho
570 1.1 jruoho static void
571 1.1 jruoho AcpiRsOutInteger32 (
572 1.2 jruoho const char *Title,
573 1.1 jruoho UINT32 Value)
574 1.1 jruoho {
575 1.7 christos
576 1.1 jruoho AcpiOsPrintf ("%27s : %8.8X\n", Title, Value);
577 1.1 jruoho }
578 1.1 jruoho
579 1.1 jruoho static void
580 1.1 jruoho AcpiRsOutInteger64 (
581 1.2 jruoho const char *Title,
582 1.1 jruoho UINT64 Value)
583 1.1 jruoho {
584 1.7 christos
585 1.1 jruoho AcpiOsPrintf ("%27s : %8.8X%8.8X\n", Title,
586 1.1 jruoho ACPI_FORMAT_UINT64 (Value));
587 1.1 jruoho }
588 1.1 jruoho
589 1.1 jruoho static void
590 1.1 jruoho AcpiRsOutTitle (
591 1.2 jruoho const char *Title)
592 1.1 jruoho {
593 1.7 christos
594 1.1 jruoho AcpiOsPrintf ("%27s : ", Title);
595 1.1 jruoho }
596 1.1 jruoho
597 1.1 jruoho
598 1.1 jruoho /*******************************************************************************
599 1.1 jruoho *
600 1.1 jruoho * FUNCTION: AcpiRsDump*List
601 1.1 jruoho *
602 1.1 jruoho * PARAMETERS: Length - Number of elements in the list
603 1.1 jruoho * Data - Start of the list
604 1.1 jruoho *
605 1.1 jruoho * RETURN: None
606 1.1 jruoho *
607 1.1 jruoho * DESCRIPTION: Miscellaneous functions to dump lists of raw data
608 1.1 jruoho *
609 1.1 jruoho ******************************************************************************/
610 1.1 jruoho
611 1.1 jruoho static void
612 1.1 jruoho AcpiRsDumpByteList (
613 1.1 jruoho UINT16 Length,
614 1.1 jruoho UINT8 *Data)
615 1.1 jruoho {
616 1.1 jruoho UINT8 i;
617 1.1 jruoho
618 1.1 jruoho
619 1.1 jruoho for (i = 0; i < Length; i++)
620 1.1 jruoho {
621 1.7 christos AcpiOsPrintf ("%25s%2.2X : %2.2X\n", "Byte", i, Data[i]);
622 1.1 jruoho }
623 1.1 jruoho }
624 1.1 jruoho
625 1.1 jruoho static void
626 1.1 jruoho AcpiRsDumpShortByteList (
627 1.6 christos UINT8 Length,
628 1.6 christos UINT8 *Data)
629 1.1 jruoho {
630 1.1 jruoho UINT8 i;
631 1.1 jruoho
632 1.1 jruoho
633 1.1 jruoho for (i = 0; i < Length; i++)
634 1.1 jruoho {
635 1.1 jruoho AcpiOsPrintf ("%X ", Data[i]);
636 1.1 jruoho }
637 1.7 christos
638 1.1 jruoho AcpiOsPrintf ("\n");
639 1.1 jruoho }
640 1.1 jruoho
641 1.1 jruoho static void
642 1.1 jruoho AcpiRsDumpDwordList (
643 1.1 jruoho UINT8 Length,
644 1.1 jruoho UINT32 *Data)
645 1.1 jruoho {
646 1.1 jruoho UINT8 i;
647 1.1 jruoho
648 1.1 jruoho
649 1.1 jruoho for (i = 0; i < Length; i++)
650 1.1 jruoho {
651 1.7 christos AcpiOsPrintf ("%25s%2.2X : %8.8X\n", "Dword", i, Data[i]);
652 1.1 jruoho }
653 1.1 jruoho }
654 1.1 jruoho
655 1.4 christos static void
656 1.4 christos AcpiRsDumpWordList (
657 1.4 christos UINT16 Length,
658 1.4 christos UINT16 *Data)
659 1.4 christos {
660 1.4 christos UINT16 i;
661 1.4 christos
662 1.4 christos
663 1.4 christos for (i = 0; i < Length; i++)
664 1.4 christos {
665 1.7 christos AcpiOsPrintf ("%25s%2.2X : %4.4X\n", "Word", i, Data[i]);
666 1.4 christos }
667 1.4 christos }
668