1 /******************************************************************************
2  *
3  * Module Name: exdump - Interpreter debug output routines
4  *
5  *****************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2019, Intel Corp.
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions, and the following disclaimer,
16  *    without modification.
17  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18  *    substantially similar to the "NO WARRANTY" disclaimer below
19  *    ("Disclaimer") and any redistribution must be conditioned upon
20  *    including a substantially similar Disclaimer requirement for further
21  *    binary redistribution.
22  * 3. Neither the names of the above-listed copyright holders nor the names
23  *    of any contributors may be used to endorse or promote products derived
24  *    from this software without specific prior written permission.
25  *
26  * Alternatively, this software may be distributed under the terms of the
27  * GNU General Public License ("GPL") version 2 as published by the Free
28  * Software Foundation.
29  *
30  * NO WARRANTY
31  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41  * POSSIBILITY OF SUCH DAMAGES.
42  */
43 
44 #include "acpi.h"
45 #include "accommon.h"
46 #include "acinterp.h"
47 #include "amlcode.h"
48 #include "acnamesp.h"
49 
50 
51 #define _COMPONENT          ACPI_EXECUTER
52         ACPI_MODULE_NAME    ("exdump")
53 
54 /*
55  * The following routines are used for debug output only
56  */
57 #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)
58 
59 /* Local prototypes */
60 
61 static void
62 AcpiExOutString (
63     const char              *Title,
64     const char              *Value);
65 
66 static void
67 AcpiExOutPointer (
68     const char              *Title,
69     const void              *Value);
70 
71 static void
72 AcpiExDumpObject (
73     ACPI_OPERAND_OBJECT     *ObjDesc,
74     ACPI_EXDUMP_INFO        *Info);
75 
76 static void
77 AcpiExDumpReferenceObj (
78     ACPI_OPERAND_OBJECT     *ObjDesc);
79 
80 static void
81 AcpiExDumpPackageObj (
82     ACPI_OPERAND_OBJECT     *ObjDesc,
83     UINT32                  Level,
84     UINT32                  Index);
85 
86 
87 /*******************************************************************************
88  *
89  * Object Descriptor info tables
90  *
91  * Note: The first table entry must be an INIT opcode and must contain
92  * the table length (number of table entries)
93  *
94  ******************************************************************************/
95 
96 static ACPI_EXDUMP_INFO     AcpiExDumpInteger[2] =
97 {
98     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpInteger),        NULL},
99     {ACPI_EXD_UINT64,   ACPI_EXD_OFFSET (Integer.Value),                "Value"}
100 };
101 
102 static ACPI_EXDUMP_INFO     AcpiExDumpString[4] =
103 {
104     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpString),         NULL},
105     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (String.Length),                "Length"},
106     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (String.Pointer),               "Pointer"},
107     {ACPI_EXD_STRING,   0,                                              NULL}
108 };
109 
110 static ACPI_EXDUMP_INFO     AcpiExDumpBuffer[5] =
111 {
112     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpBuffer),         NULL},
113     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (Buffer.Length),                "Length"},
114     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Buffer.Pointer),               "Pointer"},
115     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (Buffer.Node),                  "Parent Node"},
116     {ACPI_EXD_BUFFER,   0,                                              NULL}
117 };
118 
119 static ACPI_EXDUMP_INFO     AcpiExDumpPackage[6] =
120 {
121     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpPackage),        NULL},
122     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (Package.Node),                 "Parent Node"},
123     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Package.Flags),                "Flags"},
124     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (Package.Count),                "Element Count"},
125     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Package.Elements),             "Element List"},
126     {ACPI_EXD_PACKAGE,  0,                                              NULL}
127 };
128 
129 static ACPI_EXDUMP_INFO     AcpiExDumpDevice[4] =
130 {
131     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpDevice),         NULL},
132     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Device.NotifyList[0]),         "System Notify"},
133     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Device.NotifyList[1]),         "Device Notify"},
134     {ACPI_EXD_HDLR_LIST,ACPI_EXD_OFFSET (Device.Handler),               "Handler"}
135 };
136 
137 static ACPI_EXDUMP_INFO     AcpiExDumpEvent[2] =
138 {
139     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpEvent),          NULL},
140     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Event.OsSemaphore),            "OsSemaphore"}
141 };
142 
143 static ACPI_EXDUMP_INFO     AcpiExDumpMethod[9] =
144 {
145     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpMethod),         NULL},
146     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Method.InfoFlags),             "Info Flags"},
147     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Method.ParamCount),            "Parameter Count"},
148     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Method.SyncLevel),             "Sync Level"},
149     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Method.Mutex),                 "Mutex"},
150     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Method.OwnerId),               "Owner Id"},
151     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Method.ThreadCount),           "Thread Count"},
152     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (Method.AmlLength),             "Aml Length"},
153     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Method.AmlStart),              "Aml Start"}
154 };
155 
156 static ACPI_EXDUMP_INFO     AcpiExDumpMutex[6] =
157 {
158     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpMutex),          NULL},
159     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Mutex.SyncLevel),              "Sync Level"},
160     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Mutex.OriginalSyncLevel),      "Original Sync Level"},
161     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Mutex.OwnerThread),            "Owner Thread"},
162     {ACPI_EXD_UINT16,   ACPI_EXD_OFFSET (Mutex.AcquisitionDepth),       "Acquire Depth"},
163     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Mutex.OsMutex),                "OsMutex"}
164 };
165 
166 static ACPI_EXDUMP_INFO     AcpiExDumpRegion[8] =
167 {
168     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpRegion),         NULL},
169     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Region.SpaceId),               "Space Id"},
170     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Region.Flags),                 "Flags"},
171     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (Region.Node),                  "Parent Node"},
172     {ACPI_EXD_ADDRESS,  ACPI_EXD_OFFSET (Region.Address),               "Address"},
173     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (Region.Length),                "Length"},
174     {ACPI_EXD_HDLR_LIST,ACPI_EXD_OFFSET (Region.Handler),               "Handler"},
175     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Region.Next),                  "Next"}
176 };
177 
178 static ACPI_EXDUMP_INFO     AcpiExDumpPower[6] =
179 {
180     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpPower),          NULL},
181     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (PowerResource.SystemLevel),    "System Level"},
182     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (PowerResource.ResourceOrder),  "Resource Order"},
183     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (PowerResource.NotifyList[0]),  "System Notify"},
184     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (PowerResource.NotifyList[1]),  "Device Notify"},
185     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (PowerResource.Handler),        "Handler"}
186 };
187 
188 static ACPI_EXDUMP_INFO     AcpiExDumpProcessor[7] =
189 {
190     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpProcessor),      NULL},
191     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Processor.ProcId),             "Processor ID"},
192     {ACPI_EXD_UINT8 ,   ACPI_EXD_OFFSET (Processor.Length),             "Length"},
193     {ACPI_EXD_ADDRESS,  ACPI_EXD_OFFSET (Processor.Address),            "Address"},
194     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Processor.NotifyList[0]),      "System Notify"},
195     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Processor.NotifyList[1]),      "Device Notify"},
196     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Processor.Handler),            "Handler"}
197 };
198 
199 static ACPI_EXDUMP_INFO     AcpiExDumpThermal[4] =
200 {
201     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpThermal),        NULL},
202     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (ThermalZone.NotifyList[0]),    "System Notify"},
203     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (ThermalZone.NotifyList[1]),    "Device Notify"},
204     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (ThermalZone.Handler),          "Handler"}
205 };
206 
207 static ACPI_EXDUMP_INFO     AcpiExDumpBufferField[3] =
208 {
209     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpBufferField),    NULL},
210     {ACPI_EXD_FIELD,    0,                                              NULL},
211     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (BufferField.BufferObj),        "Buffer Object"}
212 };
213 
214 static ACPI_EXDUMP_INFO     AcpiExDumpRegionField[5] =
215 {
216     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpRegionField),    NULL},
217     {ACPI_EXD_FIELD,    0,                                              NULL},
218     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Field.AccessLength),           "AccessLength"},
219     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Field.RegionObj),              "Region Object"},
220     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Field.ResourceBuffer),         "ResourceBuffer"}
221 };
222 
223 static ACPI_EXDUMP_INFO     AcpiExDumpBankField[5] =
224 {
225     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpBankField),      NULL},
226     {ACPI_EXD_FIELD,    0,                                              NULL},
227     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (BankField.Value),              "Value"},
228     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (BankField.RegionObj),          "Region Object"},
229     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (BankField.BankObj),            "Bank Object"}
230 };
231 
232 static ACPI_EXDUMP_INFO     AcpiExDumpIndexField[5] =
233 {
234     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpBankField),      NULL},
235     {ACPI_EXD_FIELD,    0,                                              NULL},
236     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (IndexField.Value),             "Value"},
237     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (IndexField.IndexObj),          "Index Object"},
238     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (IndexField.DataObj),           "Data Object"}
239 };
240 
241 static ACPI_EXDUMP_INFO     AcpiExDumpReference[9] =
242 {
243     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpReference),       NULL},
244     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Reference.Class),              "Class"},
245     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Reference.TargetType),         "Target Type"},
246     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (Reference.Value),              "Value"},
247     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Reference.Object),             "Object Desc"},
248     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (Reference.Node),               "Node"},
249     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Reference.Where),              "Where"},
250     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Reference.IndexPointer),       "Index Pointer"},
251     {ACPI_EXD_REFERENCE,0,                                              NULL}
252 };
253 
254 static ACPI_EXDUMP_INFO     AcpiExDumpAddressHandler[6] =
255 {
256     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpAddressHandler), NULL},
257     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (AddressSpace.SpaceId),         "Space Id"},
258     {ACPI_EXD_HDLR_LIST,ACPI_EXD_OFFSET (AddressSpace.Next),            "Next"},
259     {ACPI_EXD_RGN_LIST, ACPI_EXD_OFFSET (AddressSpace.RegionList),      "Region List"},
260     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (AddressSpace.Node),            "Node"},
261     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (AddressSpace.Context),         "Context"}
262 };
263 
264 static ACPI_EXDUMP_INFO     AcpiExDumpNotify[7] =
265 {
266     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpNotify),         NULL},
267     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (Notify.Node),                  "Node"},
268     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (Notify.HandlerType),           "Handler Type"},
269     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Notify.Handler),               "Handler"},
270     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Notify.Context),               "Context"},
271     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Notify.Next[0]),               "Next System Notify"},
272     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Notify.Next[1]),               "Next Device Notify"}
273 };
274 
275 static ACPI_EXDUMP_INFO     AcpiExDumpExtra[6] =
276 {
277     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpExtra),          NULL},
278     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Extra.Method_REG),             "_REG Method"},
279     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (Extra.ScopeNode),              "Scope Node"},
280     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Extra.RegionContext),          "Region Context"},
281     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Extra.AmlStart),               "Aml Start"},
282     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (Extra.AmlLength),              "Aml Length"}
283 };
284 
285 static ACPI_EXDUMP_INFO     AcpiExDumpData[3] =
286 {
287     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpData),           NULL},
288     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Data.Handler),                 "Handler"},
289     {ACPI_EXD_POINTER,  ACPI_EXD_OFFSET (Data.Pointer),                 "Raw Data"}
290 };
291 
292 /* Miscellaneous tables */
293 
294 static ACPI_EXDUMP_INFO     AcpiExDumpCommon[5] =
295 {
296     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpCommon),         NULL},
297     {ACPI_EXD_TYPE ,    0,                                              NULL},
298     {ACPI_EXD_UINT16,   ACPI_EXD_OFFSET (Common.ReferenceCount),        "Reference Count"},
299     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (Common.Flags),                 "Flags"},
300     {ACPI_EXD_LIST,     ACPI_EXD_OFFSET (Common.NextObject),            "Object List"}
301 };
302 
303 static ACPI_EXDUMP_INFO     AcpiExDumpFieldCommon[7] =
304 {
305     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpFieldCommon),    NULL},
306     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (CommonField.FieldFlags),       "Field Flags"},
307     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (CommonField.AccessByteWidth),  "Access Byte Width"},
308     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (CommonField.BitLength),        "Bit Length"},
309     {ACPI_EXD_UINT8,    ACPI_EXD_OFFSET (CommonField.StartFieldBitOffset),"Field Bit Offset"},
310     {ACPI_EXD_UINT32,   ACPI_EXD_OFFSET (CommonField.BaseByteOffset),   "Base Byte Offset"},
311     {ACPI_EXD_NODE,     ACPI_EXD_OFFSET (CommonField.Node),             "Parent Node"}
312 };
313 
314 static ACPI_EXDUMP_INFO     AcpiExDumpNode[7] =
315 {
316     {ACPI_EXD_INIT,     ACPI_EXD_TABLE_SIZE (AcpiExDumpNode),           NULL},
317     {ACPI_EXD_UINT8,    ACPI_EXD_NSOFFSET (Flags),                      "Flags"},
318     {ACPI_EXD_UINT8,    ACPI_EXD_NSOFFSET (OwnerId),                    "Owner Id"},
319     {ACPI_EXD_LIST,     ACPI_EXD_NSOFFSET (Object),                     "Object List"},
320     {ACPI_EXD_NODE,     ACPI_EXD_NSOFFSET (Parent),                     "Parent"},
321     {ACPI_EXD_NODE,     ACPI_EXD_NSOFFSET (Child),                      "Child"},
322     {ACPI_EXD_NODE,     ACPI_EXD_NSOFFSET (Peer),                       "Peer"}
323 };
324 
325 
326 /* Dispatch table, indexed by object type */
327 
328 static ACPI_EXDUMP_INFO     *AcpiExDumpInfo[] =
329 {
330     NULL,
331     AcpiExDumpInteger,
332     AcpiExDumpString,
333     AcpiExDumpBuffer,
334     AcpiExDumpPackage,
335     NULL,
336     AcpiExDumpDevice,
337     AcpiExDumpEvent,
338     AcpiExDumpMethod,
339     AcpiExDumpMutex,
340     AcpiExDumpRegion,
341     AcpiExDumpPower,
342     AcpiExDumpProcessor,
343     AcpiExDumpThermal,
344     AcpiExDumpBufferField,
345     NULL,
346     NULL,
347     AcpiExDumpRegionField,
348     AcpiExDumpBankField,
349     AcpiExDumpIndexField,
350     AcpiExDumpReference,
351     NULL,
352     NULL,
353     AcpiExDumpNotify,
354     AcpiExDumpAddressHandler,
355     NULL,
356     NULL,
357     NULL,
358     AcpiExDumpExtra,
359     AcpiExDumpData
360 };
361 
362 
363 /*******************************************************************************
364  *
365  * FUNCTION:    AcpiExDumpObject
366  *
367  * PARAMETERS:  ObjDesc             - Descriptor to dump
368  *              Info                - Info table corresponding to this object
369  *                                    type
370  *
371  * RETURN:      None
372  *
373  * DESCRIPTION: Walk the info table for this object
374  *
375  ******************************************************************************/
376 
377 static void
378 AcpiExDumpObject (
379     ACPI_OPERAND_OBJECT     *ObjDesc,
380     ACPI_EXDUMP_INFO        *Info)
381 {
382     UINT8                   *Target;
383     const char              *Name;
384     UINT8                   Count;
385     ACPI_OPERAND_OBJECT     *Start;
386     ACPI_OPERAND_OBJECT     *Data = NULL;
387     ACPI_OPERAND_OBJECT     *Next;
388     ACPI_NAMESPACE_NODE     *Node;
389 
390 
391     if (!Info)
392     {
393         AcpiOsPrintf (
394             "ExDumpObject: Display not implemented for object type %s\n",
395             AcpiUtGetObjectTypeName (ObjDesc));
396         return;
397     }
398 
399     /* First table entry must contain the table length (# of table entries) */
400 
401     Count = Info->Offset;
402 
403     while (Count)
404     {
405         if (!ObjDesc)
406         {
407             return;
408         }
409 
410         Target = ACPI_ADD_PTR (UINT8, ObjDesc, Info->Offset);
411         Name = Info->Name;
412 
413         switch (Info->Opcode)
414         {
415         case ACPI_EXD_INIT:
416 
417             break;
418 
419         case ACPI_EXD_TYPE:
420 
421             AcpiOsPrintf ("%20s : %2.2X [%s]\n", "Type",
422                 ObjDesc->Common.Type,
423                 AcpiUtGetObjectTypeName (ObjDesc));
424             break;
425 
426         case ACPI_EXD_UINT8:
427 
428             AcpiOsPrintf ("%20s : %2.2X\n", Name, *Target);
429             break;
430 
431         case ACPI_EXD_UINT16:
432 
433             AcpiOsPrintf ("%20s : %4.4X\n", Name, ACPI_GET16 (Target));
434             break;
435 
436         case ACPI_EXD_UINT32:
437 
438             AcpiOsPrintf ("%20s : %8.8X\n", Name, ACPI_GET32 (Target));
439             break;
440 
441         case ACPI_EXD_UINT64:
442 
443             AcpiOsPrintf ("%20s : %8.8X%8.8X\n", "Value",
444                 ACPI_FORMAT_UINT64 (ACPI_GET64 (Target)));
445             break;
446 
447         case ACPI_EXD_POINTER:
448         case ACPI_EXD_ADDRESS:
449 
450             AcpiExOutPointer (Name, *ACPI_CAST_PTR (void *, Target));
451             break;
452 
453         case ACPI_EXD_STRING:
454 
455             AcpiUtPrintString (ObjDesc->String.Pointer, ACPI_UINT8_MAX);
456             AcpiOsPrintf ("\n");
457             break;
458 
459         case ACPI_EXD_BUFFER:
460 
461             ACPI_DUMP_BUFFER (
462                 ObjDesc->Buffer.Pointer, ObjDesc->Buffer.Length);
463             break;
464 
465         case ACPI_EXD_PACKAGE:
466 
467             /* Dump the package contents */
468 
469             AcpiOsPrintf ("\nPackage Contents:\n");
470             AcpiExDumpPackageObj (ObjDesc, 0, 0);
471             break;
472 
473         case ACPI_EXD_FIELD:
474 
475             AcpiExDumpObject (ObjDesc, AcpiExDumpFieldCommon);
476             break;
477 
478         case ACPI_EXD_REFERENCE:
479 
480             AcpiExOutString ("Class Name", AcpiUtGetReferenceName (ObjDesc));
481             AcpiExDumpReferenceObj (ObjDesc);
482             break;
483 
484         case ACPI_EXD_LIST:
485 
486             Start = *ACPI_CAST_PTR (void *, Target);
487             Next = Start;
488 
489             AcpiOsPrintf ("%20s : %p ", Name, Next);
490             if (Next)
491             {
492                 AcpiOsPrintf ("%s (Type %2.2X)",
493                     AcpiUtGetObjectTypeName (Next), Next->Common.Type);
494 
495                 while (Next->Common.NextObject)
496                 {
497                     if ((Next->Common.Type == ACPI_TYPE_LOCAL_DATA) &&
498                         !Data)
499                     {
500                         Data = Next;
501                     }
502 
503                     Next = Next->Common.NextObject;
504                     AcpiOsPrintf ("->%p(%s %2.2X)", Next,
505                         AcpiUtGetObjectTypeName (Next), Next->Common.Type);
506 
507                     if ((Next == Start) || (Next == Data))
508                     {
509                         AcpiOsPrintf (
510                             "\n**** Error: Object list appears to be circular linked");
511                         break;
512                     }
513                 }
514             }
515             else
516             {
517                 AcpiOsPrintf ("- No attached objects");
518             }
519 
520             AcpiOsPrintf ("\n");
521             break;
522 
523         case ACPI_EXD_HDLR_LIST:
524 
525             Start = *ACPI_CAST_PTR (void *, Target);
526             Next = Start;
527 
528             AcpiOsPrintf ("%20s : %p", Name, Next);
529             if (Next)
530             {
531                 AcpiOsPrintf ("(%s %2.2X)",
532                     AcpiUtGetObjectTypeName (Next),
533                     Next->AddressSpace.SpaceId);
534 
535                 while (Next->AddressSpace.Next)
536                 {
537                     if ((Next->Common.Type == ACPI_TYPE_LOCAL_DATA) &&
538                         !Data)
539                     {
540                         Data = Next;
541                     }
542 
543                     Next = Next->AddressSpace.Next;
544                     AcpiOsPrintf ("->%p(%s %2.2X)", Next,
545                         AcpiUtGetObjectTypeName (Next),
546                         Next->AddressSpace.SpaceId);
547 
548                     if ((Next == Start) || (Next == Data))
549                     {
550                         AcpiOsPrintf (
551                             "\n**** Error: Handler list appears to be circular linked");
552                         break;
553                     }
554                 }
555             }
556 
557             AcpiOsPrintf ("\n");
558             break;
559 
560         case ACPI_EXD_RGN_LIST:
561 
562             Start = *ACPI_CAST_PTR (void *, Target);
563             Next = Start;
564 
565             AcpiOsPrintf ("%20s : %p", Name, Next);
566             if (Next)
567             {
568                 AcpiOsPrintf ("(%s %2.2X)",
569                     AcpiUtGetObjectTypeName (Next), Next->Common.Type);
570 
571                 while (Next->Region.Next)
572                 {
573                     if ((Next->Common.Type == ACPI_TYPE_LOCAL_DATA) &&
574                         !Data)
575                     {
576                         Data = Next;
577                     }
578 
579                     Next = Next->Region.Next;
580                     AcpiOsPrintf ("->%p(%s %2.2X)", Next,
581                         AcpiUtGetObjectTypeName (Next), Next->Common.Type);
582 
583                     if ((Next == Start) || (Next == Data))
584                     {
585                         AcpiOsPrintf (
586                             "\n**** Error: Region list appears to be circular linked");
587                         break;
588                     }
589                 }
590             }
591 
592             AcpiOsPrintf ("\n");
593             break;
594 
595         case ACPI_EXD_NODE:
596 
597             Node = *ACPI_CAST_PTR (ACPI_NAMESPACE_NODE *, Target);
598 
599             AcpiOsPrintf ("%20s : %p", Name, Node);
600             if (Node)
601             {
602                 AcpiOsPrintf (" [%4.4s]", Node->Name.Ascii);
603             }
604             AcpiOsPrintf ("\n");
605             break;
606 
607         default:
608 
609             AcpiOsPrintf ("**** Invalid table opcode [%X] ****\n",
610                 Info->Opcode);
611             return;
612         }
613 
614         Info++;
615         Count--;
616     }
617 }
618 
619 
620 /*******************************************************************************
621  *
622  * FUNCTION:    AcpiExDumpOperand
623  *
624  * PARAMETERS:  *ObjDesc        - Pointer to entry to be dumped
625  *              Depth           - Current nesting depth
626  *
627  * RETURN:      None
628  *
629  * DESCRIPTION: Dump an operand object
630  *
631  ******************************************************************************/
632 
633 void
634 AcpiExDumpOperand (
635     ACPI_OPERAND_OBJECT     *ObjDesc,
636     UINT32                  Depth)
637 {
638     UINT32                  Length;
639     UINT32                  Index;
640 
641 
642     ACPI_FUNCTION_NAME (ExDumpOperand);
643 
644 
645     /* Check if debug output enabled */
646 
647     if (!ACPI_IS_DEBUG_ENABLED (ACPI_LV_EXEC, _COMPONENT))
648     {
649         return;
650     }
651 
652     if (!ObjDesc)
653     {
654         /* This could be a null element of a package */
655 
656         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Null Object Descriptor\n"));
657         return;
658     }
659 
660     if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_NAMED)
661     {
662         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%p Namespace Node: ", ObjDesc));
663         ACPI_DUMP_ENTRY (ObjDesc, ACPI_LV_EXEC);
664         return;
665     }
666 
667     if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_OPERAND)
668     {
669         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC,
670             "%p is not a node or operand object: [%s]\n",
671             ObjDesc, AcpiUtGetDescriptorName (ObjDesc)));
672         ACPI_DUMP_BUFFER (ObjDesc, sizeof (ACPI_OPERAND_OBJECT));
673         return;
674     }
675 
676     /* ObjDesc is a valid object */
677 
678     if (Depth > 0)
679     {
680         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%*s[%u] %p Refs=%u ",
681             Depth, " ", Depth, ObjDesc, ObjDesc->Common.ReferenceCount));
682     }
683     else
684     {
685         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%p Refs=%u ",
686             ObjDesc, ObjDesc->Common.ReferenceCount));
687     }
688 
689     /* Decode object type */
690 
691     switch (ObjDesc->Common.Type)
692     {
693     case ACPI_TYPE_LOCAL_REFERENCE:
694 
695         AcpiOsPrintf ("Reference: [%s] ",
696             AcpiUtGetReferenceName (ObjDesc));
697 
698         switch (ObjDesc->Reference.Class)
699         {
700         case ACPI_REFCLASS_DEBUG:
701 
702             AcpiOsPrintf ("\n");
703             break;
704 
705         case ACPI_REFCLASS_INDEX:
706 
707             AcpiOsPrintf ("%p\n", ObjDesc->Reference.Object);
708             break;
709 
710         case ACPI_REFCLASS_TABLE:
711 
712             AcpiOsPrintf ("Table Index %X\n", ObjDesc->Reference.Value);
713             break;
714 
715         case ACPI_REFCLASS_REFOF:
716 
717             AcpiOsPrintf ("%p [%s]\n", ObjDesc->Reference.Object,
718                 AcpiUtGetTypeName (((ACPI_OPERAND_OBJECT *)
719                     ObjDesc->Reference.Object)->Common.Type));
720             break;
721 
722         case ACPI_REFCLASS_NAME:
723 
724             AcpiUtRepairName (ObjDesc->Reference.Node->Name.Ascii);
725             AcpiOsPrintf ("- [%4.4s] (Node %p)\n",
726                 ObjDesc->Reference.Node->Name.Ascii,
727                 ObjDesc->Reference.Node);
728             break;
729 
730         case ACPI_REFCLASS_ARG:
731         case ACPI_REFCLASS_LOCAL:
732 
733             AcpiOsPrintf ("%X\n", ObjDesc->Reference.Value);
734             break;
735 
736         default:    /* Unknown reference class */
737 
738             AcpiOsPrintf ("%2.2X\n", ObjDesc->Reference.Class);
739             break;
740         }
741         break;
742 
743     case ACPI_TYPE_BUFFER:
744 
745         AcpiOsPrintf ("Buffer length %.2X @ %p\n",
746             ObjDesc->Buffer.Length, ObjDesc->Buffer.Pointer);
747 
748         /* Debug only -- dump the buffer contents */
749 
750         if (ObjDesc->Buffer.Pointer)
751         {
752             Length = ObjDesc->Buffer.Length;
753             if (Length > 128)
754             {
755                 Length = 128;
756             }
757 
758             AcpiOsPrintf (
759                 "Buffer Contents: (displaying length 0x%.2X)\n", Length);
760             ACPI_DUMP_BUFFER (ObjDesc->Buffer.Pointer, Length);
761         }
762         break;
763 
764     case ACPI_TYPE_INTEGER:
765 
766         AcpiOsPrintf ("Integer %8.8X%8.8X\n",
767             ACPI_FORMAT_UINT64 (ObjDesc->Integer.Value));
768         break;
769 
770     case ACPI_TYPE_PACKAGE:
771 
772         AcpiOsPrintf ("Package [Len %X] ElementArray %p\n",
773             ObjDesc->Package.Count, ObjDesc->Package.Elements);
774 
775         /*
776          * If elements exist, package element pointer is valid,
777          * and debug_level exceeds 1, dump package's elements.
778          */
779         if (ObjDesc->Package.Count &&
780             ObjDesc->Package.Elements &&
781             AcpiDbgLevel > 1)
782         {
783             for (Index = 0; Index < ObjDesc->Package.Count; Index++)
784             {
785                 AcpiExDumpOperand (
786                     ObjDesc->Package.Elements[Index], Depth + 1);
787             }
788         }
789         break;
790 
791     case ACPI_TYPE_REGION:
792 
793         AcpiOsPrintf ("Region %s (%X)",
794             AcpiUtGetRegionName (ObjDesc->Region.SpaceId),
795             ObjDesc->Region.SpaceId);
796 
797         /*
798          * If the address and length have not been evaluated,
799          * don't print them.
800          */
801         if (!(ObjDesc->Region.Flags & AOPOBJ_DATA_VALID))
802         {
803             AcpiOsPrintf ("\n");
804         }
805         else
806         {
807             AcpiOsPrintf (" base %8.8X%8.8X Length %X\n",
808                 ACPI_FORMAT_UINT64 (ObjDesc->Region.Address),
809                 ObjDesc->Region.Length);
810         }
811         break;
812 
813     case ACPI_TYPE_STRING:
814 
815         AcpiOsPrintf ("String length %X @ %p ",
816             ObjDesc->String.Length,
817             ObjDesc->String.Pointer);
818 
819         AcpiUtPrintString (ObjDesc->String.Pointer, ACPI_UINT8_MAX);
820         AcpiOsPrintf ("\n");
821         break;
822 
823     case ACPI_TYPE_LOCAL_BANK_FIELD:
824 
825         AcpiOsPrintf ("BankField\n");
826         break;
827 
828     case ACPI_TYPE_LOCAL_REGION_FIELD:
829 
830         AcpiOsPrintf ("RegionField: Bits=%X AccWidth=%X Lock=%X Update=%X at "
831             "byte=%X bit=%X of below:\n",
832             ObjDesc->Field.BitLength,
833             ObjDesc->Field.AccessByteWidth,
834             ObjDesc->Field.FieldFlags & AML_FIELD_LOCK_RULE_MASK,
835             ObjDesc->Field.FieldFlags & AML_FIELD_UPDATE_RULE_MASK,
836             ObjDesc->Field.BaseByteOffset,
837             ObjDesc->Field.StartFieldBitOffset);
838 
839         AcpiExDumpOperand (ObjDesc->Field.RegionObj, Depth + 1);
840         break;
841 
842     case ACPI_TYPE_LOCAL_INDEX_FIELD:
843 
844         AcpiOsPrintf ("IndexField\n");
845         break;
846 
847     case ACPI_TYPE_BUFFER_FIELD:
848 
849         AcpiOsPrintf ("BufferField: %X bits at byte %X bit %X of\n",
850             ObjDesc->BufferField.BitLength,
851             ObjDesc->BufferField.BaseByteOffset,
852             ObjDesc->BufferField.StartFieldBitOffset);
853 
854         if (!ObjDesc->BufferField.BufferObj)
855         {
856             ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "*NULL*\n"));
857         }
858         else if ((ObjDesc->BufferField.BufferObj)->Common.Type !=
859             ACPI_TYPE_BUFFER)
860         {
861             AcpiOsPrintf ("*not a Buffer*\n");
862         }
863         else
864         {
865             AcpiExDumpOperand (ObjDesc->BufferField.BufferObj, Depth + 1);
866         }
867         break;
868 
869     case ACPI_TYPE_EVENT:
870 
871         AcpiOsPrintf ("Event\n");
872         break;
873 
874     case ACPI_TYPE_METHOD:
875 
876         AcpiOsPrintf ("Method(%X) @ %p:%X\n",
877             ObjDesc->Method.ParamCount,
878             ObjDesc->Method.AmlStart,
879             ObjDesc->Method.AmlLength);
880         break;
881 
882     case ACPI_TYPE_MUTEX:
883 
884         AcpiOsPrintf ("Mutex\n");
885         break;
886 
887     case ACPI_TYPE_DEVICE:
888 
889         AcpiOsPrintf ("Device\n");
890         break;
891 
892     case ACPI_TYPE_POWER:
893 
894         AcpiOsPrintf ("Power\n");
895         break;
896 
897     case ACPI_TYPE_PROCESSOR:
898 
899         AcpiOsPrintf ("Processor\n");
900         break;
901 
902     case ACPI_TYPE_THERMAL:
903 
904         AcpiOsPrintf ("Thermal\n");
905         break;
906 
907     default:
908 
909         /* Unknown Type */
910 
911         AcpiOsPrintf ("Unknown Type %X\n", ObjDesc->Common.Type);
912         break;
913     }
914 
915     return;
916 }
917 
918 
919 /*******************************************************************************
920  *
921  * FUNCTION:    AcpiExDumpOperands
922  *
923  * PARAMETERS:  Operands            - A list of Operand objects
924  *              OpcodeName          - AML opcode name
925  *              NumOperands         - Operand count for this opcode
926  *
927  * DESCRIPTION: Dump the operands associated with the opcode
928  *
929  ******************************************************************************/
930 
931 void
932 AcpiExDumpOperands (
933     ACPI_OPERAND_OBJECT     **Operands,
934     const char              *OpcodeName,
935     UINT32                  NumOperands)
936 {
937     ACPI_FUNCTION_TRACE (ExDumpOperands);
938 
939 
940     if (!OpcodeName)
941     {
942         OpcodeName = "UNKNOWN";
943     }
944 
945     ACPI_DEBUG_PRINT ((ACPI_DB_EXEC,
946         "**** Start operand dump for opcode [%s], %u operands\n",
947         OpcodeName, NumOperands));
948 
949     if (NumOperands == 0)
950     {
951         NumOperands = 1;
952     }
953 
954     /* Dump the individual operands */
955 
956     while (NumOperands)
957     {
958         AcpiExDumpOperand (*Operands, 0);
959         Operands++;
960         NumOperands--;
961     }
962 
963     ACPI_DEBUG_PRINT ((ACPI_DB_EXEC,
964         "**** End operand dump for [%s]\n", OpcodeName));
965     return_VOID;
966 }
967 
968 
969 /*******************************************************************************
970  *
971  * FUNCTION:    AcpiExOut* functions
972  *
973  * PARAMETERS:  Title               - Descriptive text
974  *              Value               - Value to be displayed
975  *
976  * DESCRIPTION: Object dump output formatting functions. These functions
977  *              reduce the number of format strings required and keeps them
978  *              all in one place for easy modification.
979  *
980  ******************************************************************************/
981 
982 static void
983 AcpiExOutString (
984     const char              *Title,
985     const char              *Value)
986 {
987     AcpiOsPrintf ("%20s : %s\n", Title, Value);
988 }
989 
990 static void
991 AcpiExOutPointer (
992     const char              *Title,
993     const void              *Value)
994 {
995     AcpiOsPrintf ("%20s : %p\n", Title, Value);
996 }
997 
998 
999 /*******************************************************************************
1000  *
1001  * FUNCTION:    AcpiExDumpNamespaceNode
1002  *
1003  * PARAMETERS:  Node                - Descriptor to dump
1004  *              Flags               - Force display if TRUE
1005  *
1006  * DESCRIPTION: Dumps the members of the given.Node
1007  *
1008  ******************************************************************************/
1009 
1010 void
1011 AcpiExDumpNamespaceNode (
1012     ACPI_NAMESPACE_NODE     *Node,
1013     UINT32                  Flags)
1014 {
1015 
1016     ACPI_FUNCTION_ENTRY ();
1017 
1018 
1019     if (!Flags)
1020     {
1021         /* Check if debug output enabled */
1022 
1023         if (!ACPI_IS_DEBUG_ENABLED (ACPI_LV_OBJECTS, _COMPONENT))
1024         {
1025             return;
1026         }
1027     }
1028 
1029     AcpiOsPrintf ("%20s : %4.4s\n", "Name", AcpiUtGetNodeName (Node));
1030     AcpiOsPrintf ("%20s : %2.2X [%s]\n", "Type",
1031         Node->Type, AcpiUtGetTypeName (Node->Type));
1032 
1033     AcpiExDumpObject (ACPI_CAST_PTR (ACPI_OPERAND_OBJECT, Node),
1034         AcpiExDumpNode);
1035 }
1036 
1037 
1038 /*******************************************************************************
1039  *
1040  * FUNCTION:    AcpiExDumpReferenceObj
1041  *
1042  * PARAMETERS:  Object              - Descriptor to dump
1043  *
1044  * DESCRIPTION: Dumps a reference object
1045  *
1046  ******************************************************************************/
1047 
1048 static void
1049 AcpiExDumpReferenceObj (
1050     ACPI_OPERAND_OBJECT     *ObjDesc)
1051 {
1052     ACPI_BUFFER             RetBuf;
1053     ACPI_STATUS             Status;
1054 
1055 
1056     RetBuf.Length = ACPI_ALLOCATE_LOCAL_BUFFER;
1057 
1058     if (ObjDesc->Reference.Class == ACPI_REFCLASS_NAME)
1059     {
1060         AcpiOsPrintf (" %p ", ObjDesc->Reference.Node);
1061 
1062         Status = AcpiNsHandleToPathname (ObjDesc->Reference.Node,
1063             &RetBuf, TRUE);
1064         if (ACPI_FAILURE (Status))
1065         {
1066             AcpiOsPrintf (" Could not convert name to pathname: %s\n",
1067                 AcpiFormatException (Status));
1068         }
1069         else
1070         {
1071             AcpiOsPrintf ("%s: %s\n",
1072                 AcpiUtGetTypeName (ObjDesc->Reference.Node->Type),
1073                 (char *) RetBuf.Pointer);
1074             ACPI_FREE (RetBuf.Pointer);
1075         }
1076     }
1077     else if (ObjDesc->Reference.Object)
1078     {
1079         if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_OPERAND)
1080         {
1081             AcpiOsPrintf ("%22s %p", "Target :",
1082                 ObjDesc->Reference.Object);
1083             if (ObjDesc->Reference.Class == ACPI_REFCLASS_TABLE)
1084             {
1085                 AcpiOsPrintf (" Table Index: %X\n",
1086                     ObjDesc->Reference.Value);
1087             }
1088             else
1089             {
1090                 AcpiOsPrintf (" [%s]\n",
1091                     AcpiUtGetTypeName (((ACPI_OPERAND_OBJECT *)
1092                     ObjDesc->Reference.Object)->Common.Type));
1093             }
1094         }
1095         else
1096         {
1097             AcpiOsPrintf (" Target: %p\n", ObjDesc->Reference.Object);
1098         }
1099     }
1100 }
1101 
1102 
1103 /*******************************************************************************
1104  *
1105  * FUNCTION:    AcpiExDumpPackageObj
1106  *
1107  * PARAMETERS:  ObjDesc             - Descriptor to dump
1108  *              Level               - Indentation Level
1109  *              Index               - Package index for this object
1110  *
1111  * DESCRIPTION: Dumps the elements of the package
1112  *
1113  ******************************************************************************/
1114 
1115 static void
1116 AcpiExDumpPackageObj (
1117     ACPI_OPERAND_OBJECT     *ObjDesc,
1118     UINT32                  Level,
1119     UINT32                  Index)
1120 {
1121     UINT32                  i;
1122 
1123 
1124     /* Indentation and index output */
1125 
1126     if (Level > 0)
1127     {
1128         for (i = 0; i < Level; i++)
1129         {
1130             AcpiOsPrintf ("  ");
1131         }
1132 
1133         AcpiOsPrintf ("[%.2d] ", Index);
1134     }
1135 
1136     AcpiOsPrintf ("%p ", ObjDesc);
1137 
1138     /* Null package elements are allowed */
1139 
1140     if (!ObjDesc)
1141     {
1142         AcpiOsPrintf ("[Null Object]\n");
1143         return;
1144     }
1145 
1146     /* Packages may only contain a few object types */
1147 
1148     switch (ObjDesc->Common.Type)
1149     {
1150     case ACPI_TYPE_INTEGER:
1151 
1152         AcpiOsPrintf ("[Integer] = %8.8X%8.8X\n",
1153             ACPI_FORMAT_UINT64 (ObjDesc->Integer.Value));
1154         break;
1155 
1156     case ACPI_TYPE_STRING:
1157 
1158         AcpiOsPrintf ("[String]  Value: ");
1159         AcpiUtPrintString (ObjDesc->String.Pointer, ACPI_UINT8_MAX);
1160         AcpiOsPrintf ("\n");
1161         break;
1162 
1163     case ACPI_TYPE_BUFFER:
1164 
1165         AcpiOsPrintf ("[Buffer] Length %.2X = ", ObjDesc->Buffer.Length);
1166         if (ObjDesc->Buffer.Length)
1167         {
1168             AcpiUtDebugDumpBuffer (
1169                 ACPI_CAST_PTR (UINT8, ObjDesc->Buffer.Pointer),
1170                 ObjDesc->Buffer.Length, DB_DWORD_DISPLAY, _COMPONENT);
1171         }
1172         else
1173         {
1174             AcpiOsPrintf ("\n");
1175         }
1176         break;
1177 
1178     case ACPI_TYPE_PACKAGE:
1179 
1180         AcpiOsPrintf ("[Package] Contains %u Elements:\n",
1181             ObjDesc->Package.Count);
1182 
1183         for (i = 0; i < ObjDesc->Package.Count; i++)
1184         {
1185             AcpiExDumpPackageObj (
1186                 ObjDesc->Package.Elements[i], Level + 1, i);
1187         }
1188         break;
1189 
1190     case ACPI_TYPE_LOCAL_REFERENCE:
1191 
1192         AcpiOsPrintf ("[Object Reference] Class [%s]",
1193             AcpiUtGetReferenceName (ObjDesc));
1194         AcpiExDumpReferenceObj (ObjDesc);
1195         break;
1196 
1197     default:
1198 
1199         AcpiOsPrintf ("[%s] Type: %2.2X\n",
1200             AcpiUtGetTypeName (ObjDesc->Common.Type), ObjDesc->Common.Type);
1201         break;
1202     }
1203 }
1204 
1205 
1206 /*******************************************************************************
1207  *
1208  * FUNCTION:    AcpiExDumpObjectDescriptor
1209  *
1210  * PARAMETERS:  ObjDesc             - Descriptor to dump
1211  *              Flags               - Force display if TRUE
1212  *
1213  * DESCRIPTION: Dumps the members of the object descriptor given.
1214  *
1215  ******************************************************************************/
1216 
1217 void
1218 AcpiExDumpObjectDescriptor (
1219     ACPI_OPERAND_OBJECT     *ObjDesc,
1220     UINT32                  Flags)
1221 {
1222     ACPI_FUNCTION_TRACE (ExDumpObjectDescriptor);
1223 
1224 
1225     if (!ObjDesc)
1226     {
1227         return_VOID;
1228     }
1229 
1230     if (!Flags)
1231     {
1232         /* Check if debug output enabled */
1233 
1234         if (!ACPI_IS_DEBUG_ENABLED (ACPI_LV_OBJECTS, _COMPONENT))
1235         {
1236             return_VOID;
1237         }
1238     }
1239 
1240     if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_NAMED)
1241     {
1242         AcpiExDumpNamespaceNode ((ACPI_NAMESPACE_NODE *) ObjDesc, Flags);
1243 
1244         ObjDesc = ((ACPI_NAMESPACE_NODE *) ObjDesc)->Object;
1245         if (!ObjDesc)
1246         {
1247             return_VOID;
1248         }
1249 
1250         AcpiOsPrintf ("\nAttached Object %p", ObjDesc);
1251         if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_NAMED)
1252         {
1253             AcpiOsPrintf (" - Namespace Node");
1254         }
1255 
1256         AcpiOsPrintf (":\n");
1257         goto DumpObject;
1258     }
1259 
1260     if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_OPERAND)
1261     {
1262         AcpiOsPrintf (
1263             "%p is not an ACPI operand object: [%s]\n",
1264             ObjDesc, AcpiUtGetDescriptorName (ObjDesc));
1265         return_VOID;
1266     }
1267 
1268     /* Validate the object type */
1269 
1270     if (ObjDesc->Common.Type > ACPI_TYPE_LOCAL_MAX)
1271     {
1272         AcpiOsPrintf ("Not a known object type: %2.2X\n",
1273             ObjDesc->Common.Type);
1274         return_VOID;
1275     }
1276 
1277 
1278 DumpObject:
1279 
1280     if (!ObjDesc)
1281     {
1282         return_VOID;
1283     }
1284 
1285     /* Common Fields */
1286 
1287     AcpiExDumpObject (ObjDesc, AcpiExDumpCommon);
1288 
1289     /* Object-specific fields */
1290 
1291     AcpiExDumpObject (ObjDesc, AcpiExDumpInfo[ObjDesc->Common.Type]);
1292 
1293     if (ObjDesc->Common.Type == ACPI_TYPE_REGION)
1294     {
1295         ObjDesc = ObjDesc->Common.NextObject;
1296         if (ObjDesc->Common.Type > ACPI_TYPE_LOCAL_MAX)
1297         {
1298             AcpiOsPrintf (
1299                 "Secondary object is not a known object type: %2.2X\n",
1300                 ObjDesc->Common.Type);
1301 
1302             return_VOID;
1303         }
1304 
1305         AcpiOsPrintf ("\nExtra attached Object (%p):\n", ObjDesc);
1306         AcpiExDumpObject (ObjDesc, AcpiExDumpInfo[ObjDesc->Common.Type]);
1307     }
1308 
1309     return_VOID;
1310 }
1311 
1312 #endif
1313