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