xref: /dflybsd-src/sys/contrib/dev/acpica/source/components/disassembler/dmutils.c (revision 20294b7e33bbb88515745d3036e94e3155ea80a9)
10d02842fSSascha Wildner /*******************************************************************************
20d02842fSSascha Wildner  *
30d02842fSSascha Wildner  * Module Name: dmutils - AML disassembler utilities
40d02842fSSascha Wildner  *
50d02842fSSascha Wildner  ******************************************************************************/
60d02842fSSascha Wildner 
70d02842fSSascha Wildner /*
8*20294b7eSSascha Wildner  * Copyright (C) 2000 - 2014, Intel Corp.
90d02842fSSascha Wildner  * All rights reserved.
100d02842fSSascha Wildner  *
110d02842fSSascha Wildner  * Redistribution and use in source and binary forms, with or without
120d02842fSSascha Wildner  * modification, are permitted provided that the following conditions
130d02842fSSascha Wildner  * are met:
140d02842fSSascha Wildner  * 1. Redistributions of source code must retain the above copyright
150d02842fSSascha Wildner  *    notice, this list of conditions, and the following disclaimer,
160d02842fSSascha Wildner  *    without modification.
170d02842fSSascha Wildner  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
180d02842fSSascha Wildner  *    substantially similar to the "NO WARRANTY" disclaimer below
190d02842fSSascha Wildner  *    ("Disclaimer") and any redistribution must be conditioned upon
200d02842fSSascha Wildner  *    including a substantially similar Disclaimer requirement for further
210d02842fSSascha Wildner  *    binary redistribution.
220d02842fSSascha Wildner  * 3. Neither the names of the above-listed copyright holders nor the names
230d02842fSSascha Wildner  *    of any contributors may be used to endorse or promote products derived
240d02842fSSascha Wildner  *    from this software without specific prior written permission.
250d02842fSSascha Wildner  *
260d02842fSSascha Wildner  * Alternatively, this software may be distributed under the terms of the
270d02842fSSascha Wildner  * GNU General Public License ("GPL") version 2 as published by the Free
280d02842fSSascha Wildner  * Software Foundation.
290d02842fSSascha Wildner  *
300d02842fSSascha Wildner  * NO WARRANTY
310d02842fSSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
320d02842fSSascha Wildner  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
330d02842fSSascha Wildner  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
340d02842fSSascha Wildner  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
350d02842fSSascha Wildner  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
360d02842fSSascha Wildner  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
370d02842fSSascha Wildner  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
380d02842fSSascha Wildner  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
390d02842fSSascha Wildner  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
400d02842fSSascha Wildner  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
410d02842fSSascha Wildner  * POSSIBILITY OF SUCH DAMAGES.
420d02842fSSascha Wildner  */
430d02842fSSascha Wildner 
440d02842fSSascha Wildner 
450d02842fSSascha Wildner #include "acpi.h"
460d02842fSSascha Wildner #include "accommon.h"
470d02842fSSascha Wildner #include "amlcode.h"
480d02842fSSascha Wildner #include "acdisasm.h"
490d02842fSSascha Wildner 
500d02842fSSascha Wildner #ifdef ACPI_ASL_COMPILER
510d02842fSSascha Wildner #include <acnamesp.h>
520d02842fSSascha Wildner #endif
530d02842fSSascha Wildner 
540d02842fSSascha Wildner #ifdef ACPI_DISASSEMBLER
550d02842fSSascha Wildner 
560d02842fSSascha Wildner #define _COMPONENT          ACPI_CA_DEBUGGER
570d02842fSSascha Wildner         ACPI_MODULE_NAME    ("dmutils")
580d02842fSSascha Wildner 
590d02842fSSascha Wildner 
600d02842fSSascha Wildner /* Data used in keeping track of fields */
610d02842fSSascha Wildner #if 0
620d02842fSSascha Wildner const char                      *AcpiGbl_FENames[] =
630d02842fSSascha Wildner {
640d02842fSSascha Wildner     "skip",
650d02842fSSascha Wildner     "?access?"
660d02842fSSascha Wildner };              /* FE = Field Element */
670d02842fSSascha Wildner #endif
680d02842fSSascha Wildner 
690d02842fSSascha Wildner /* Operators for Match() */
700d02842fSSascha Wildner 
710d02842fSSascha Wildner const char                      *AcpiGbl_MatchOps[] =
720d02842fSSascha Wildner {
730d02842fSSascha Wildner     "MTR",
740d02842fSSascha Wildner     "MEQ",
750d02842fSSascha Wildner     "MLE",
760d02842fSSascha Wildner     "MLT",
770d02842fSSascha Wildner     "MGE",
780d02842fSSascha Wildner     "MGT"
790d02842fSSascha Wildner };
800d02842fSSascha Wildner 
810d02842fSSascha Wildner /* Access type decoding */
820d02842fSSascha Wildner 
830d02842fSSascha Wildner const char                      *AcpiGbl_AccessTypes[] =
840d02842fSSascha Wildner {
850d02842fSSascha Wildner     "AnyAcc",
860d02842fSSascha Wildner     "ByteAcc",
870d02842fSSascha Wildner     "WordAcc",
880d02842fSSascha Wildner     "DWordAcc",
890d02842fSSascha Wildner     "QWordAcc",
900d02842fSSascha Wildner     "BufferAcc",
910d02842fSSascha Wildner     "InvalidAccType",
920d02842fSSascha Wildner     "InvalidAccType"
930d02842fSSascha Wildner };
940d02842fSSascha Wildner 
950d02842fSSascha Wildner /* Lock rule decoding */
960d02842fSSascha Wildner 
970d02842fSSascha Wildner const char                      *AcpiGbl_LockRule[] =
980d02842fSSascha Wildner {
990d02842fSSascha Wildner     "NoLock",
1000d02842fSSascha Wildner     "Lock"
1010d02842fSSascha Wildner };
1020d02842fSSascha Wildner 
1030d02842fSSascha Wildner /* Update rule decoding */
1040d02842fSSascha Wildner 
1050d02842fSSascha Wildner const char                      *AcpiGbl_UpdateRules[] =
1060d02842fSSascha Wildner {
1070d02842fSSascha Wildner     "Preserve",
1080d02842fSSascha Wildner     "WriteAsOnes",
1090d02842fSSascha Wildner     "WriteAsZeros",
1100d02842fSSascha Wildner     "InvalidUpdateRule"
1110d02842fSSascha Wildner };
1120d02842fSSascha Wildner 
1130d02842fSSascha Wildner /* Strings used to decode resource descriptors */
1140d02842fSSascha Wildner 
1150d02842fSSascha Wildner const char                      *AcpiGbl_WordDecode[] =
1160d02842fSSascha Wildner {
1170d02842fSSascha Wildner     "Memory",
1180d02842fSSascha Wildner     "IO",
1190d02842fSSascha Wildner     "BusNumber",
1200d02842fSSascha Wildner     "UnknownResourceType"
1210d02842fSSascha Wildner };
1220d02842fSSascha Wildner 
1230d02842fSSascha Wildner const char                      *AcpiGbl_IrqDecode[] =
1240d02842fSSascha Wildner {
1250d02842fSSascha Wildner     "IRQNoFlags",
1260d02842fSSascha Wildner     "IRQ"
1270d02842fSSascha Wildner };
1280d02842fSSascha Wildner 
1290d02842fSSascha Wildner 
1300d02842fSSascha Wildner /*******************************************************************************
1310d02842fSSascha Wildner  *
1320d02842fSSascha Wildner  * FUNCTION:    AcpiDmDecodeAttribute
1330d02842fSSascha Wildner  *
1340d02842fSSascha Wildner  * PARAMETERS:  Attribute       - Attribute field of AccessAs keyword
1350d02842fSSascha Wildner  *
1360d02842fSSascha Wildner  * RETURN:      None
1370d02842fSSascha Wildner  *
1380d02842fSSascha Wildner  * DESCRIPTION: Decode the AccessAs attribute byte. (Mostly SMBus and
1390d02842fSSascha Wildner  *              GenericSerialBus stuff.)
1400d02842fSSascha Wildner  *
1410d02842fSSascha Wildner  ******************************************************************************/
1420d02842fSSascha Wildner 
1430d02842fSSascha Wildner void
1440d02842fSSascha Wildner AcpiDmDecodeAttribute (
1450d02842fSSascha Wildner     UINT8                   Attribute)
1460d02842fSSascha Wildner {
1470d02842fSSascha Wildner 
1480d02842fSSascha Wildner     switch (Attribute)
1490d02842fSSascha Wildner     {
1500d02842fSSascha Wildner     case AML_FIELD_ATTRIB_QUICK:
1510d02842fSSascha Wildner 
1520d02842fSSascha Wildner         AcpiOsPrintf ("AttribQuick");
1530d02842fSSascha Wildner         break;
1540d02842fSSascha Wildner 
1550d02842fSSascha Wildner     case AML_FIELD_ATTRIB_SEND_RCV:
1560d02842fSSascha Wildner 
1570d02842fSSascha Wildner         AcpiOsPrintf ("AttribSendReceive");
1580d02842fSSascha Wildner         break;
1590d02842fSSascha Wildner 
1600d02842fSSascha Wildner     case AML_FIELD_ATTRIB_BYTE:
1610d02842fSSascha Wildner 
1620d02842fSSascha Wildner         AcpiOsPrintf ("AttribByte");
1630d02842fSSascha Wildner         break;
1640d02842fSSascha Wildner 
1650d02842fSSascha Wildner     case AML_FIELD_ATTRIB_WORD:
1660d02842fSSascha Wildner 
1670d02842fSSascha Wildner         AcpiOsPrintf ("AttribWord");
1680d02842fSSascha Wildner         break;
1690d02842fSSascha Wildner 
1700d02842fSSascha Wildner     case AML_FIELD_ATTRIB_BLOCK:
1710d02842fSSascha Wildner 
1720d02842fSSascha Wildner         AcpiOsPrintf ("AttribBlock");
1730d02842fSSascha Wildner         break;
1740d02842fSSascha Wildner 
1750d02842fSSascha Wildner     case AML_FIELD_ATTRIB_MULTIBYTE:
1760d02842fSSascha Wildner 
1770d02842fSSascha Wildner         AcpiOsPrintf ("AttribBytes");
1780d02842fSSascha Wildner         break;
1790d02842fSSascha Wildner 
1800d02842fSSascha Wildner     case AML_FIELD_ATTRIB_WORD_CALL:
1810d02842fSSascha Wildner 
1820d02842fSSascha Wildner         AcpiOsPrintf ("AttribProcessCall");
1830d02842fSSascha Wildner         break;
1840d02842fSSascha Wildner 
1850d02842fSSascha Wildner     case AML_FIELD_ATTRIB_BLOCK_CALL:
1860d02842fSSascha Wildner 
1870d02842fSSascha Wildner         AcpiOsPrintf ("AttribBlockProcessCall");
1880d02842fSSascha Wildner         break;
1890d02842fSSascha Wildner 
1900d02842fSSascha Wildner     case AML_FIELD_ATTRIB_RAW_BYTES:
1910d02842fSSascha Wildner 
1920d02842fSSascha Wildner         AcpiOsPrintf ("AttribRawBytes");
1930d02842fSSascha Wildner         break;
1940d02842fSSascha Wildner 
1950d02842fSSascha Wildner     case AML_FIELD_ATTRIB_RAW_PROCESS:
1960d02842fSSascha Wildner 
1970d02842fSSascha Wildner         AcpiOsPrintf ("AttribRawProcessBytes");
1980d02842fSSascha Wildner         break;
1990d02842fSSascha Wildner 
2000d02842fSSascha Wildner     default:
2010d02842fSSascha Wildner 
2020d02842fSSascha Wildner         /* A ByteConst is allowed by the grammar */
2030d02842fSSascha Wildner 
2040d02842fSSascha Wildner         AcpiOsPrintf ("0x%2.2X", Attribute);
2050d02842fSSascha Wildner         break;
2060d02842fSSascha Wildner     }
2070d02842fSSascha Wildner }
2080d02842fSSascha Wildner 
2090d02842fSSascha Wildner 
2100d02842fSSascha Wildner /*******************************************************************************
2110d02842fSSascha Wildner  *
2120d02842fSSascha Wildner  * FUNCTION:    AcpiDmIndent
2130d02842fSSascha Wildner  *
2140d02842fSSascha Wildner  * PARAMETERS:  Level               - Current source code indentation level
2150d02842fSSascha Wildner  *
2160d02842fSSascha Wildner  * RETURN:      None
2170d02842fSSascha Wildner  *
2180d02842fSSascha Wildner  * DESCRIPTION: Indent 4 spaces per indentation level.
2190d02842fSSascha Wildner  *
2200d02842fSSascha Wildner  ******************************************************************************/
2210d02842fSSascha Wildner 
2220d02842fSSascha Wildner void
2230d02842fSSascha Wildner AcpiDmIndent (
2240d02842fSSascha Wildner     UINT32                  Level)
2250d02842fSSascha Wildner {
2260d02842fSSascha Wildner 
2270d02842fSSascha Wildner     if (!Level)
2280d02842fSSascha Wildner     {
2290d02842fSSascha Wildner         return;
2300d02842fSSascha Wildner     }
2310d02842fSSascha Wildner 
2320d02842fSSascha Wildner     AcpiOsPrintf ("%*.s", ACPI_MUL_4 (Level), " ");
2330d02842fSSascha Wildner }
2340d02842fSSascha Wildner 
2350d02842fSSascha Wildner 
2360d02842fSSascha Wildner /*******************************************************************************
2370d02842fSSascha Wildner  *
2380d02842fSSascha Wildner  * FUNCTION:    AcpiDmCommaIfListMember
2390d02842fSSascha Wildner  *
2400d02842fSSascha Wildner  * PARAMETERS:  Op              - Current operator/operand
2410d02842fSSascha Wildner  *
2420d02842fSSascha Wildner  * RETURN:      TRUE if a comma was inserted
2430d02842fSSascha Wildner  *
2440d02842fSSascha Wildner  * DESCRIPTION: Insert a comma if this Op is a member of an argument list.
2450d02842fSSascha Wildner  *
2460d02842fSSascha Wildner  ******************************************************************************/
2470d02842fSSascha Wildner 
2480d02842fSSascha Wildner BOOLEAN
2490d02842fSSascha Wildner AcpiDmCommaIfListMember (
2500d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op)
2510d02842fSSascha Wildner {
2520d02842fSSascha Wildner 
2530d02842fSSascha Wildner     if (!Op->Common.Next)
2540d02842fSSascha Wildner     {
2550d02842fSSascha Wildner         return (FALSE);
2560d02842fSSascha Wildner     }
2570d02842fSSascha Wildner 
2580d02842fSSascha Wildner     if (AcpiDmListType (Op->Common.Parent) & BLOCK_COMMA_LIST)
2590d02842fSSascha Wildner     {
2600d02842fSSascha Wildner         /* Check for a NULL target operand */
2610d02842fSSascha Wildner 
2620d02842fSSascha Wildner         if ((Op->Common.Next->Common.AmlOpcode == AML_INT_NAMEPATH_OP) &&
2630d02842fSSascha Wildner             (!Op->Common.Next->Common.Value.String))
2640d02842fSSascha Wildner         {
2650d02842fSSascha Wildner             /*
2660d02842fSSascha Wildner              * To handle the Divide() case where there are two optional
2670d02842fSSascha Wildner              * targets, look ahead one more op. If null, this null target
2680d02842fSSascha Wildner              * is the one and only target -- no comma needed. Otherwise,
2690d02842fSSascha Wildner              * we need a comma to prepare for the next target.
2700d02842fSSascha Wildner              */
2710d02842fSSascha Wildner             if (!Op->Common.Next->Common.Next)
2720d02842fSSascha Wildner             {
2730d02842fSSascha Wildner                 return (FALSE);
2740d02842fSSascha Wildner             }
2750d02842fSSascha Wildner         }
2760d02842fSSascha Wildner 
2770d02842fSSascha Wildner         if ((Op->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST) &&
2780d02842fSSascha Wildner             (!(Op->Common.Next->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST)))
2790d02842fSSascha Wildner         {
2800d02842fSSascha Wildner             return (FALSE);
2810d02842fSSascha Wildner         }
2820d02842fSSascha Wildner 
2830d02842fSSascha Wildner         AcpiOsPrintf (", ");
2840d02842fSSascha Wildner         return (TRUE);
2850d02842fSSascha Wildner     }
2860d02842fSSascha Wildner 
2870d02842fSSascha Wildner     else if ((Op->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST) &&
2880d02842fSSascha Wildner              (Op->Common.Next->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST))
2890d02842fSSascha Wildner     {
2900d02842fSSascha Wildner         AcpiOsPrintf (", ");
2910d02842fSSascha Wildner         return (TRUE);
2920d02842fSSascha Wildner     }
2930d02842fSSascha Wildner 
2940d02842fSSascha Wildner     return (FALSE);
2950d02842fSSascha Wildner }
2960d02842fSSascha Wildner 
2970d02842fSSascha Wildner 
2980d02842fSSascha Wildner /*******************************************************************************
2990d02842fSSascha Wildner  *
3000d02842fSSascha Wildner  * FUNCTION:    AcpiDmCommaIfFieldMember
3010d02842fSSascha Wildner  *
3020d02842fSSascha Wildner  * PARAMETERS:  Op              - Current operator/operand
3030d02842fSSascha Wildner  *
3040d02842fSSascha Wildner  * RETURN:      None
3050d02842fSSascha Wildner  *
3060d02842fSSascha Wildner  * DESCRIPTION: Insert a comma if this Op is a member of a Field argument list.
3070d02842fSSascha Wildner  *
3080d02842fSSascha Wildner  ******************************************************************************/
3090d02842fSSascha Wildner 
3100d02842fSSascha Wildner void
3110d02842fSSascha Wildner AcpiDmCommaIfFieldMember (
3120d02842fSSascha Wildner     ACPI_PARSE_OBJECT       *Op)
3130d02842fSSascha Wildner {
3140d02842fSSascha Wildner 
3150d02842fSSascha Wildner     if (Op->Common.Next)
3160d02842fSSascha Wildner     {
3170d02842fSSascha Wildner         AcpiOsPrintf (", ");
3180d02842fSSascha Wildner     }
3190d02842fSSascha Wildner }
3200d02842fSSascha Wildner 
3210d02842fSSascha Wildner #endif
322