xref: /freebsd/sys/contrib/dev/acpica/components/disassembler/dmopcode.c (revision ec0e626bafb335b30c499d06066997f54b10c092)
1 /*******************************************************************************
2  *
3  * Module Name: dmopcode - AML disassembler, specific AML opcodes
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 <contrib/dev/acpica/include/acpi.h>
45 #include <contrib/dev/acpica/include/accommon.h>
46 #include <contrib/dev/acpica/include/acparser.h>
47 #include <contrib/dev/acpica/include/amlcode.h>
48 #include <contrib/dev/acpica/include/acdisasm.h>
49 #include <contrib/dev/acpica/include/acinterp.h>
50 #include <contrib/dev/acpica/include/acnamesp.h>
51 
52 #ifdef ACPI_DISASSEMBLER
53 
54 #define _COMPONENT          ACPI_CA_DEBUGGER
55         ACPI_MODULE_NAME    ("dmopcode")
56 
57 
58 /* Local prototypes */
59 
60 static void
61 AcpiDmMatchKeyword (
62     ACPI_PARSE_OBJECT       *Op);
63 
64 
65 /*******************************************************************************
66  *
67  * FUNCTION:    AcpiDmDisplayTargetPathname
68  *
69  * PARAMETERS:  Op              - Parse object
70  *
71  * RETURN:      None
72  *
73  * DESCRIPTION: For AML opcodes that have a target operand, display the full
74  *              pathname for the target, in a comment field. Handles Return()
75  *              statements also.
76  *
77  ******************************************************************************/
78 
79 void
80 AcpiDmDisplayTargetPathname (
81     ACPI_PARSE_OBJECT       *Op)
82 {
83     ACPI_PARSE_OBJECT       *NextOp;
84     ACPI_PARSE_OBJECT       *PrevOp = NULL;
85     char                    *Pathname;
86     const ACPI_OPCODE_INFO  *OpInfo;
87 
88 
89     if (Op->Common.AmlOpcode == AML_RETURN_OP)
90     {
91         PrevOp = Op->Asl.Value.Arg;
92     }
93     else
94     {
95         OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode);
96         if (!(OpInfo->Flags & AML_HAS_TARGET))
97         {
98             return;
99         }
100 
101         /* Target is the last Op in the arg list */
102 
103         NextOp = Op->Asl.Value.Arg;
104         while (NextOp)
105         {
106             PrevOp = NextOp;
107             NextOp = PrevOp->Asl.Next;
108         }
109     }
110 
111     if (!PrevOp)
112     {
113         return;
114     }
115 
116     /* We must have a namepath AML opcode */
117 
118     if (PrevOp->Asl.AmlOpcode != AML_INT_NAMEPATH_OP)
119     {
120         return;
121     }
122 
123     /* A null string is the "no target specified" case */
124 
125     if (!PrevOp->Asl.Value.String)
126     {
127         return;
128     }
129 
130     /* No node means "unresolved external reference" */
131 
132     if (!PrevOp->Asl.Node)
133     {
134         AcpiOsPrintf (" /* External reference */");
135         return;
136     }
137 
138     /* Ignore if path is already from the root */
139 
140     if (*PrevOp->Asl.Value.String == '\\')
141     {
142         return;
143     }
144 
145     /* Now: we can get the full pathname */
146 
147     Pathname = AcpiNsGetExternalPathname (PrevOp->Asl.Node);
148     if (!Pathname)
149     {
150         return;
151     }
152 
153     AcpiOsPrintf (" /* %s */", Pathname);
154     ACPI_FREE (Pathname);
155 }
156 
157 
158 /*******************************************************************************
159  *
160  * FUNCTION:    AcpiDmNotifyDescription
161  *
162  * PARAMETERS:  Op              - Name() parse object
163  *
164  * RETURN:      None
165  *
166  * DESCRIPTION: Emit a description comment for the value associated with a
167  *              Notify() operator.
168  *
169  ******************************************************************************/
170 
171 void
172 AcpiDmNotifyDescription (
173     ACPI_PARSE_OBJECT       *Op)
174 {
175     ACPI_PARSE_OBJECT       *NextOp;
176     ACPI_NAMESPACE_NODE     *Node;
177     UINT8                   NotifyValue;
178     UINT8                   Type = ACPI_TYPE_ANY;
179 
180 
181     /* The notify value is the second argument */
182 
183     NextOp = Op->Asl.Value.Arg;
184     NextOp = NextOp->Asl.Next;
185 
186     switch (NextOp->Common.AmlOpcode)
187     {
188     case AML_ZERO_OP:
189     case AML_ONE_OP:
190 
191         NotifyValue = (UINT8) NextOp->Common.AmlOpcode;
192         break;
193 
194     case AML_BYTE_OP:
195 
196         NotifyValue = (UINT8) NextOp->Asl.Value.Integer;
197         break;
198 
199     default:
200         return;
201     }
202 
203     /*
204      * Attempt to get the namespace node so we can determine the object type.
205      * Some notify values are dependent on the object type (Device, Thermal,
206      * or Processor).
207      */
208     Node = Op->Asl.Node;
209     if (Node)
210     {
211         Type = Node->Type;
212     }
213 
214     AcpiOsPrintf (" // %s", AcpiUtGetNotifyName (NotifyValue, Type));
215 }
216 
217 
218 /*******************************************************************************
219  *
220  * FUNCTION:    AcpiDmPredefinedDescription
221  *
222  * PARAMETERS:  Op              - Name() parse object
223  *
224  * RETURN:      None
225  *
226  * DESCRIPTION: Emit a description comment for a predefined ACPI name.
227  *              Used for iASL compiler only.
228  *
229  ******************************************************************************/
230 
231 void
232 AcpiDmPredefinedDescription (
233     ACPI_PARSE_OBJECT       *Op)
234 {
235 #ifdef ACPI_ASL_COMPILER
236     const AH_PREDEFINED_NAME    *Info;
237     char                        *NameString;
238     int                         LastCharIsDigit;
239     int                         LastCharsAreHex;
240 
241 
242     if (!Op)
243     {
244         return;
245     }
246 
247     /* Ensure that the comment field is emitted only once */
248 
249     if (Op->Common.DisasmFlags & ACPI_PARSEOP_PREDEF_CHECKED)
250     {
251         return;
252     }
253     Op->Common.DisasmFlags |= ACPI_PARSEOP_PREDEF_CHECKED;
254 
255     /* Predefined name must start with an underscore */
256 
257     NameString = ACPI_CAST_PTR (char, &Op->Named.Name);
258     if (NameString[0] != '_')
259     {
260         return;
261     }
262 
263     /*
264      * Check for the special ACPI names:
265      * _ACd, _ALd, _EJd, _Exx, _Lxx, _Qxx, _Wxx, _T_a
266      * (where d=decimal_digit, x=hex_digit, a=anything)
267      *
268      * Convert these to the generic name for table lookup.
269      * Note: NameString is guaranteed to be upper case here.
270      */
271     LastCharIsDigit =
272         (ACPI_IS_DIGIT (NameString[3]));    /* d */
273     LastCharsAreHex =
274         (ACPI_IS_XDIGIT (NameString[2]) &&  /* xx */
275          ACPI_IS_XDIGIT (NameString[3]));
276 
277     switch (NameString[1])
278     {
279     case 'A':
280 
281         if ((NameString[2] == 'C') && (LastCharIsDigit))
282         {
283             NameString = "_ACx";
284         }
285         else if ((NameString[2] == 'L') && (LastCharIsDigit))
286         {
287             NameString = "_ALx";
288         }
289         break;
290 
291     case 'E':
292 
293         if ((NameString[2] == 'J') && (LastCharIsDigit))
294         {
295             NameString = "_EJx";
296         }
297         else if (LastCharsAreHex)
298         {
299             NameString = "_Exx";
300         }
301         break;
302 
303     case 'L':
304 
305         if (LastCharsAreHex)
306         {
307             NameString = "_Lxx";
308         }
309         break;
310 
311     case 'Q':
312 
313         if (LastCharsAreHex)
314         {
315             NameString = "_Qxx";
316         }
317         break;
318 
319     case 'T':
320 
321         if (NameString[2] == '_')
322         {
323             NameString = "_T_x";
324         }
325         break;
326 
327     case 'W':
328 
329         if (LastCharsAreHex)
330         {
331             NameString = "_Wxx";
332         }
333         break;
334 
335     default:
336 
337         break;
338     }
339 
340     /* Match the name in the info table */
341 
342     Info = AcpiAhMatchPredefinedName (NameString);
343     if (Info)
344     {
345         AcpiOsPrintf ("  // %4.4s: %s",
346             NameString, ACPI_CAST_PTR (char, Info->Description));
347     }
348 
349 #endif
350     return;
351 }
352 
353 
354 /*******************************************************************************
355  *
356  * FUNCTION:    AcpiDmFieldPredefinedDescription
357  *
358  * PARAMETERS:  Op              - Parse object
359  *
360  * RETURN:      None
361  *
362  * DESCRIPTION: Emit a description comment for a resource descriptor tag
363  *              (which is a predefined ACPI name.) Used for iASL compiler only.
364  *
365  ******************************************************************************/
366 
367 void
368 AcpiDmFieldPredefinedDescription (
369     ACPI_PARSE_OBJECT       *Op)
370 {
371 #ifdef ACPI_ASL_COMPILER
372     ACPI_PARSE_OBJECT       *IndexOp;
373     char                    *Tag;
374     const ACPI_OPCODE_INFO  *OpInfo;
375     const AH_PREDEFINED_NAME *Info;
376 
377 
378     if (!Op)
379     {
380         return;
381     }
382 
383     /* Ensure that the comment field is emitted only once */
384 
385     if (Op->Common.DisasmFlags & ACPI_PARSEOP_PREDEF_CHECKED)
386     {
387         return;
388     }
389     Op->Common.DisasmFlags |= ACPI_PARSEOP_PREDEF_CHECKED;
390 
391     /*
392      * Op must be one of the Create* operators: CreateField, CreateBitField,
393      * CreateByteField, CreateWordField, CreateDwordField, CreateQwordField
394      */
395     OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode);
396     if (!(OpInfo->Flags & AML_CREATE))
397     {
398         return;
399     }
400 
401     /* Second argument is the Index argument */
402 
403     IndexOp = Op->Common.Value.Arg;
404     IndexOp = IndexOp->Common.Next;
405 
406     /* Index argument must be a namepath */
407 
408     if (IndexOp->Common.AmlOpcode != AML_INT_NAMEPATH_OP)
409     {
410         return;
411     }
412 
413     /* Major cheat: We previously put the Tag ptr in the Node field */
414 
415     Tag = ACPI_CAST_PTR (char, IndexOp->Common.Node);
416     if (!Tag)
417     {
418         return;
419     }
420 
421     /* Match the name in the info table */
422 
423     Info = AcpiAhMatchPredefinedName (Tag);
424     if (Info)
425     {
426         AcpiOsPrintf ("  // %4.4s: %s", Tag,
427             ACPI_CAST_PTR (char, Info->Description));
428     }
429 
430 #endif
431     return;
432 }
433 
434 
435 /*******************************************************************************
436  *
437  * FUNCTION:    AcpiDmMethodFlags
438  *
439  * PARAMETERS:  Op              - Method Object to be examined
440  *
441  * RETURN:      None
442  *
443  * DESCRIPTION: Decode control method flags
444  *
445  ******************************************************************************/
446 
447 void
448 AcpiDmMethodFlags (
449     ACPI_PARSE_OBJECT       *Op)
450 {
451     UINT32                  Flags;
452     UINT32                  Args;
453 
454 
455     /* The next Op contains the flags */
456 
457     Op = AcpiPsGetDepthNext (NULL, Op);
458     Flags = (UINT8) Op->Common.Value.Integer;
459     Args = Flags & 0x07;
460 
461     /* Mark the Op as completed */
462 
463     Op->Common.DisasmFlags |= ACPI_PARSEOP_IGNORE;
464 
465     /* 1) Method argument count */
466 
467     AcpiOsPrintf (", %u, ", Args);
468 
469     /* 2) Serialize rule */
470 
471     if (!(Flags & 0x08))
472     {
473         AcpiOsPrintf ("Not");
474     }
475 
476     AcpiOsPrintf ("Serialized");
477 
478     /* 3) SyncLevel */
479 
480     if (Flags & 0xF0)
481     {
482         AcpiOsPrintf (", %u", Flags >> 4);
483     }
484 }
485 
486 
487 /*******************************************************************************
488  *
489  * FUNCTION:    AcpiDmFieldFlags
490  *
491  * PARAMETERS:  Op              - Field Object to be examined
492  *
493  * RETURN:      None
494  *
495  * DESCRIPTION: Decode Field definition flags
496  *
497  ******************************************************************************/
498 
499 void
500 AcpiDmFieldFlags (
501     ACPI_PARSE_OBJECT       *Op)
502 {
503     UINT32                  Flags;
504 
505 
506     Op = Op->Common.Next;
507     Flags = (UINT8) Op->Common.Value.Integer;
508 
509     /* Mark the Op as completed */
510 
511     Op->Common.DisasmFlags |= ACPI_PARSEOP_IGNORE;
512 
513     AcpiOsPrintf ("%s, ", AcpiGbl_AccessTypes [Flags & 0x07]);
514     AcpiOsPrintf ("%s, ", AcpiGbl_LockRule [(Flags & 0x10) >> 4]);
515     AcpiOsPrintf ("%s)",  AcpiGbl_UpdateRules [(Flags & 0x60) >> 5]);
516 }
517 
518 
519 /*******************************************************************************
520  *
521  * FUNCTION:    AcpiDmAddressSpace
522  *
523  * PARAMETERS:  SpaceId         - ID to be translated
524  *
525  * RETURN:      None
526  *
527  * DESCRIPTION: Decode a SpaceId to an AddressSpaceKeyword
528  *
529  ******************************************************************************/
530 
531 void
532 AcpiDmAddressSpace (
533     UINT8                   SpaceId)
534 {
535 
536     if (SpaceId >= ACPI_NUM_PREDEFINED_REGIONS)
537     {
538         if (SpaceId == 0x7F)
539         {
540             AcpiOsPrintf ("FFixedHW, ");
541         }
542         else
543         {
544             AcpiOsPrintf ("0x%.2X, ", SpaceId);
545         }
546     }
547     else
548     {
549         AcpiOsPrintf ("%s, ", AcpiGbl_RegionTypes [SpaceId]);
550     }
551 }
552 
553 
554 /*******************************************************************************
555  *
556  * FUNCTION:    AcpiDmRegionFlags
557  *
558  * PARAMETERS:  Op              - Object to be examined
559  *
560  * RETURN:      None
561  *
562  * DESCRIPTION: Decode OperationRegion flags
563  *
564  ******************************************************************************/
565 
566 void
567 AcpiDmRegionFlags (
568     ACPI_PARSE_OBJECT       *Op)
569 {
570 
571     /* The next Op contains the SpaceId */
572 
573     Op = AcpiPsGetDepthNext (NULL, Op);
574 
575     /* Mark the Op as completed */
576 
577     Op->Common.DisasmFlags |= ACPI_PARSEOP_IGNORE;
578 
579     AcpiOsPrintf (", ");
580     AcpiDmAddressSpace ((UINT8) Op->Common.Value.Integer);
581 }
582 
583 
584 /*******************************************************************************
585  *
586  * FUNCTION:    AcpiDmMatchOp
587  *
588  * PARAMETERS:  Op              - Match Object to be examined
589  *
590  * RETURN:      None
591  *
592  * DESCRIPTION: Decode Match opcode operands
593  *
594  ******************************************************************************/
595 
596 void
597 AcpiDmMatchOp (
598     ACPI_PARSE_OBJECT       *Op)
599 {
600     ACPI_PARSE_OBJECT       *NextOp;
601 
602 
603     NextOp = AcpiPsGetDepthNext (NULL, Op);
604     NextOp = NextOp->Common.Next;
605 
606     if (!NextOp)
607     {
608         /* Handle partial tree during single-step */
609 
610         return;
611     }
612 
613     /* Mark the two nodes that contain the encoding for the match keywords */
614 
615     NextOp->Common.DisasmOpcode = ACPI_DASM_MATCHOP;
616 
617     NextOp = NextOp->Common.Next;
618     NextOp = NextOp->Common.Next;
619     NextOp->Common.DisasmOpcode = ACPI_DASM_MATCHOP;
620 }
621 
622 
623 /*******************************************************************************
624  *
625  * FUNCTION:    AcpiDmMatchKeyword
626  *
627  * PARAMETERS:  Op              - Match Object to be examined
628  *
629  * RETURN:      None
630  *
631  * DESCRIPTION: Decode Match opcode operands
632  *
633  ******************************************************************************/
634 
635 static void
636 AcpiDmMatchKeyword (
637     ACPI_PARSE_OBJECT       *Op)
638 {
639 
640     if (((UINT32) Op->Common.Value.Integer) > ACPI_MAX_MATCH_OPCODE)
641     {
642         AcpiOsPrintf ("/* Unknown Match Keyword encoding */");
643     }
644     else
645     {
646         AcpiOsPrintf ("%s", ACPI_CAST_PTR (char,
647             AcpiGbl_MatchOps[(ACPI_SIZE) Op->Common.Value.Integer]));
648     }
649 }
650 
651 
652 /*******************************************************************************
653  *
654  * FUNCTION:    AcpiDmDisassembleOneOp
655  *
656  * PARAMETERS:  WalkState           - Current walk info
657  *              Info                - Parse tree walk info
658  *              Op                  - Op that is to be printed
659  *
660  * RETURN:      None
661  *
662  * DESCRIPTION: Disassemble a single AML opcode
663  *
664  ******************************************************************************/
665 
666 void
667 AcpiDmDisassembleOneOp (
668     ACPI_WALK_STATE         *WalkState,
669     ACPI_OP_WALK_INFO       *Info,
670     ACPI_PARSE_OBJECT       *Op)
671 {
672     const ACPI_OPCODE_INFO  *OpInfo = NULL;
673     UINT32                  Offset;
674     UINT32                  Length;
675     ACPI_PARSE_OBJECT       *Child;
676     ACPI_STATUS             Status;
677     UINT8                   *Aml;
678     const AH_DEVICE_ID      *IdInfo;
679 
680 
681     if (!Op)
682     {
683         AcpiOsPrintf ("<NULL OP PTR>");
684         return;
685     }
686 
687     switch (Op->Common.DisasmOpcode)
688     {
689     case ACPI_DASM_MATCHOP:
690 
691         AcpiDmMatchKeyword (Op);
692         return;
693 
694     case ACPI_DASM_LNOT_SUFFIX:
695 
696         if (!AcpiGbl_CstyleDisassembly)
697         {
698             switch (Op->Common.AmlOpcode)
699             {
700             case AML_LEQUAL_OP:
701                 AcpiOsPrintf ("LNotEqual");
702                 break;
703 
704             case AML_LGREATER_OP:
705                 AcpiOsPrintf ("LLessEqual");
706                 break;
707 
708             case AML_LLESS_OP:
709                 AcpiOsPrintf ("LGreaterEqual");
710                 break;
711 
712             default:
713                 break;
714             }
715         }
716 
717         Op->Common.DisasmOpcode = 0;
718         Op->Common.DisasmFlags |= ACPI_PARSEOP_IGNORE;
719         return;
720 
721     default:
722         break;
723     }
724 
725     OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode);
726 
727     /* The op and arguments */
728 
729     switch (Op->Common.AmlOpcode)
730     {
731     case AML_LNOT_OP:
732 
733         Child = Op->Common.Value.Arg;
734         if ((Child->Common.AmlOpcode == AML_LEQUAL_OP) ||
735             (Child->Common.AmlOpcode == AML_LGREATER_OP) ||
736             (Child->Common.AmlOpcode == AML_LLESS_OP))
737         {
738             Child->Common.DisasmOpcode = ACPI_DASM_LNOT_SUFFIX;
739             Op->Common.DisasmOpcode = ACPI_DASM_LNOT_PREFIX;
740         }
741         else
742         {
743             AcpiOsPrintf ("%s", OpInfo->Name);
744         }
745         break;
746 
747     case AML_BYTE_OP:
748 
749         AcpiOsPrintf ("0x%2.2X", (UINT32) Op->Common.Value.Integer);
750         break;
751 
752     case AML_WORD_OP:
753 
754         if (Op->Common.DisasmOpcode == ACPI_DASM_EISAID)
755         {
756             AcpiDmDecompressEisaId ((UINT32) Op->Common.Value.Integer);
757         }
758         else
759         {
760             AcpiOsPrintf ("0x%4.4X", (UINT32) Op->Common.Value.Integer);
761         }
762         break;
763 
764     case AML_DWORD_OP:
765 
766         if (Op->Common.DisasmOpcode == ACPI_DASM_EISAID)
767         {
768             AcpiDmDecompressEisaId ((UINT32) Op->Common.Value.Integer);
769         }
770         else
771         {
772             AcpiOsPrintf ("0x%8.8X", (UINT32) Op->Common.Value.Integer);
773         }
774         break;
775 
776     case AML_QWORD_OP:
777 
778         AcpiOsPrintf ("0x%8.8X%8.8X",
779             ACPI_FORMAT_UINT64 (Op->Common.Value.Integer));
780         break;
781 
782     case AML_STRING_OP:
783 
784         AcpiUtPrintString (Op->Common.Value.String, ACPI_UINT16_MAX);
785 
786         /* For _HID/_CID strings, attempt to output a descriptive comment */
787 
788         if (Op->Common.DisasmOpcode == ACPI_DASM_HID_STRING)
789         {
790             /* If we know about the ID, emit the description */
791 
792             IdInfo = AcpiAhMatchHardwareId (Op->Common.Value.String);
793             if (IdInfo)
794             {
795                 AcpiOsPrintf (" /* %s */", IdInfo->Description);
796             }
797         }
798         break;
799 
800     case AML_BUFFER_OP:
801         /*
802          * Determine the type of buffer. We can have one of the following:
803          *
804          * 1) ResourceTemplate containing Resource Descriptors.
805          * 2) Unicode String buffer
806          * 3) ASCII String buffer
807          * 4) Raw data buffer (if none of the above)
808          *
809          * Since there are no special AML opcodes to differentiate these
810          * types of buffers, we have to closely look at the data in the
811          * buffer to determine the type.
812          */
813         if (!AcpiGbl_NoResourceDisassembly)
814         {
815             Status = AcpiDmIsResourceTemplate (WalkState, Op);
816             if (ACPI_SUCCESS (Status))
817             {
818                 Op->Common.DisasmOpcode = ACPI_DASM_RESOURCE;
819                 AcpiOsPrintf ("ResourceTemplate");
820                 break;
821             }
822             else if (Status == AE_AML_NO_RESOURCE_END_TAG)
823             {
824                 AcpiOsPrintf ("/**** Is ResourceTemplate, but EndTag not at buffer end ****/ ");
825             }
826         }
827 
828         if (AcpiDmIsUuidBuffer (Op))
829         {
830             Op->Common.DisasmOpcode = ACPI_DASM_UUID;
831             AcpiOsPrintf ("ToUUID (");
832         }
833         else if (AcpiDmIsUnicodeBuffer (Op))
834         {
835             Op->Common.DisasmOpcode = ACPI_DASM_UNICODE;
836             AcpiOsPrintf ("Unicode (");
837         }
838         else if (AcpiDmIsStringBuffer (Op))
839         {
840             Op->Common.DisasmOpcode = ACPI_DASM_STRING;
841             AcpiOsPrintf ("Buffer");
842         }
843         else if (AcpiDmIsPldBuffer (Op))
844         {
845             Op->Common.DisasmOpcode = ACPI_DASM_PLD_METHOD;
846             AcpiOsPrintf ("ToPLD (");
847         }
848         else
849         {
850             Op->Common.DisasmOpcode = ACPI_DASM_BUFFER;
851             AcpiOsPrintf ("Buffer");
852         }
853         break;
854 
855     case AML_INT_STATICSTRING_OP:
856 
857         if (Op->Common.Value.String)
858         {
859             AcpiOsPrintf ("%s", Op->Common.Value.String);
860         }
861         else
862         {
863             AcpiOsPrintf ("\"<NULL STATIC STRING PTR>\"");
864         }
865         break;
866 
867     case AML_INT_NAMEPATH_OP:
868 
869         AcpiDmNamestring (Op->Common.Value.Name);
870         break;
871 
872     case AML_INT_NAMEDFIELD_OP:
873 
874         Length = AcpiDmDumpName (Op->Named.Name);
875         AcpiOsPrintf (",%*.s  %u", (unsigned) (5 - Length), " ",
876             (UINT32) Op->Common.Value.Integer);
877         AcpiDmCommaIfFieldMember (Op);
878 
879         Info->BitOffset += (UINT32) Op->Common.Value.Integer;
880         break;
881 
882     case AML_INT_RESERVEDFIELD_OP:
883 
884         /* Offset() -- Must account for previous offsets */
885 
886         Offset = (UINT32) Op->Common.Value.Integer;
887         Info->BitOffset += Offset;
888 
889         if (Info->BitOffset % 8 == 0)
890         {
891             AcpiOsPrintf ("Offset (0x%.2X)", ACPI_DIV_8 (Info->BitOffset));
892         }
893         else
894         {
895             AcpiOsPrintf ("    ,   %u", Offset);
896         }
897 
898         AcpiDmCommaIfFieldMember (Op);
899         break;
900 
901     case AML_INT_ACCESSFIELD_OP:
902     case AML_INT_EXTACCESSFIELD_OP:
903 
904         AcpiOsPrintf ("AccessAs (%s, ",
905             AcpiGbl_AccessTypes [(UINT32) (Op->Common.Value.Integer & 0x7)]);
906 
907         AcpiDmDecodeAttribute ((UINT8) (Op->Common.Value.Integer >> 8));
908 
909         if (Op->Common.AmlOpcode == AML_INT_EXTACCESSFIELD_OP)
910         {
911             AcpiOsPrintf (" (0x%2.2X)", (unsigned) ((Op->Common.Value.Integer >> 16) & 0xFF));
912         }
913 
914         AcpiOsPrintf (")");
915         AcpiDmCommaIfFieldMember (Op);
916         break;
917 
918     case AML_INT_CONNECTION_OP:
919         /*
920          * Two types of Connection() - one with a buffer object, the
921          * other with a namestring that points to a buffer object.
922          */
923         AcpiOsPrintf ("Connection (");
924         Child = Op->Common.Value.Arg;
925 
926         if (Child->Common.AmlOpcode == AML_INT_BYTELIST_OP)
927         {
928             AcpiOsPrintf ("\n");
929 
930             Aml = Child->Named.Data;
931             Length = (UINT32) Child->Common.Value.Integer;
932 
933             Info->Level += 1;
934             Info->MappingOp = Op;
935             Op->Common.DisasmOpcode = ACPI_DASM_RESOURCE;
936 
937             AcpiDmResourceTemplate (Info, Op->Common.Parent, Aml, Length);
938 
939             Info->Level -= 1;
940             AcpiDmIndent (Info->Level);
941         }
942         else
943         {
944             AcpiDmNamestring (Child->Common.Value.Name);
945         }
946 
947         AcpiOsPrintf (")");
948         AcpiDmCommaIfFieldMember (Op);
949         AcpiOsPrintf ("\n");
950 
951         Op->Common.DisasmFlags |= ACPI_PARSEOP_IGNORE; /* for now, ignore in AcpiDmAscendingOp */
952         Child->Common.DisasmFlags |= ACPI_PARSEOP_IGNORE;
953         break;
954 
955     case AML_INT_BYTELIST_OP:
956 
957         AcpiDmByteList (Info, Op);
958         break;
959 
960     case AML_INT_METHODCALL_OP:
961 
962         Op = AcpiPsGetDepthNext (NULL, Op);
963         Op->Common.DisasmFlags |= ACPI_PARSEOP_IGNORE;
964 
965         AcpiDmNamestring (Op->Common.Value.Name);
966         break;
967 
968     default:
969 
970         /* Just get the opcode name and print it */
971 
972         AcpiOsPrintf ("%s", OpInfo->Name);
973 
974 
975 #ifdef ACPI_DEBUGGER
976 
977         if ((Op->Common.AmlOpcode == AML_INT_RETURN_VALUE_OP) &&
978             (WalkState) &&
979             (WalkState->Results) &&
980             (WalkState->ResultCount))
981         {
982             AcpiDmDecodeInternalObject (
983                 WalkState->Results->Results.ObjDesc [
984                     (WalkState->ResultCount - 1) %
985                         ACPI_RESULTS_FRAME_OBJ_NUM]);
986         }
987 #endif
988 
989         break;
990     }
991 }
992 
993 #endif  /* ACPI_DISASSEMBLER */
994