xref: /freebsd/sys/contrib/dev/acpica/components/debugger/dbdisply.c (revision dda5b39711dab90ae1c5624bdd6ff7453177df31)
1 /*******************************************************************************
2  *
3  * Module Name: dbdisply - debug display commands
4  *
5  ******************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2013, 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 
45 #include <contrib/dev/acpica/include/acpi.h>
46 #include <contrib/dev/acpica/include/accommon.h>
47 #include <contrib/dev/acpica/include/amlcode.h>
48 #include <contrib/dev/acpica/include/acdispat.h>
49 #include <contrib/dev/acpica/include/acnamesp.h>
50 #include <contrib/dev/acpica/include/acparser.h>
51 #include <contrib/dev/acpica/include/acinterp.h>
52 #include <contrib/dev/acpica/include/acdebug.h>
53 #include <contrib/dev/acpica/include/acdisasm.h>
54 
55 
56 #ifdef ACPI_DEBUGGER
57 
58 #define _COMPONENT          ACPI_CA_DEBUGGER
59         ACPI_MODULE_NAME    ("dbdisply")
60 
61 /* Local prototypes */
62 
63 static void
64 AcpiDbDumpParserDescriptor (
65     ACPI_PARSE_OBJECT       *Op);
66 
67 static void *
68 AcpiDbGetPointer (
69     void                    *Target);
70 
71 static ACPI_STATUS
72 AcpiDbDisplayNonRootHandlers (
73     ACPI_HANDLE             ObjHandle,
74     UINT32                  NestingLevel,
75     void                    *Context,
76     void                    **ReturnValue);
77 
78 /*
79  * System handler information.
80  * Used for Handlers command, in AcpiDbDisplayHandlers.
81  */
82 #define ACPI_PREDEFINED_PREFIX          "%25s (%.2X) : "
83 #define ACPI_HANDLER_NAME_STRING               "%30s : "
84 #define ACPI_HANDLER_PRESENT_STRING                    "%-9s (%p)\n"
85 #define ACPI_HANDLER_PRESENT_STRING2                   "%-9s (%p)"
86 #define ACPI_HANDLER_NOT_PRESENT_STRING                "%-9s\n"
87 
88 /* All predefined Address Space IDs */
89 
90 static ACPI_ADR_SPACE_TYPE  AcpiGbl_SpaceIdList[] =
91 {
92     ACPI_ADR_SPACE_SYSTEM_MEMORY,
93     ACPI_ADR_SPACE_SYSTEM_IO,
94     ACPI_ADR_SPACE_PCI_CONFIG,
95     ACPI_ADR_SPACE_EC,
96     ACPI_ADR_SPACE_SMBUS,
97     ACPI_ADR_SPACE_CMOS,
98     ACPI_ADR_SPACE_PCI_BAR_TARGET,
99     ACPI_ADR_SPACE_IPMI,
100     ACPI_ADR_SPACE_GPIO,
101     ACPI_ADR_SPACE_GSBUS,
102     ACPI_ADR_SPACE_DATA_TABLE,
103     ACPI_ADR_SPACE_FIXED_HARDWARE
104 };
105 
106 /* Global handler information */
107 
108 typedef struct acpi_handler_info
109 {
110     void                    *Handler;
111     char                    *Name;
112 
113 } ACPI_HANDLER_INFO;
114 
115 static ACPI_HANDLER_INFO    AcpiGbl_HandlerList[] =
116 {
117     {&AcpiGbl_GlobalNotify[0].Handler,  "System Notifications"},
118     {&AcpiGbl_GlobalNotify[1].Handler,  "Device Notifications"},
119     {&AcpiGbl_TableHandler,             "ACPI Table Events"},
120     {&AcpiGbl_ExceptionHandler,         "Control Method Exceptions"},
121     {&AcpiGbl_InterfaceHandler,         "OSI Invocations"}
122 };
123 
124 
125 /*******************************************************************************
126  *
127  * FUNCTION:    AcpiDbGetPointer
128  *
129  * PARAMETERS:  Target          - Pointer to string to be converted
130  *
131  * RETURN:      Converted pointer
132  *
133  * DESCRIPTION: Convert an ascii pointer value to a real value
134  *
135  ******************************************************************************/
136 
137 static void *
138 AcpiDbGetPointer (
139     void                    *Target)
140 {
141     void                    *ObjPtr;
142     ACPI_SIZE               Address;
143 
144 
145     Address = ACPI_STRTOUL (Target, NULL, 16);
146     ObjPtr = ACPI_TO_POINTER (Address);
147     return (ObjPtr);
148 }
149 
150 
151 /*******************************************************************************
152  *
153  * FUNCTION:    AcpiDbDumpParserDescriptor
154  *
155  * PARAMETERS:  Op              - A parser Op descriptor
156  *
157  * RETURN:      None
158  *
159  * DESCRIPTION: Display a formatted parser object
160  *
161  ******************************************************************************/
162 
163 static void
164 AcpiDbDumpParserDescriptor (
165     ACPI_PARSE_OBJECT       *Op)
166 {
167     const ACPI_OPCODE_INFO  *Info;
168 
169 
170     Info = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode);
171 
172     AcpiOsPrintf ("Parser Op Descriptor:\n");
173     AcpiOsPrintf ("%20.20s : %4.4X\n", "Opcode", Op->Common.AmlOpcode);
174 
175     ACPI_DEBUG_ONLY_MEMBERS (AcpiOsPrintf ("%20.20s : %s\n", "Opcode Name",
176         Info->Name));
177 
178     AcpiOsPrintf ("%20.20s : %p\n", "Value/ArgList", Op->Common.Value.Arg);
179     AcpiOsPrintf ("%20.20s : %p\n", "Parent", Op->Common.Parent);
180     AcpiOsPrintf ("%20.20s : %p\n", "NextOp", Op->Common.Next);
181 }
182 
183 
184 /*******************************************************************************
185  *
186  * FUNCTION:    AcpiDbDecodeAndDisplayObject
187  *
188  * PARAMETERS:  Target          - String with object to be displayed. Names
189  *                                and hex pointers are supported.
190  *              OutputType      - Byte, Word, Dword, or Qword (B|W|D|Q)
191  *
192  * RETURN:      None
193  *
194  * DESCRIPTION: Display a formatted ACPI object
195  *
196  ******************************************************************************/
197 
198 void
199 AcpiDbDecodeAndDisplayObject (
200     char                    *Target,
201     char                    *OutputType)
202 {
203     void                    *ObjPtr;
204     ACPI_NAMESPACE_NODE     *Node;
205     ACPI_OPERAND_OBJECT     *ObjDesc;
206     UINT32                  Display = DB_BYTE_DISPLAY;
207     char                    Buffer[80];
208     ACPI_BUFFER             RetBuf;
209     ACPI_STATUS             Status;
210     UINT32                  Size;
211 
212 
213     if (!Target)
214     {
215         return;
216     }
217 
218     /* Decode the output type */
219 
220     if (OutputType)
221     {
222         AcpiUtStrupr (OutputType);
223         if (OutputType[0] == 'W')
224         {
225             Display = DB_WORD_DISPLAY;
226         }
227         else if (OutputType[0] == 'D')
228         {
229             Display = DB_DWORD_DISPLAY;
230         }
231         else if (OutputType[0] == 'Q')
232         {
233             Display = DB_QWORD_DISPLAY;
234         }
235     }
236 
237     RetBuf.Length = sizeof (Buffer);
238     RetBuf.Pointer = Buffer;
239 
240     /* Differentiate between a number and a name */
241 
242     if ((Target[0] >= 0x30) && (Target[0] <= 0x39))
243     {
244         ObjPtr = AcpiDbGetPointer (Target);
245         if (!AcpiOsReadable (ObjPtr, 16))
246         {
247             AcpiOsPrintf ("Address %p is invalid in this address space\n",
248                 ObjPtr);
249             return;
250         }
251 
252         /* Decode the object type */
253 
254         switch (ACPI_GET_DESCRIPTOR_TYPE (ObjPtr))
255         {
256         case ACPI_DESC_TYPE_NAMED:
257 
258             /* This is a namespace Node */
259 
260             if (!AcpiOsReadable (ObjPtr, sizeof (ACPI_NAMESPACE_NODE)))
261             {
262                 AcpiOsPrintf (
263                     "Cannot read entire Named object at address %p\n", ObjPtr);
264                 return;
265             }
266 
267             Node = ObjPtr;
268             goto DumpNode;
269 
270         case ACPI_DESC_TYPE_OPERAND:
271 
272             /* This is a ACPI OPERAND OBJECT */
273 
274             if (!AcpiOsReadable (ObjPtr, sizeof (ACPI_OPERAND_OBJECT)))
275             {
276                 AcpiOsPrintf ("Cannot read entire ACPI object at address %p\n",
277                     ObjPtr);
278                 return;
279             }
280 
281             AcpiUtDebugDumpBuffer (ObjPtr, sizeof (ACPI_OPERAND_OBJECT), Display,
282                 ACPI_UINT32_MAX);
283             AcpiExDumpObjectDescriptor (ObjPtr, 1);
284             break;
285 
286         case ACPI_DESC_TYPE_PARSER:
287 
288             /* This is a Parser Op object */
289 
290             if (!AcpiOsReadable (ObjPtr, sizeof (ACPI_PARSE_OBJECT)))
291             {
292                 AcpiOsPrintf (
293                     "Cannot read entire Parser object at address %p\n", ObjPtr);
294                 return;
295             }
296 
297             AcpiUtDebugDumpBuffer (ObjPtr, sizeof (ACPI_PARSE_OBJECT), Display,
298                 ACPI_UINT32_MAX);
299             AcpiDbDumpParserDescriptor ((ACPI_PARSE_OBJECT *) ObjPtr);
300             break;
301 
302         default:
303 
304             /* Is not a recognizeable object */
305 
306             Size = 16;
307             if (AcpiOsReadable (ObjPtr, 64))
308             {
309                 Size = 64;
310             }
311 
312             /* Just dump some memory */
313 
314             AcpiUtDebugDumpBuffer (ObjPtr, Size, Display, ACPI_UINT32_MAX);
315             break;
316         }
317 
318         return;
319     }
320 
321     /* The parameter is a name string that must be resolved to a Named obj */
322 
323     Node = AcpiDbLocalNsLookup (Target);
324     if (!Node)
325     {
326         return;
327     }
328 
329 
330 DumpNode:
331     /* Now dump the NS node */
332 
333     Status = AcpiGetName (Node, ACPI_FULL_PATHNAME, &RetBuf);
334     if (ACPI_FAILURE (Status))
335     {
336         AcpiOsPrintf ("Could not convert name to pathname\n");
337     }
338 
339     else
340     {
341         AcpiOsPrintf ("Object (%p) Pathname:  %s\n",
342             Node, (char *) RetBuf.Pointer);
343     }
344 
345     if (!AcpiOsReadable (Node, sizeof (ACPI_NAMESPACE_NODE)))
346     {
347         AcpiOsPrintf ("Invalid Named object at address %p\n", Node);
348         return;
349     }
350 
351     AcpiUtDebugDumpBuffer ((void *) Node, sizeof (ACPI_NAMESPACE_NODE),
352         Display, ACPI_UINT32_MAX);
353     AcpiExDumpNamespaceNode (Node, 1);
354 
355     ObjDesc = AcpiNsGetAttachedObject (Node);
356     if (ObjDesc)
357     {
358         AcpiOsPrintf ("\nAttached Object (%p):\n", ObjDesc);
359         if (!AcpiOsReadable (ObjDesc, sizeof (ACPI_OPERAND_OBJECT)))
360         {
361             AcpiOsPrintf ("Invalid internal ACPI Object at address %p\n",
362                 ObjDesc);
363             return;
364         }
365 
366         AcpiUtDebugDumpBuffer ((void *) ObjDesc, sizeof (ACPI_OPERAND_OBJECT),
367             Display, ACPI_UINT32_MAX);
368         AcpiExDumpObjectDescriptor (ObjDesc, 1);
369     }
370 }
371 
372 
373 /*******************************************************************************
374  *
375  * FUNCTION:    AcpiDbDisplayMethodInfo
376  *
377  * PARAMETERS:  StartOp         - Root of the control method parse tree
378  *
379  * RETURN:      None
380  *
381  * DESCRIPTION: Display information about the current method
382  *
383  ******************************************************************************/
384 
385 void
386 AcpiDbDisplayMethodInfo (
387     ACPI_PARSE_OBJECT       *StartOp)
388 {
389     ACPI_WALK_STATE         *WalkState;
390     ACPI_OPERAND_OBJECT     *ObjDesc;
391     ACPI_NAMESPACE_NODE     *Node;
392     ACPI_PARSE_OBJECT       *RootOp;
393     ACPI_PARSE_OBJECT       *Op;
394     const ACPI_OPCODE_INFO  *OpInfo;
395     UINT32                  NumOps = 0;
396     UINT32                  NumOperands = 0;
397     UINT32                  NumOperators = 0;
398     UINT32                  NumRemainingOps = 0;
399     UINT32                  NumRemainingOperands = 0;
400     UINT32                  NumRemainingOperators = 0;
401     BOOLEAN                 CountRemaining = FALSE;
402 
403 
404     WalkState = AcpiDsGetCurrentWalkState (AcpiGbl_CurrentWalkList);
405     if (!WalkState)
406     {
407         AcpiOsPrintf ("There is no method currently executing\n");
408         return;
409     }
410 
411     ObjDesc = WalkState->MethodDesc;
412     Node    = WalkState->MethodNode;
413 
414     AcpiOsPrintf ("Currently executing control method is [%4.4s]\n",
415             AcpiUtGetNodeName (Node));
416     AcpiOsPrintf ("%X Arguments, SyncLevel = %X\n",
417             (UINT32) ObjDesc->Method.ParamCount,
418             (UINT32) ObjDesc->Method.SyncLevel);
419 
420 
421     RootOp = StartOp;
422     while (RootOp->Common.Parent)
423     {
424         RootOp = RootOp->Common.Parent;
425     }
426 
427     Op = RootOp;
428 
429     while (Op)
430     {
431         if (Op == StartOp)
432         {
433             CountRemaining = TRUE;
434         }
435 
436         NumOps++;
437         if (CountRemaining)
438         {
439             NumRemainingOps++;
440         }
441 
442         /* Decode the opcode */
443 
444         OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode);
445         switch (OpInfo->Class)
446         {
447         case AML_CLASS_ARGUMENT:
448 
449             if (CountRemaining)
450             {
451                 NumRemainingOperands++;
452             }
453 
454             NumOperands++;
455             break;
456 
457         case AML_CLASS_UNKNOWN:
458 
459             /* Bad opcode or ASCII character */
460 
461             continue;
462 
463         default:
464 
465             if (CountRemaining)
466             {
467                 NumRemainingOperators++;
468             }
469 
470             NumOperators++;
471             break;
472         }
473 
474         Op = AcpiPsGetDepthNext (StartOp, Op);
475     }
476 
477     AcpiOsPrintf (
478         "Method contains:       %X AML Opcodes - %X Operators, %X Operands\n",
479         NumOps, NumOperators, NumOperands);
480 
481     AcpiOsPrintf (
482         "Remaining to execute:  %X AML Opcodes - %X Operators, %X Operands\n",
483         NumRemainingOps, NumRemainingOperators, NumRemainingOperands);
484 }
485 
486 
487 /*******************************************************************************
488  *
489  * FUNCTION:    AcpiDbDisplayLocals
490  *
491  * PARAMETERS:  None
492  *
493  * RETURN:      None
494  *
495  * DESCRIPTION: Display all locals for the currently running control method
496  *
497  ******************************************************************************/
498 
499 void
500 AcpiDbDisplayLocals (
501     void)
502 {
503     ACPI_WALK_STATE         *WalkState;
504 
505 
506     WalkState = AcpiDsGetCurrentWalkState (AcpiGbl_CurrentWalkList);
507     if (!WalkState)
508     {
509         AcpiOsPrintf ("There is no method currently executing\n");
510         return;
511     }
512 
513     AcpiDmDisplayLocals (WalkState);
514 }
515 
516 
517 /*******************************************************************************
518  *
519  * FUNCTION:    AcpiDbDisplayArguments
520  *
521  * PARAMETERS:  None
522  *
523  * RETURN:      None
524  *
525  * DESCRIPTION: Display all arguments for the currently running control method
526  *
527  ******************************************************************************/
528 
529 void
530 AcpiDbDisplayArguments (
531     void)
532 {
533     ACPI_WALK_STATE         *WalkState;
534 
535 
536     WalkState = AcpiDsGetCurrentWalkState (AcpiGbl_CurrentWalkList);
537     if (!WalkState)
538     {
539         AcpiOsPrintf ("There is no method currently executing\n");
540         return;
541     }
542 
543     AcpiDmDisplayArguments (WalkState);
544 }
545 
546 
547 /*******************************************************************************
548  *
549  * FUNCTION:    AcpiDbDisplayResults
550  *
551  * PARAMETERS:  None
552  *
553  * RETURN:      None
554  *
555  * DESCRIPTION: Display current contents of a method result stack
556  *
557  ******************************************************************************/
558 
559 void
560 AcpiDbDisplayResults (
561     void)
562 {
563     UINT32                  i;
564     ACPI_WALK_STATE         *WalkState;
565     ACPI_OPERAND_OBJECT     *ObjDesc;
566     UINT32                  ResultCount = 0;
567     ACPI_NAMESPACE_NODE     *Node;
568     ACPI_GENERIC_STATE      *Frame;
569     UINT32                  Index; /* Index onto current frame */
570 
571 
572     WalkState = AcpiDsGetCurrentWalkState (AcpiGbl_CurrentWalkList);
573     if (!WalkState)
574     {
575         AcpiOsPrintf ("There is no method currently executing\n");
576         return;
577     }
578 
579     ObjDesc = WalkState->MethodDesc;
580     Node    = WalkState->MethodNode;
581 
582     if (WalkState->Results)
583     {
584         ResultCount = WalkState->ResultCount;
585     }
586 
587     AcpiOsPrintf ("Method [%4.4s] has %X stacked result objects\n",
588             AcpiUtGetNodeName (Node), ResultCount);
589 
590     /* From the top element of result stack */
591 
592     Frame = WalkState->Results;
593     Index = (ResultCount - 1) % ACPI_RESULTS_FRAME_OBJ_NUM;
594 
595     for (i = 0; i < ResultCount; i++)
596     {
597         ObjDesc = Frame->Results.ObjDesc[Index];
598         AcpiOsPrintf ("Result%u: ", i);
599         AcpiDmDisplayInternalObject (ObjDesc, WalkState);
600         if (Index == 0)
601         {
602             Frame = Frame->Results.Next;
603             Index = ACPI_RESULTS_FRAME_OBJ_NUM;
604         }
605         Index--;
606     }
607 }
608 
609 
610 /*******************************************************************************
611  *
612  * FUNCTION:    AcpiDbDisplayCallingTree
613  *
614  * PARAMETERS:  None
615  *
616  * RETURN:      None
617  *
618  * DESCRIPTION: Display current calling tree of nested control methods
619  *
620  ******************************************************************************/
621 
622 void
623 AcpiDbDisplayCallingTree (
624     void)
625 {
626     ACPI_WALK_STATE         *WalkState;
627     ACPI_NAMESPACE_NODE     *Node;
628 
629 
630     WalkState = AcpiDsGetCurrentWalkState (AcpiGbl_CurrentWalkList);
631     if (!WalkState)
632     {
633         AcpiOsPrintf ("There is no method currently executing\n");
634         return;
635     }
636 
637     Node = WalkState->MethodNode;
638     AcpiOsPrintf ("Current Control Method Call Tree\n");
639 
640     while (WalkState)
641     {
642         Node = WalkState->MethodNode;
643 
644         AcpiOsPrintf ("    [%4.4s]\n", AcpiUtGetNodeName (Node));
645 
646         WalkState = WalkState->Next;
647     }
648 }
649 
650 
651 /*******************************************************************************
652  *
653  * FUNCTION:    AcpiDbDisplayObjectType
654  *
655  * PARAMETERS:  Name            - User entered NS node handle or name
656  *
657  * RETURN:      None
658  *
659  * DESCRIPTION: Display type of an arbitrary NS node
660  *
661  ******************************************************************************/
662 
663 void
664 AcpiDbDisplayObjectType (
665     char                    *Name)
666 {
667     ACPI_NAMESPACE_NODE     *Node;
668     ACPI_DEVICE_INFO        *Info;
669     ACPI_STATUS             Status;
670     UINT32                  i;
671 
672 
673     Node = AcpiDbConvertToNode (Name);
674     if (!Node)
675     {
676         return;
677     }
678 
679     Status = AcpiGetObjectInfo (ACPI_CAST_PTR (ACPI_HANDLE, Node), &Info);
680     if (ACPI_FAILURE (Status))
681     {
682         AcpiOsPrintf ("Could not get object info, %s\n",
683             AcpiFormatException (Status));
684         return;
685     }
686 
687     if (Info->Valid & ACPI_VALID_ADR)
688     {
689         AcpiOsPrintf ("ADR: %8.8X%8.8X, STA: %8.8X, Flags: %X\n",
690             ACPI_FORMAT_UINT64 (Info->Address),
691             Info->CurrentStatus, Info->Flags);
692     }
693     if (Info->Valid & ACPI_VALID_SXDS)
694     {
695         AcpiOsPrintf ("S1D-%2.2X S2D-%2.2X S3D-%2.2X S4D-%2.2X\n",
696             Info->HighestDstates[0], Info->HighestDstates[1],
697             Info->HighestDstates[2], Info->HighestDstates[3]);
698     }
699     if (Info->Valid & ACPI_VALID_SXWS)
700     {
701         AcpiOsPrintf ("S0W-%2.2X S1W-%2.2X S2W-%2.2X S3W-%2.2X S4W-%2.2X\n",
702             Info->LowestDstates[0], Info->LowestDstates[1],
703             Info->LowestDstates[2], Info->LowestDstates[3],
704             Info->LowestDstates[4]);
705     }
706 
707     if (Info->Valid & ACPI_VALID_HID)
708     {
709         AcpiOsPrintf ("HID: %s\n", Info->HardwareId.String);
710     }
711     if (Info->Valid & ACPI_VALID_UID)
712     {
713         AcpiOsPrintf ("UID: %s\n", Info->UniqueId.String);
714     }
715     if (Info->Valid & ACPI_VALID_SUB)
716     {
717         AcpiOsPrintf ("SUB: %s\n", Info->SubsystemId.String);
718     }
719     if (Info->Valid & ACPI_VALID_CID)
720     {
721         for (i = 0; i < Info->CompatibleIdList.Count; i++)
722         {
723             AcpiOsPrintf ("CID %u: %s\n", i,
724                 Info->CompatibleIdList.Ids[i].String);
725         }
726     }
727 
728     ACPI_FREE (Info);
729 }
730 
731 
732 /*******************************************************************************
733  *
734  * FUNCTION:    AcpiDbDisplayResultObject
735  *
736  * PARAMETERS:  ObjDesc         - Object to be displayed
737  *              WalkState       - Current walk state
738  *
739  * RETURN:      None
740  *
741  * DESCRIPTION: Display the result of an AML opcode
742  *
743  * Note: Curently only displays the result object if we are single stepping.
744  * However, this output may be useful in other contexts and could be enabled
745  * to do so if needed.
746  *
747  ******************************************************************************/
748 
749 void
750 AcpiDbDisplayResultObject (
751     ACPI_OPERAND_OBJECT     *ObjDesc,
752     ACPI_WALK_STATE         *WalkState)
753 {
754 
755     /* Only display if single stepping */
756 
757     if (!AcpiGbl_CmSingleStep)
758     {
759         return;
760     }
761 
762     AcpiOsPrintf ("ResultObj: ");
763     AcpiDmDisplayInternalObject (ObjDesc, WalkState);
764     AcpiOsPrintf ("\n");
765 }
766 
767 
768 /*******************************************************************************
769  *
770  * FUNCTION:    AcpiDbDisplayArgumentObject
771  *
772  * PARAMETERS:  ObjDesc         - Object to be displayed
773  *              WalkState       - Current walk state
774  *
775  * RETURN:      None
776  *
777  * DESCRIPTION: Display the result of an AML opcode
778  *
779  ******************************************************************************/
780 
781 void
782 AcpiDbDisplayArgumentObject (
783     ACPI_OPERAND_OBJECT     *ObjDesc,
784     ACPI_WALK_STATE         *WalkState)
785 {
786 
787     if (!AcpiGbl_CmSingleStep)
788     {
789         return;
790     }
791 
792     AcpiOsPrintf ("ArgObj:    ");
793     AcpiDmDisplayInternalObject (ObjDesc, WalkState);
794 }
795 
796 
797 #if (!ACPI_REDUCED_HARDWARE)
798 /*******************************************************************************
799  *
800  * FUNCTION:    AcpiDbDisplayGpes
801  *
802  * PARAMETERS:  None
803  *
804  * RETURN:      None
805  *
806  * DESCRIPTION: Display the current GPE structures
807  *
808  ******************************************************************************/
809 
810 void
811 AcpiDbDisplayGpes (
812     void)
813 {
814     ACPI_GPE_BLOCK_INFO     *GpeBlock;
815     ACPI_GPE_XRUPT_INFO     *GpeXruptInfo;
816     ACPI_GPE_EVENT_INFO     *GpeEventInfo;
817     ACPI_GPE_REGISTER_INFO  *GpeRegisterInfo;
818     char                    *GpeType;
819     ACPI_GPE_NOTIFY_INFO    *Notify;
820     UINT32                  GpeIndex;
821     UINT32                  Block = 0;
822     UINT32                  i;
823     UINT32                  j;
824     UINT32                  Count;
825     char                    Buffer[80];
826     ACPI_BUFFER             RetBuf;
827     ACPI_STATUS             Status;
828 
829 
830     RetBuf.Length = sizeof (Buffer);
831     RetBuf.Pointer = Buffer;
832 
833     Block = 0;
834 
835     /* Walk the GPE lists */
836 
837     GpeXruptInfo = AcpiGbl_GpeXruptListHead;
838     while (GpeXruptInfo)
839     {
840         GpeBlock = GpeXruptInfo->GpeBlockListHead;
841         while (GpeBlock)
842         {
843             Status = AcpiGetName (GpeBlock->Node, ACPI_FULL_PATHNAME, &RetBuf);
844             if (ACPI_FAILURE (Status))
845             {
846                 AcpiOsPrintf ("Could not convert name to pathname\n");
847             }
848 
849             if (GpeBlock->Node == AcpiGbl_FadtGpeDevice)
850             {
851                 GpeType = "FADT-defined GPE block";
852             }
853             else
854             {
855                 GpeType = "GPE Block Device";
856             }
857 
858             AcpiOsPrintf ("\nBlock %u - Info %p  DeviceNode %p [%s] - %s\n",
859                 Block, GpeBlock, GpeBlock->Node, Buffer, GpeType);
860 
861             AcpiOsPrintf ("    Registers:    %u (%u GPEs)\n",
862                 GpeBlock->RegisterCount, GpeBlock->GpeCount);
863 
864             AcpiOsPrintf ("    GPE range:    0x%X to 0x%X on interrupt %u\n",
865                 GpeBlock->BlockBaseNumber,
866                 GpeBlock->BlockBaseNumber + (GpeBlock->GpeCount - 1),
867                 GpeXruptInfo->InterruptNumber);
868 
869             AcpiOsPrintf (
870                 "    RegisterInfo: %p  Status %8.8X%8.8X Enable %8.8X%8.8X\n",
871                 GpeBlock->RegisterInfo,
872                 ACPI_FORMAT_UINT64 (GpeBlock->RegisterInfo->StatusAddress.Address),
873                 ACPI_FORMAT_UINT64 (GpeBlock->RegisterInfo->EnableAddress.Address));
874 
875             AcpiOsPrintf ("    EventInfo:    %p\n", GpeBlock->EventInfo);
876 
877             /* Examine each GPE Register within the block */
878 
879             for (i = 0; i < GpeBlock->RegisterCount; i++)
880             {
881                 GpeRegisterInfo = &GpeBlock->RegisterInfo[i];
882 
883                 AcpiOsPrintf (
884                     "    Reg %u: (GPE %.2X-%.2X)  RunEnable %2.2X WakeEnable %2.2X"
885                     " Status %8.8X%8.8X Enable %8.8X%8.8X\n",
886                     i, GpeRegisterInfo->BaseGpeNumber,
887                     GpeRegisterInfo->BaseGpeNumber + (ACPI_GPE_REGISTER_WIDTH - 1),
888                     GpeRegisterInfo->EnableForRun,
889                     GpeRegisterInfo->EnableForWake,
890                     ACPI_FORMAT_UINT64 (GpeRegisterInfo->StatusAddress.Address),
891                     ACPI_FORMAT_UINT64 (GpeRegisterInfo->EnableAddress.Address));
892 
893                 /* Now look at the individual GPEs in this byte register */
894 
895                 for (j = 0; j < ACPI_GPE_REGISTER_WIDTH; j++)
896                 {
897                     GpeIndex = (i * ACPI_GPE_REGISTER_WIDTH) + j;
898                     GpeEventInfo = &GpeBlock->EventInfo[GpeIndex];
899 
900                     if ((GpeEventInfo->Flags & ACPI_GPE_DISPATCH_MASK) ==
901                         ACPI_GPE_DISPATCH_NONE)
902                     {
903                         /* This GPE is not used (no method or handler), ignore it */
904 
905                         continue;
906                     }
907 
908                     AcpiOsPrintf (
909                         "        GPE %.2X: %p  RunRefs %2.2X Flags %2.2X (",
910                         GpeBlock->BlockBaseNumber + GpeIndex, GpeEventInfo,
911                         GpeEventInfo->RuntimeCount, GpeEventInfo->Flags);
912 
913                     /* Decode the flags byte */
914 
915                     if (GpeEventInfo->Flags & ACPI_GPE_LEVEL_TRIGGERED)
916                     {
917                         AcpiOsPrintf ("Level, ");
918                     }
919                     else
920                     {
921                         AcpiOsPrintf ("Edge,  ");
922                     }
923 
924                     if (GpeEventInfo->Flags & ACPI_GPE_CAN_WAKE)
925                     {
926                         AcpiOsPrintf ("CanWake, ");
927                     }
928                     else
929                     {
930                         AcpiOsPrintf ("RunOnly, ");
931                     }
932 
933                     switch (GpeEventInfo->Flags & ACPI_GPE_DISPATCH_MASK)
934                     {
935                     case ACPI_GPE_DISPATCH_NONE:
936 
937                         AcpiOsPrintf ("NotUsed");
938                         break;
939 
940                     case ACPI_GPE_DISPATCH_METHOD:
941 
942                         AcpiOsPrintf ("Method");
943                         break;
944                     case ACPI_GPE_DISPATCH_HANDLER:
945 
946                         AcpiOsPrintf ("Handler");
947                         break;
948 
949                     case ACPI_GPE_DISPATCH_NOTIFY:
950 
951                         Count = 0;
952                         Notify = GpeEventInfo->Dispatch.NotifyList;
953                         while (Notify)
954                         {
955                             Count++;
956                             Notify = Notify->Next;
957                         }
958                         AcpiOsPrintf ("Implicit Notify on %u devices", Count);
959                         break;
960 
961                     default:
962 
963                         AcpiOsPrintf ("UNKNOWN: %X",
964                             GpeEventInfo->Flags & ACPI_GPE_DISPATCH_MASK);
965                         break;
966                     }
967 
968                     AcpiOsPrintf (")\n");
969                 }
970             }
971             Block++;
972             GpeBlock = GpeBlock->Next;
973         }
974         GpeXruptInfo = GpeXruptInfo->Next;
975     }
976 }
977 #endif /* !ACPI_REDUCED_HARDWARE */
978 
979 
980 /*******************************************************************************
981  *
982  * FUNCTION:    AcpiDbDisplayHandlers
983  *
984  * PARAMETERS:  None
985  *
986  * RETURN:      None
987  *
988  * DESCRIPTION: Display the currently installed global handlers
989  *
990  ******************************************************************************/
991 
992 void
993 AcpiDbDisplayHandlers (
994     void)
995 {
996     ACPI_OPERAND_OBJECT     *ObjDesc;
997     ACPI_OPERAND_OBJECT     *HandlerObj;
998     ACPI_ADR_SPACE_TYPE     SpaceId;
999     UINT32                  i;
1000 
1001 
1002     /* Operation region handlers */
1003 
1004     AcpiOsPrintf ("\nOperation Region Handlers at the namespace root:\n");
1005 
1006     ObjDesc = AcpiNsGetAttachedObject (AcpiGbl_RootNode);
1007     if (ObjDesc)
1008     {
1009         for (i = 0; i < ACPI_ARRAY_LENGTH (AcpiGbl_SpaceIdList); i++)
1010         {
1011             SpaceId = AcpiGbl_SpaceIdList[i];
1012             HandlerObj = ObjDesc->Device.Handler;
1013 
1014             AcpiOsPrintf (ACPI_PREDEFINED_PREFIX,
1015                 AcpiUtGetRegionName ((UINT8) SpaceId), SpaceId);
1016 
1017             while (HandlerObj)
1018             {
1019                 if (AcpiGbl_SpaceIdList[i] == HandlerObj->AddressSpace.SpaceId)
1020                 {
1021                     AcpiOsPrintf (ACPI_HANDLER_PRESENT_STRING,
1022                         (HandlerObj->AddressSpace.HandlerFlags &
1023                             ACPI_ADDR_HANDLER_DEFAULT_INSTALLED) ? "Default" : "User",
1024                         HandlerObj->AddressSpace.Handler);
1025                     goto FoundHandler;
1026                 }
1027 
1028                 HandlerObj = HandlerObj->AddressSpace.Next;
1029             }
1030 
1031             /* There is no handler for this SpaceId */
1032 
1033             AcpiOsPrintf ("None\n");
1034 
1035         FoundHandler:;
1036         }
1037 
1038         /* Find all handlers for user-defined SpaceIDs */
1039 
1040         HandlerObj = ObjDesc->Device.Handler;
1041         while (HandlerObj)
1042         {
1043             if (HandlerObj->AddressSpace.SpaceId >= ACPI_USER_REGION_BEGIN)
1044             {
1045                 AcpiOsPrintf (ACPI_PREDEFINED_PREFIX,
1046                     "User-defined ID", HandlerObj->AddressSpace.SpaceId);
1047                 AcpiOsPrintf (ACPI_HANDLER_PRESENT_STRING,
1048                     (HandlerObj->AddressSpace.HandlerFlags &
1049                         ACPI_ADDR_HANDLER_DEFAULT_INSTALLED) ? "Default" : "User",
1050                     HandlerObj->AddressSpace.Handler);
1051             }
1052 
1053             HandlerObj = HandlerObj->AddressSpace.Next;
1054         }
1055     }
1056 
1057 #if (!ACPI_REDUCED_HARDWARE)
1058 
1059     /* Fixed event handlers */
1060 
1061     AcpiOsPrintf ("\nFixed Event Handlers:\n");
1062 
1063     for (i = 0; i < ACPI_NUM_FIXED_EVENTS; i++)
1064     {
1065         AcpiOsPrintf (ACPI_PREDEFINED_PREFIX, AcpiUtGetEventName (i), i);
1066         if (AcpiGbl_FixedEventHandlers[i].Handler)
1067         {
1068             AcpiOsPrintf (ACPI_HANDLER_PRESENT_STRING, "User",
1069                 AcpiGbl_FixedEventHandlers[i].Handler);
1070         }
1071         else
1072         {
1073             AcpiOsPrintf (ACPI_HANDLER_NOT_PRESENT_STRING, "None");
1074         }
1075     }
1076 
1077 #endif /* !ACPI_REDUCED_HARDWARE */
1078 
1079     /* Miscellaneous global handlers */
1080 
1081     AcpiOsPrintf ("\nMiscellaneous Global Handlers:\n");
1082 
1083     for (i = 0; i < ACPI_ARRAY_LENGTH (AcpiGbl_HandlerList); i++)
1084     {
1085         AcpiOsPrintf (ACPI_HANDLER_NAME_STRING, AcpiGbl_HandlerList[i].Name);
1086         if (AcpiGbl_HandlerList[i].Handler)
1087         {
1088             AcpiOsPrintf (ACPI_HANDLER_PRESENT_STRING, "User",
1089                 AcpiGbl_HandlerList[i].Handler);
1090         }
1091         else
1092         {
1093             AcpiOsPrintf (ACPI_HANDLER_NOT_PRESENT_STRING, "None");
1094         }
1095     }
1096 
1097 
1098     /* Other handlers that are installed throughout the namespace */
1099 
1100     AcpiOsPrintf ("\nOperation Region Handlers for specific devices:\n");
1101 
1102     (void) AcpiWalkNamespace (ACPI_TYPE_DEVICE, ACPI_ROOT_OBJECT,
1103                 ACPI_UINT32_MAX, AcpiDbDisplayNonRootHandlers,
1104                 NULL, NULL, NULL);
1105 }
1106 
1107 
1108 /*******************************************************************************
1109  *
1110  * FUNCTION:    AcpiDbDisplayNonRootHandlers
1111  *
1112  * PARAMETERS:  ACPI_WALK_CALLBACK
1113  *
1114  * RETURN:      Status
1115  *
1116  * DESCRIPTION: Display information about all handlers installed for a
1117  *              device object.
1118  *
1119  ******************************************************************************/
1120 
1121 static ACPI_STATUS
1122 AcpiDbDisplayNonRootHandlers (
1123     ACPI_HANDLE             ObjHandle,
1124     UINT32                  NestingLevel,
1125     void                    *Context,
1126     void                    **ReturnValue)
1127 {
1128     ACPI_NAMESPACE_NODE     *Node = ACPI_CAST_PTR (ACPI_NAMESPACE_NODE, ObjHandle);
1129     ACPI_OPERAND_OBJECT     *ObjDesc;
1130     ACPI_OPERAND_OBJECT     *HandlerObj;
1131     char                    *Pathname;
1132 
1133 
1134     ObjDesc = AcpiNsGetAttachedObject (Node);
1135     if (!ObjDesc)
1136     {
1137         return (AE_OK);
1138     }
1139 
1140     Pathname = AcpiNsGetExternalPathname (Node);
1141     if (!Pathname)
1142     {
1143         return (AE_OK);
1144     }
1145 
1146     /* Display all handlers associated with this device */
1147 
1148     HandlerObj = ObjDesc->Device.Handler;
1149     while (HandlerObj)
1150     {
1151         AcpiOsPrintf (ACPI_PREDEFINED_PREFIX,
1152             AcpiUtGetRegionName ((UINT8) HandlerObj->AddressSpace.SpaceId),
1153             HandlerObj->AddressSpace.SpaceId);
1154 
1155         AcpiOsPrintf (ACPI_HANDLER_PRESENT_STRING2,
1156             (HandlerObj->AddressSpace.HandlerFlags &
1157                 ACPI_ADDR_HANDLER_DEFAULT_INSTALLED) ? "Default" : "User",
1158             HandlerObj->AddressSpace.Handler);
1159 
1160         AcpiOsPrintf (" Device Name: %s (%p)\n", Pathname, Node);
1161 
1162         HandlerObj = HandlerObj->AddressSpace.Next;
1163     }
1164 
1165     ACPI_FREE (Pathname);
1166     return (AE_OK);
1167 }
1168 
1169 #endif /* ACPI_DEBUGGER */
1170