Home | History | Annotate | Line # | Download | only in disassembler
dmutils.c revision 1.1.1.2.2.2
      1  1.1.1.2.2.2  bouyer /*******************************************************************************
      2  1.1.1.2.2.2  bouyer  *
      3  1.1.1.2.2.2  bouyer  * Module Name: dmutils - AML disassembler utilities
      4  1.1.1.2.2.2  bouyer  *
      5  1.1.1.2.2.2  bouyer  ******************************************************************************/
      6  1.1.1.2.2.2  bouyer 
      7  1.1.1.2.2.2  bouyer /*
      8  1.1.1.2.2.2  bouyer  * Copyright (C) 2000 - 2011, Intel Corp.
      9  1.1.1.2.2.2  bouyer  * All rights reserved.
     10  1.1.1.2.2.2  bouyer  *
     11  1.1.1.2.2.2  bouyer  * Redistribution and use in source and binary forms, with or without
     12  1.1.1.2.2.2  bouyer  * modification, are permitted provided that the following conditions
     13  1.1.1.2.2.2  bouyer  * are met:
     14  1.1.1.2.2.2  bouyer  * 1. Redistributions of source code must retain the above copyright
     15  1.1.1.2.2.2  bouyer  *    notice, this list of conditions, and the following disclaimer,
     16  1.1.1.2.2.2  bouyer  *    without modification.
     17  1.1.1.2.2.2  bouyer  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
     18  1.1.1.2.2.2  bouyer  *    substantially similar to the "NO WARRANTY" disclaimer below
     19  1.1.1.2.2.2  bouyer  *    ("Disclaimer") and any redistribution must be conditioned upon
     20  1.1.1.2.2.2  bouyer  *    including a substantially similar Disclaimer requirement for further
     21  1.1.1.2.2.2  bouyer  *    binary redistribution.
     22  1.1.1.2.2.2  bouyer  * 3. Neither the names of the above-listed copyright holders nor the names
     23  1.1.1.2.2.2  bouyer  *    of any contributors may be used to endorse or promote products derived
     24  1.1.1.2.2.2  bouyer  *    from this software without specific prior written permission.
     25  1.1.1.2.2.2  bouyer  *
     26  1.1.1.2.2.2  bouyer  * Alternatively, this software may be distributed under the terms of the
     27  1.1.1.2.2.2  bouyer  * GNU General Public License ("GPL") version 2 as published by the Free
     28  1.1.1.2.2.2  bouyer  * Software Foundation.
     29  1.1.1.2.2.2  bouyer  *
     30  1.1.1.2.2.2  bouyer  * NO WARRANTY
     31  1.1.1.2.2.2  bouyer  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     32  1.1.1.2.2.2  bouyer  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     33  1.1.1.2.2.2  bouyer  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
     34  1.1.1.2.2.2  bouyer  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     35  1.1.1.2.2.2  bouyer  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     36  1.1.1.2.2.2  bouyer  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     37  1.1.1.2.2.2  bouyer  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     38  1.1.1.2.2.2  bouyer  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     39  1.1.1.2.2.2  bouyer  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     40  1.1.1.2.2.2  bouyer  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     41  1.1.1.2.2.2  bouyer  * POSSIBILITY OF SUCH DAMAGES.
     42  1.1.1.2.2.2  bouyer  */
     43  1.1.1.2.2.2  bouyer 
     44  1.1.1.2.2.2  bouyer 
     45  1.1.1.2.2.2  bouyer #include "acpi.h"
     46  1.1.1.2.2.2  bouyer #include "accommon.h"
     47  1.1.1.2.2.2  bouyer #include "amlcode.h"
     48  1.1.1.2.2.2  bouyer #include "acdisasm.h"
     49  1.1.1.2.2.2  bouyer 
     50  1.1.1.2.2.2  bouyer #ifdef ACPI_ASL_COMPILER
     51  1.1.1.2.2.2  bouyer #include <acnamesp.h>
     52  1.1.1.2.2.2  bouyer #endif
     53  1.1.1.2.2.2  bouyer 
     54  1.1.1.2.2.2  bouyer #ifdef ACPI_DISASSEMBLER
     55  1.1.1.2.2.2  bouyer 
     56  1.1.1.2.2.2  bouyer #define _COMPONENT          ACPI_CA_DEBUGGER
     57  1.1.1.2.2.2  bouyer         ACPI_MODULE_NAME    ("dmutils")
     58  1.1.1.2.2.2  bouyer 
     59  1.1.1.2.2.2  bouyer 
     60  1.1.1.2.2.2  bouyer /* Data used in keeping track of fields */
     61  1.1.1.2.2.2  bouyer #if 0
     62  1.1.1.2.2.2  bouyer const char                      *AcpiGbl_FENames[] =
     63  1.1.1.2.2.2  bouyer {
     64  1.1.1.2.2.2  bouyer     "skip",
     65  1.1.1.2.2.2  bouyer     "?access?"
     66  1.1.1.2.2.2  bouyer };              /* FE = Field Element */
     67  1.1.1.2.2.2  bouyer #endif
     68  1.1.1.2.2.2  bouyer 
     69  1.1.1.2.2.2  bouyer /* Operators for Match() */
     70  1.1.1.2.2.2  bouyer 
     71  1.1.1.2.2.2  bouyer const char                      *AcpiGbl_MatchOps[] =
     72  1.1.1.2.2.2  bouyer {
     73  1.1.1.2.2.2  bouyer     "MTR",
     74  1.1.1.2.2.2  bouyer     "MEQ",
     75  1.1.1.2.2.2  bouyer     "MLE",
     76  1.1.1.2.2.2  bouyer     "MLT",
     77  1.1.1.2.2.2  bouyer     "MGE",
     78  1.1.1.2.2.2  bouyer     "MGT"
     79  1.1.1.2.2.2  bouyer };
     80  1.1.1.2.2.2  bouyer 
     81  1.1.1.2.2.2  bouyer /* Access type decoding */
     82  1.1.1.2.2.2  bouyer 
     83  1.1.1.2.2.2  bouyer const char                      *AcpiGbl_AccessTypes[] =
     84  1.1.1.2.2.2  bouyer {
     85  1.1.1.2.2.2  bouyer     "AnyAcc",
     86  1.1.1.2.2.2  bouyer     "ByteAcc",
     87  1.1.1.2.2.2  bouyer     "WordAcc",
     88  1.1.1.2.2.2  bouyer     "DWordAcc",
     89  1.1.1.2.2.2  bouyer     "QWordAcc",
     90  1.1.1.2.2.2  bouyer     "BufferAcc",
     91  1.1.1.2.2.2  bouyer     "InvalidAccType",
     92  1.1.1.2.2.2  bouyer     "InvalidAccType"
     93  1.1.1.2.2.2  bouyer };
     94  1.1.1.2.2.2  bouyer 
     95  1.1.1.2.2.2  bouyer /* Lock rule decoding */
     96  1.1.1.2.2.2  bouyer 
     97  1.1.1.2.2.2  bouyer const char                      *AcpiGbl_LockRule[] =
     98  1.1.1.2.2.2  bouyer {
     99  1.1.1.2.2.2  bouyer     "NoLock",
    100  1.1.1.2.2.2  bouyer     "Lock"
    101  1.1.1.2.2.2  bouyer };
    102  1.1.1.2.2.2  bouyer 
    103  1.1.1.2.2.2  bouyer /* Update rule decoding */
    104  1.1.1.2.2.2  bouyer 
    105  1.1.1.2.2.2  bouyer const char                      *AcpiGbl_UpdateRules[] =
    106  1.1.1.2.2.2  bouyer {
    107  1.1.1.2.2.2  bouyer     "Preserve",
    108  1.1.1.2.2.2  bouyer     "WriteAsOnes",
    109  1.1.1.2.2.2  bouyer     "WriteAsZeros",
    110  1.1.1.2.2.2  bouyer     "InvalidUpdateRule"
    111  1.1.1.2.2.2  bouyer };
    112  1.1.1.2.2.2  bouyer 
    113  1.1.1.2.2.2  bouyer /* Strings used to decode resource descriptors */
    114  1.1.1.2.2.2  bouyer 
    115  1.1.1.2.2.2  bouyer const char                      *AcpiGbl_WordDecode[] =
    116  1.1.1.2.2.2  bouyer {
    117  1.1.1.2.2.2  bouyer     "Memory",
    118  1.1.1.2.2.2  bouyer     "IO",
    119  1.1.1.2.2.2  bouyer     "BusNumber",
    120  1.1.1.2.2.2  bouyer     "UnknownResourceType"
    121  1.1.1.2.2.2  bouyer };
    122  1.1.1.2.2.2  bouyer 
    123  1.1.1.2.2.2  bouyer const char                      *AcpiGbl_IrqDecode[] =
    124  1.1.1.2.2.2  bouyer {
    125  1.1.1.2.2.2  bouyer     "IRQNoFlags",
    126  1.1.1.2.2.2  bouyer     "IRQ"
    127  1.1.1.2.2.2  bouyer };
    128  1.1.1.2.2.2  bouyer 
    129  1.1.1.2.2.2  bouyer 
    130  1.1.1.2.2.2  bouyer /*******************************************************************************
    131  1.1.1.2.2.2  bouyer  *
    132  1.1.1.2.2.2  bouyer  * FUNCTION:    AcpiDmDecodeAttribute
    133  1.1.1.2.2.2  bouyer  *
    134  1.1.1.2.2.2  bouyer  * PARAMETERS:  Attribute       - Attribute field of AccessAs keyword
    135  1.1.1.2.2.2  bouyer  *
    136  1.1.1.2.2.2  bouyer  * RETURN:      None
    137  1.1.1.2.2.2  bouyer  *
    138  1.1.1.2.2.2  bouyer  * DESCRIPTION: Decode the AccessAs attribute byte.  (Mostly SMBus stuff)
    139  1.1.1.2.2.2  bouyer  *
    140  1.1.1.2.2.2  bouyer  ******************************************************************************/
    141  1.1.1.2.2.2  bouyer 
    142  1.1.1.2.2.2  bouyer void
    143  1.1.1.2.2.2  bouyer AcpiDmDecodeAttribute (
    144  1.1.1.2.2.2  bouyer     UINT8                   Attribute)
    145  1.1.1.2.2.2  bouyer {
    146  1.1.1.2.2.2  bouyer 
    147  1.1.1.2.2.2  bouyer     switch (Attribute)
    148  1.1.1.2.2.2  bouyer     {
    149  1.1.1.2.2.2  bouyer     case AML_FIELD_ATTRIB_SMB_QUICK:
    150  1.1.1.2.2.2  bouyer 
    151  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("SMBQuick");
    152  1.1.1.2.2.2  bouyer         break;
    153  1.1.1.2.2.2  bouyer 
    154  1.1.1.2.2.2  bouyer     case AML_FIELD_ATTRIB_SMB_SEND_RCV:
    155  1.1.1.2.2.2  bouyer 
    156  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("SMBSendReceive");
    157  1.1.1.2.2.2  bouyer         break;
    158  1.1.1.2.2.2  bouyer 
    159  1.1.1.2.2.2  bouyer     case AML_FIELD_ATTRIB_SMB_BYTE:
    160  1.1.1.2.2.2  bouyer 
    161  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("SMBByte");
    162  1.1.1.2.2.2  bouyer         break;
    163  1.1.1.2.2.2  bouyer 
    164  1.1.1.2.2.2  bouyer     case AML_FIELD_ATTRIB_SMB_WORD:
    165  1.1.1.2.2.2  bouyer 
    166  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("SMBWord");
    167  1.1.1.2.2.2  bouyer         break;
    168  1.1.1.2.2.2  bouyer 
    169  1.1.1.2.2.2  bouyer     case AML_FIELD_ATTRIB_SMB_WORD_CALL:
    170  1.1.1.2.2.2  bouyer 
    171  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("SMBProcessCall");
    172  1.1.1.2.2.2  bouyer         break;
    173  1.1.1.2.2.2  bouyer 
    174  1.1.1.2.2.2  bouyer     case AML_FIELD_ATTRIB_SMB_BLOCK:
    175  1.1.1.2.2.2  bouyer 
    176  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("SMBBlock");
    177  1.1.1.2.2.2  bouyer         break;
    178  1.1.1.2.2.2  bouyer 
    179  1.1.1.2.2.2  bouyer     case AML_FIELD_ATTRIB_SMB_BLOCK_CALL:
    180  1.1.1.2.2.2  bouyer 
    181  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("SMBBlockProcessCall");
    182  1.1.1.2.2.2  bouyer         break;
    183  1.1.1.2.2.2  bouyer 
    184  1.1.1.2.2.2  bouyer     default:
    185  1.1.1.2.2.2  bouyer 
    186  1.1.1.2.2.2  bouyer         AcpiOsPrintf ("0x%.2X", Attribute);
    187  1.1.1.2.2.2  bouyer         break;
    188  1.1.1.2.2.2  bouyer     }
    189  1.1.1.2.2.2  bouyer }
    190  1.1.1.2.2.2  bouyer 
    191  1.1.1.2.2.2  bouyer 
    192  1.1.1.2.2.2  bouyer /*******************************************************************************
    193  1.1.1.2.2.2  bouyer  *
    194  1.1.1.2.2.2  bouyer  * FUNCTION:    AcpiDmIndent
    195  1.1.1.2.2.2  bouyer  *
    196  1.1.1.2.2.2  bouyer  * PARAMETERS:  Level               - Current source code indentation level
    197  1.1.1.2.2.2  bouyer  *
    198  1.1.1.2.2.2  bouyer  * RETURN:      None
    199  1.1.1.2.2.2  bouyer  *
    200  1.1.1.2.2.2  bouyer  * DESCRIPTION: Indent 4 spaces per indentation level.
    201  1.1.1.2.2.2  bouyer  *
    202  1.1.1.2.2.2  bouyer  ******************************************************************************/
    203  1.1.1.2.2.2  bouyer 
    204  1.1.1.2.2.2  bouyer void
    205  1.1.1.2.2.2  bouyer AcpiDmIndent (
    206  1.1.1.2.2.2  bouyer     UINT32                  Level)
    207  1.1.1.2.2.2  bouyer {
    208  1.1.1.2.2.2  bouyer 
    209  1.1.1.2.2.2  bouyer     if (!Level)
    210  1.1.1.2.2.2  bouyer     {
    211  1.1.1.2.2.2  bouyer         return;
    212  1.1.1.2.2.2  bouyer     }
    213  1.1.1.2.2.2  bouyer 
    214  1.1.1.2.2.2  bouyer     AcpiOsPrintf ("%*.s", ACPI_MUL_4 (Level), " ");
    215  1.1.1.2.2.2  bouyer }
    216  1.1.1.2.2.2  bouyer 
    217  1.1.1.2.2.2  bouyer 
    218  1.1.1.2.2.2  bouyer /*******************************************************************************
    219  1.1.1.2.2.2  bouyer  *
    220  1.1.1.2.2.2  bouyer  * FUNCTION:    AcpiDmCommaIfListMember
    221  1.1.1.2.2.2  bouyer  *
    222  1.1.1.2.2.2  bouyer  * PARAMETERS:  Op              - Current operator/operand
    223  1.1.1.2.2.2  bouyer  *
    224  1.1.1.2.2.2  bouyer  * RETURN:      TRUE if a comma was inserted
    225  1.1.1.2.2.2  bouyer  *
    226  1.1.1.2.2.2  bouyer  * DESCRIPTION: Insert a comma if this Op is a member of an argument list.
    227  1.1.1.2.2.2  bouyer  *
    228  1.1.1.2.2.2  bouyer  ******************************************************************************/
    229  1.1.1.2.2.2  bouyer 
    230  1.1.1.2.2.2  bouyer BOOLEAN
    231  1.1.1.2.2.2  bouyer AcpiDmCommaIfListMember (
    232  1.1.1.2.2.2  bouyer     ACPI_PARSE_OBJECT       *Op)
    233  1.1.1.2.2.2  bouyer {
    234  1.1.1.2.2.2  bouyer 
    235  1.1.1.2.2.2  bouyer     if (!Op->Common.Next)
    236  1.1.1.2.2.2  bouyer     {
    237  1.1.1.2.2.2  bouyer         return FALSE;
    238  1.1.1.2.2.2  bouyer     }
    239  1.1.1.2.2.2  bouyer 
    240  1.1.1.2.2.2  bouyer     if (AcpiDmListType (Op->Common.Parent) & BLOCK_COMMA_LIST)
    241  1.1.1.2.2.2  bouyer     {
    242  1.1.1.2.2.2  bouyer         /* Check for a NULL target operand */
    243  1.1.1.2.2.2  bouyer 
    244  1.1.1.2.2.2  bouyer         if ((Op->Common.Next->Common.AmlOpcode == AML_INT_NAMEPATH_OP) &&
    245  1.1.1.2.2.2  bouyer             (!Op->Common.Next->Common.Value.String))
    246  1.1.1.2.2.2  bouyer         {
    247  1.1.1.2.2.2  bouyer             /*
    248  1.1.1.2.2.2  bouyer              * To handle the Divide() case where there are two optional
    249  1.1.1.2.2.2  bouyer              * targets, look ahead one more op.  If null, this null target
    250  1.1.1.2.2.2  bouyer              * is the one and only target -- no comma needed.  Otherwise,
    251  1.1.1.2.2.2  bouyer              * we need a comma to prepare for the next target.
    252  1.1.1.2.2.2  bouyer              */
    253  1.1.1.2.2.2  bouyer             if (!Op->Common.Next->Common.Next)
    254  1.1.1.2.2.2  bouyer             {
    255  1.1.1.2.2.2  bouyer                 return FALSE;
    256  1.1.1.2.2.2  bouyer             }
    257  1.1.1.2.2.2  bouyer         }
    258  1.1.1.2.2.2  bouyer 
    259  1.1.1.2.2.2  bouyer         if ((Op->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST) &&
    260  1.1.1.2.2.2  bouyer             (!(Op->Common.Next->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST)))
    261  1.1.1.2.2.2  bouyer         {
    262  1.1.1.2.2.2  bouyer             return FALSE;
    263  1.1.1.2.2.2  bouyer         }
    264  1.1.1.2.2.2  bouyer 
    265  1.1.1.2.2.2  bouyer         AcpiOsPrintf (", ");
    266  1.1.1.2.2.2  bouyer         return (TRUE);
    267  1.1.1.2.2.2  bouyer     }
    268  1.1.1.2.2.2  bouyer 
    269  1.1.1.2.2.2  bouyer     else if ((Op->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST) &&
    270  1.1.1.2.2.2  bouyer              (Op->Common.Next->Common.DisasmFlags & ACPI_PARSEOP_PARAMLIST))
    271  1.1.1.2.2.2  bouyer     {
    272  1.1.1.2.2.2  bouyer         AcpiOsPrintf (", ");
    273  1.1.1.2.2.2  bouyer         return (TRUE);
    274  1.1.1.2.2.2  bouyer     }
    275  1.1.1.2.2.2  bouyer 
    276  1.1.1.2.2.2  bouyer     return (FALSE);
    277  1.1.1.2.2.2  bouyer }
    278  1.1.1.2.2.2  bouyer 
    279  1.1.1.2.2.2  bouyer 
    280  1.1.1.2.2.2  bouyer /*******************************************************************************
    281  1.1.1.2.2.2  bouyer  *
    282  1.1.1.2.2.2  bouyer  * FUNCTION:    AcpiDmCommaIfFieldMember
    283  1.1.1.2.2.2  bouyer  *
    284  1.1.1.2.2.2  bouyer  * PARAMETERS:  Op              - Current operator/operand
    285  1.1.1.2.2.2  bouyer  *
    286  1.1.1.2.2.2  bouyer  * RETURN:      None
    287  1.1.1.2.2.2  bouyer  *
    288  1.1.1.2.2.2  bouyer  * DESCRIPTION: Insert a comma if this Op is a member of a Field argument list.
    289  1.1.1.2.2.2  bouyer  *
    290  1.1.1.2.2.2  bouyer  ******************************************************************************/
    291  1.1.1.2.2.2  bouyer 
    292  1.1.1.2.2.2  bouyer void
    293  1.1.1.2.2.2  bouyer AcpiDmCommaIfFieldMember (
    294  1.1.1.2.2.2  bouyer     ACPI_PARSE_OBJECT       *Op)
    295  1.1.1.2.2.2  bouyer {
    296  1.1.1.2.2.2  bouyer 
    297  1.1.1.2.2.2  bouyer     if (Op->Common.Next)
    298  1.1.1.2.2.2  bouyer     {
    299  1.1.1.2.2.2  bouyer         AcpiOsPrintf (", ");
    300  1.1.1.2.2.2  bouyer     }
    301  1.1.1.2.2.2  bouyer }
    302  1.1.1.2.2.2  bouyer 
    303  1.1.1.2.2.2  bouyer #endif
    304