Home | History | Annotate | Line # | Download | only in disassembler
dmutils.c revision 1.1
      1  1.1  jruoho /*******************************************************************************
      2  1.1  jruoho  *
      3  1.1  jruoho  * Module Name: dmutils - AML disassembler utilities
      4  1.1  jruoho  *
      5  1.1  jruoho  ******************************************************************************/
      6  1.1  jruoho 
      7  1.1  jruoho /******************************************************************************
      8  1.1  jruoho  *
      9  1.1  jruoho  * 1. Copyright Notice
     10  1.1  jruoho  *
     11  1.1  jruoho  * Some or all of this work - Copyright (c) 1999 - 2010, Intel Corp.
     12  1.1  jruoho  * All rights reserved.
     13  1.1  jruoho  *
     14  1.1  jruoho  * 2. License
     15  1.1  jruoho  *
     16  1.1  jruoho  * 2.1. This is your license from Intel Corp. under its intellectual property
     17  1.1  jruoho  * rights.  You may have additional license terms from the party that provided
     18  1.1  jruoho  * you this software, covering your right to use that party's intellectual
     19  1.1  jruoho  * property rights.
     20  1.1  jruoho  *
     21  1.1  jruoho  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
     22  1.1  jruoho  * copy of the source code appearing in this file ("Covered Code") an
     23  1.1  jruoho  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
     24  1.1  jruoho  * base code distributed originally by Intel ("Original Intel Code") to copy,
     25  1.1  jruoho  * make derivatives, distribute, use and display any portion of the Covered
     26  1.1  jruoho  * Code in any form, with the right to sublicense such rights; and
     27  1.1  jruoho  *
     28  1.1  jruoho  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
     29  1.1  jruoho  * license (with the right to sublicense), under only those claims of Intel
     30  1.1  jruoho  * patents that are infringed by the Original Intel Code, to make, use, sell,
     31  1.1  jruoho  * offer to sell, and import the Covered Code and derivative works thereof
     32  1.1  jruoho  * solely to the minimum extent necessary to exercise the above copyright
     33  1.1  jruoho  * license, and in no event shall the patent license extend to any additions
     34  1.1  jruoho  * to or modifications of the Original Intel Code.  No other license or right
     35  1.1  jruoho  * is granted directly or by implication, estoppel or otherwise;
     36  1.1  jruoho  *
     37  1.1  jruoho  * The above copyright and patent license is granted only if the following
     38  1.1  jruoho  * conditions are met:
     39  1.1  jruoho  *
     40  1.1  jruoho  * 3. Conditions
     41  1.1  jruoho  *
     42  1.1  jruoho  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
     43  1.1  jruoho  * Redistribution of source code of any substantial portion of the Covered
     44  1.1  jruoho  * Code or modification with rights to further distribute source must include
     45  1.1  jruoho  * the above Copyright Notice, the above License, this list of Conditions,
     46  1.1  jruoho  * and the following Disclaimer and Export Compliance provision.  In addition,
     47  1.1  jruoho  * Licensee must cause all Covered Code to which Licensee contributes to
     48  1.1  jruoho  * contain a file documenting the changes Licensee made to create that Covered
     49  1.1  jruoho  * Code and the date of any change.  Licensee must include in that file the
     50  1.1  jruoho  * documentation of any changes made by any predecessor Licensee.  Licensee
     51  1.1  jruoho  * must include a prominent statement that the modification is derived,
     52  1.1  jruoho  * directly or indirectly, from Original Intel Code.
     53  1.1  jruoho  *
     54  1.1  jruoho  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
     55  1.1  jruoho  * Redistribution of source code of any substantial portion of the Covered
     56  1.1  jruoho  * Code or modification without rights to further distribute source must
     57  1.1  jruoho  * include the following Disclaimer and Export Compliance provision in the
     58  1.1  jruoho  * documentation and/or other materials provided with distribution.  In
     59  1.1  jruoho  * addition, Licensee may not authorize further sublicense of source of any
     60  1.1  jruoho  * portion of the Covered Code, and must include terms to the effect that the
     61  1.1  jruoho  * license from Licensee to its licensee is limited to the intellectual
     62  1.1  jruoho  * property embodied in the software Licensee provides to its licensee, and
     63  1.1  jruoho  * not to intellectual property embodied in modifications its licensee may
     64  1.1  jruoho  * make.
     65  1.1  jruoho  *
     66  1.1  jruoho  * 3.3. Redistribution of Executable. Redistribution in executable form of any
     67  1.1  jruoho  * substantial portion of the Covered Code or modification must reproduce the
     68  1.1  jruoho  * above Copyright Notice, and the following Disclaimer and Export Compliance
     69  1.1  jruoho  * provision in the documentation and/or other materials provided with the
     70  1.1  jruoho  * distribution.
     71  1.1  jruoho  *
     72  1.1  jruoho  * 3.4. Intel retains all right, title, and interest in and to the Original
     73  1.1  jruoho  * Intel Code.
     74  1.1  jruoho  *
     75  1.1  jruoho  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
     76  1.1  jruoho  * Intel shall be used in advertising or otherwise to promote the sale, use or
     77  1.1  jruoho  * other dealings in products derived from or relating to the Covered Code
     78  1.1  jruoho  * without prior written authorization from Intel.
     79  1.1  jruoho  *
     80  1.1  jruoho  * 4. Disclaimer and Export Compliance
     81  1.1  jruoho  *
     82  1.1  jruoho  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
     83  1.1  jruoho  * HERE.  ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
     84  1.1  jruoho  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT,  ASSISTANCE,
     85  1.1  jruoho  * INSTALLATION, TRAINING OR OTHER SERVICES.  INTEL WILL NOT PROVIDE ANY
     86  1.1  jruoho  * UPDATES, ENHANCEMENTS OR EXTENSIONS.  INTEL SPECIFICALLY DISCLAIMS ANY
     87  1.1  jruoho  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
     88  1.1  jruoho  * PARTICULAR PURPOSE.
     89  1.1  jruoho  *
     90  1.1  jruoho  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
     91  1.1  jruoho  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
     92  1.1  jruoho  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
     93  1.1  jruoho  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
     94  1.1  jruoho  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
     95  1.1  jruoho  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES.  THESE LIMITATIONS
     96  1.1  jruoho  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
     97  1.1  jruoho  * LIMITED REMEDY.
     98  1.1  jruoho  *
     99  1.1  jruoho  * 4.3. Licensee shall not export, either directly or indirectly, any of this
    100  1.1  jruoho  * software or system incorporating such software without first obtaining any
    101  1.1  jruoho  * required license or other approval from the U. S. Department of Commerce or
    102  1.1  jruoho  * any other agency or department of the United States Government.  In the
    103  1.1  jruoho  * event Licensee exports any such software from the United States or
    104  1.1  jruoho  * re-exports any such software from a foreign destination, Licensee shall
    105  1.1  jruoho  * ensure that the distribution and export/re-export of the software is in
    106  1.1  jruoho  * compliance with all laws, regulations, orders, or other restrictions of the
    107  1.1  jruoho  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
    108  1.1  jruoho  * any of its subsidiaries will export/re-export any technical data, process,
    109  1.1  jruoho  * software, or service, directly or indirectly, to any country for which the
    110  1.1  jruoho  * United States government or any agency thereof requires an export license,
    111  1.1  jruoho  * other governmental approval, or letter of assurance, without first obtaining
    112  1.1  jruoho  * such license, approval or letter.
    113  1.1  jruoho  *
    114  1.1  jruoho  *****************************************************************************/
    115  1.1  jruoho 
    116  1.1  jruoho 
    117  1.1  jruoho #include "acpi.h"
    118  1.1  jruoho #include "accommon.h"
    119  1.1  jruoho #include "amlcode.h"
    120  1.1  jruoho #include "acdisasm.h"
    121  1.1  jruoho 
    122  1.1  jruoho #ifdef ACPI_ASL_COMPILER
    123  1.1  jruoho #include <acnamesp.h>
    124  1.1  jruoho #endif
    125  1.1  jruoho 
    126  1.1  jruoho #ifdef ACPI_DISASSEMBLER
    127  1.1  jruoho 
    128  1.1  jruoho #define _COMPONENT          ACPI_CA_DEBUGGER
    129  1.1  jruoho         ACPI_MODULE_NAME    ("dmutils")
    130  1.1  jruoho 
    131  1.1  jruoho 
    132  1.1  jruoho /* Data used in keeping track of fields */
    133  1.1  jruoho #if 0
    134  1.1  jruoho const char                      *AcpiGbl_FENames[] =
    135  1.1  jruoho {
    136  1.1  jruoho     "skip",
    137  1.1  jruoho     "?access?"
    138  1.1  jruoho };              /* FE = Field Element */
    139  1.1  jruoho #endif
    140  1.1  jruoho 
    141  1.1  jruoho /* Operators for Match() */
    142  1.1  jruoho 
    143  1.1  jruoho const char                      *AcpiGbl_MatchOps[] =
    144  1.1  jruoho {
    145  1.1  jruoho     "MTR",
    146  1.1  jruoho     "MEQ",
    147  1.1  jruoho     "MLE",
    148  1.1  jruoho     "MLT",
    149  1.1  jruoho     "MGE",
    150  1.1  jruoho     "MGT"
    151  1.1  jruoho };
    152  1.1  jruoho 
    153  1.1  jruoho /* Access type decoding */
    154  1.1  jruoho 
    155  1.1  jruoho const char                      *AcpiGbl_AccessTypes[] =
    156  1.1  jruoho {
    157  1.1  jruoho     "AnyAcc",
    158  1.1  jruoho     "ByteAcc",
    159  1.1  jruoho     "WordAcc",
    160  1.1  jruoho     "DWordAcc",
    161  1.1  jruoho     "QWordAcc",
    162  1.1  jruoho     "BufferAcc",
    163  1.1  jruoho     "InvalidAccType",
    164  1.1  jruoho     "InvalidAccType"
    165  1.1  jruoho };
    166  1.1  jruoho 
    167  1.1  jruoho /* Lock rule decoding */
    168  1.1  jruoho 
    169  1.1  jruoho const char                      *AcpiGbl_LockRule[] =
    170  1.1  jruoho {
    171  1.1  jruoho     "NoLock",
    172  1.1  jruoho     "Lock"
    173  1.1  jruoho };
    174  1.1  jruoho 
    175  1.1  jruoho /* Update rule decoding */
    176  1.1  jruoho 
    177  1.1  jruoho const char                      *AcpiGbl_UpdateRules[] =
    178  1.1  jruoho {
    179  1.1  jruoho     "Preserve",
    180  1.1  jruoho     "WriteAsOnes",
    181  1.1  jruoho     "WriteAsZeros",
    182  1.1  jruoho     "InvalidUpdateRule"
    183  1.1  jruoho };
    184  1.1  jruoho 
    185  1.1  jruoho /* Strings used to decode resource descriptors */
    186  1.1  jruoho 
    187  1.1  jruoho const char                      *AcpiGbl_WordDecode[] =
    188  1.1  jruoho {
    189  1.1  jruoho     "Memory",
    190  1.1  jruoho     "IO",
    191  1.1  jruoho     "BusNumber",
    192  1.1  jruoho     "UnknownResourceType"
    193  1.1  jruoho };
    194  1.1  jruoho 
    195  1.1  jruoho const char                      *AcpiGbl_IrqDecode[] =
    196  1.1  jruoho {
    197  1.1  jruoho     "IRQNoFlags",
    198  1.1  jruoho     "IRQ"
    199  1.1  jruoho };
    200  1.1  jruoho 
    201  1.1  jruoho 
    202  1.1  jruoho /*******************************************************************************
    203  1.1  jruoho  *
    204  1.1  jruoho  * FUNCTION:    AcpiDmDecodeAttribute
    205  1.1  jruoho  *
    206  1.1  jruoho  * PARAMETERS:  Attribute       - Attribute field of AccessAs keyword
    207  1.1  jruoho  *
    208  1.1  jruoho  * RETURN:      None
    209  1.1  jruoho  *
    210  1.1  jruoho  * DESCRIPTION: Decode the AccessAs attribute byte.  (Mostly SMBus stuff)
    211  1.1  jruoho  *
    212  1.1  jruoho  ******************************************************************************/
    213  1.1  jruoho 
    214  1.1  jruoho void
    215  1.1  jruoho AcpiDmDecodeAttribute (
    216  1.1  jruoho     UINT8                   Attribute)
    217  1.1  jruoho {
    218  1.1  jruoho 
    219  1.1  jruoho     switch (Attribute)
    220  1.1  jruoho     {
    221  1.1  jruoho     case AML_FIELD_ATTRIB_SMB_QUICK:
    222  1.1  jruoho 
    223  1.1  jruoho         AcpiOsPrintf ("SMBQuick");
    224  1.1  jruoho         break;
    225  1.1  jruoho 
    226  1.1  jruoho     case AML_FIELD_ATTRIB_SMB_SEND_RCV:
    227  1.1  jruoho 
    228  1.1  jruoho         AcpiOsPrintf ("SMBSendReceive");
    229  1.1  jruoho         break;
    230  1.1  jruoho 
    231  1.1  jruoho     case AML_FIELD_ATTRIB_SMB_BYTE:
    232  1.1  jruoho 
    233  1.1  jruoho         AcpiOsPrintf ("SMBByte");
    234  1.1  jruoho         break;
    235  1.1  jruoho 
    236  1.1  jruoho     case AML_FIELD_ATTRIB_SMB_WORD:
    237  1.1  jruoho 
    238  1.1  jruoho         AcpiOsPrintf ("SMBWord");
    239  1.1  jruoho         break;
    240  1.1  jruoho 
    241  1.1  jruoho     case AML_FIELD_ATTRIB_SMB_WORD_CALL:
    242  1.1  jruoho 
    243  1.1  jruoho         AcpiOsPrintf ("SMBProcessCall");
    244  1.1  jruoho         break;
    245  1.1  jruoho 
    246  1.1  jruoho     case AML_FIELD_ATTRIB_SMB_BLOCK:
    247  1.1  jruoho 
    248  1.1  jruoho         AcpiOsPrintf ("SMBBlock");
    249  1.1  jruoho         break;
    250  1.1  jruoho 
    251  1.1  jruoho     case AML_FIELD_ATTRIB_SMB_BLOCK_CALL:
    252  1.1  jruoho 
    253  1.1  jruoho         AcpiOsPrintf ("SMBBlockProcessCall");
    254  1.1  jruoho         break;
    255  1.1  jruoho 
    256  1.1  jruoho     default:
    257  1.1  jruoho 
    258  1.1  jruoho         AcpiOsPrintf ("0x%.2X", Attribute);
    259  1.1  jruoho         break;
    260  1.1  jruoho     }
    261  1.1  jruoho }
    262  1.1  jruoho 
    263  1.1  jruoho 
    264  1.1  jruoho /*******************************************************************************
    265  1.1  jruoho  *
    266  1.1  jruoho  * FUNCTION:    AcpiDmIndent
    267  1.1  jruoho  *
    268  1.1  jruoho  * PARAMETERS:  Level               - Current source code indentation level
    269  1.1  jruoho  *
    270  1.1  jruoho  * RETURN:      None
    271  1.1  jruoho  *
    272  1.1  jruoho  * DESCRIPTION: Indent 4 spaces per indentation level.
    273  1.1  jruoho  *
    274  1.1  jruoho  ******************************************************************************/
    275  1.1  jruoho 
    276  1.1  jruoho void
    277  1.1  jruoho AcpiDmIndent (
    278  1.1  jruoho     UINT32                  Level)
    279  1.1  jruoho {
    280  1.1  jruoho 
    281  1.1  jruoho     if (!Level)
    282  1.1  jruoho     {
    283  1.1  jruoho         return;
    284  1.1  jruoho     }
    285  1.1  jruoho 
    286  1.1  jruoho     AcpiOsPrintf ("%*.s", ACPI_MUL_4 (Level), " ");
    287  1.1  jruoho }
    288  1.1  jruoho 
    289  1.1  jruoho 
    290  1.1  jruoho /*******************************************************************************
    291  1.1  jruoho  *
    292  1.1  jruoho  * FUNCTION:    AcpiDmCommaIfListMember
    293  1.1  jruoho  *
    294  1.1  jruoho  * PARAMETERS:  Op              - Current operator/operand
    295  1.1  jruoho  *
    296  1.1  jruoho  * RETURN:      TRUE if a comma was inserted
    297  1.1  jruoho  *
    298  1.1  jruoho  * DESCRIPTION: Insert a comma if this Op is a member of an argument list.
    299  1.1  jruoho  *
    300  1.1  jruoho  ******************************************************************************/
    301  1.1  jruoho 
    302  1.1  jruoho BOOLEAN
    303  1.1  jruoho AcpiDmCommaIfListMember (
    304  1.1  jruoho     ACPI_PARSE_OBJECT       *Op)
    305  1.1  jruoho {
    306  1.1  jruoho 
    307  1.1  jruoho     if (!Op->Common.Next)
    308  1.1  jruoho     {
    309  1.1  jruoho         return FALSE;
    310  1.1  jruoho     }
    311  1.1  jruoho 
    312  1.1  jruoho     if (AcpiDmListType (Op->Common.Parent) & BLOCK_COMMA_LIST)
    313  1.1  jruoho     {
    314  1.1  jruoho         /* Check for a NULL target operand */
    315  1.1  jruoho 
    316  1.1  jruoho         if ((Op->Common.Next->Common.AmlOpcode == AML_INT_NAMEPATH_OP) &&
    317  1.1  jruoho             (!Op->Common.Next->Common.Value.String))
    318  1.1  jruoho         {
    319  1.1  jruoho             /*
    320  1.1  jruoho              * To handle the Divide() case where there are two optional
    321  1.1  jruoho              * targets, look ahead one more op.  If null, this null target
    322  1.1  jruoho              * is the one and only target -- no comma needed.  Otherwise,
    323  1.1  jruoho              * we need a comma to prepare for the next target.
    324  1.1  jruoho              */
    325  1.1  jruoho             if (!Op->Common.Next->Common.Next)
    326  1.1  jruoho             {
    327  1.1  jruoho                 return FALSE;
    328  1.1  jruoho             }
    329  1.1  jruoho         }
    330  1.1  jruoho 
    331  1.1  jruoho         if ((Op->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST) &&
    332  1.1  jruoho             (!(Op->Common.Next->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST)))
    333  1.1  jruoho         {
    334  1.1  jruoho             return FALSE;
    335  1.1  jruoho         }
    336  1.1  jruoho 
    337  1.1  jruoho         AcpiOsPrintf (", ");
    338  1.1  jruoho         return (TRUE);
    339  1.1  jruoho     }
    340  1.1  jruoho 
    341  1.1  jruoho     else if ((Op->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST) &&
    342  1.1  jruoho              (Op->Common.Next->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST))
    343  1.1  jruoho     {
    344  1.1  jruoho         AcpiOsPrintf (", ");
    345  1.1  jruoho         return (TRUE);
    346  1.1  jruoho     }
    347  1.1  jruoho 
    348  1.1  jruoho     return (FALSE);
    349  1.1  jruoho }
    350  1.1  jruoho 
    351  1.1  jruoho 
    352  1.1  jruoho /*******************************************************************************
    353  1.1  jruoho  *
    354  1.1  jruoho  * FUNCTION:    AcpiDmCommaIfFieldMember
    355  1.1  jruoho  *
    356  1.1  jruoho  * PARAMETERS:  Op              - Current operator/operand
    357  1.1  jruoho  *
    358  1.1  jruoho  * RETURN:      None
    359  1.1  jruoho  *
    360  1.1  jruoho  * DESCRIPTION: Insert a comma if this Op is a member of a Field argument list.
    361  1.1  jruoho  *
    362  1.1  jruoho  ******************************************************************************/
    363  1.1  jruoho 
    364  1.1  jruoho void
    365  1.1  jruoho AcpiDmCommaIfFieldMember (
    366  1.1  jruoho     ACPI_PARSE_OBJECT       *Op)
    367  1.1  jruoho {
    368  1.1  jruoho 
    369  1.1  jruoho     if (Op->Common.Next)
    370  1.1  jruoho     {
    371  1.1  jruoho         AcpiOsPrintf (", ");
    372  1.1  jruoho     }
    373  1.1  jruoho }
    374  1.1  jruoho 
    375  1.1  jruoho #endif
    376