Home | History | Annotate | Line # | Download | only in utilities
utdecode.c revision 1.13
      1   1.1    jruoho /******************************************************************************
      2   1.1    jruoho  *
      3   1.1    jruoho  * Module Name: utdecode - Utility decoding routines (value-to-string)
      4   1.1    jruoho  *
      5   1.1    jruoho  *****************************************************************************/
      6   1.1    jruoho 
      7   1.1    jruoho /*
      8  1.11  christos  * Copyright (C) 2000 - 2017, Intel Corp.
      9   1.1    jruoho  * All rights reserved.
     10   1.1    jruoho  *
     11   1.1    jruoho  * Redistribution and use in source and binary forms, with or without
     12   1.1    jruoho  * modification, are permitted provided that the following conditions
     13   1.1    jruoho  * are met:
     14   1.1    jruoho  * 1. Redistributions of source code must retain the above copyright
     15   1.1    jruoho  *    notice, this list of conditions, and the following disclaimer,
     16   1.1    jruoho  *    without modification.
     17   1.1    jruoho  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
     18   1.1    jruoho  *    substantially similar to the "NO WARRANTY" disclaimer below
     19   1.1    jruoho  *    ("Disclaimer") and any redistribution must be conditioned upon
     20   1.1    jruoho  *    including a substantially similar Disclaimer requirement for further
     21   1.1    jruoho  *    binary redistribution.
     22   1.1    jruoho  * 3. Neither the names of the above-listed copyright holders nor the names
     23   1.1    jruoho  *    of any contributors may be used to endorse or promote products derived
     24   1.1    jruoho  *    from this software without specific prior written permission.
     25   1.1    jruoho  *
     26   1.1    jruoho  * Alternatively, this software may be distributed under the terms of the
     27   1.1    jruoho  * GNU General Public License ("GPL") version 2 as published by the Free
     28   1.1    jruoho  * Software Foundation.
     29   1.1    jruoho  *
     30   1.1    jruoho  * NO WARRANTY
     31   1.1    jruoho  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     32   1.1    jruoho  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     33   1.1    jruoho  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
     34   1.1    jruoho  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     35   1.1    jruoho  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     36   1.1    jruoho  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     37   1.1    jruoho  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     38   1.1    jruoho  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     39   1.1    jruoho  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     40   1.1    jruoho  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     41   1.1    jruoho  * POSSIBILITY OF SUCH DAMAGES.
     42   1.1    jruoho  */
     43   1.1    jruoho 
     44   1.1    jruoho #include "acpi.h"
     45   1.1    jruoho #include "accommon.h"
     46   1.1    jruoho #include "acnamesp.h"
     47  1.11  christos #include "amlcode.h"
     48   1.1    jruoho 
     49   1.1    jruoho #define _COMPONENT          ACPI_UTILITIES
     50   1.1    jruoho         ACPI_MODULE_NAME    ("utdecode")
     51   1.1    jruoho 
     52   1.1    jruoho 
     53   1.1    jruoho /*
     54   1.1    jruoho  * Properties of the ACPI Object Types, both internal and external.
     55   1.1    jruoho  * The table is indexed by values of ACPI_OBJECT_TYPE
     56   1.1    jruoho  */
     57   1.1    jruoho const UINT8                     AcpiGbl_NsProperties[ACPI_NUM_NS_TYPES] =
     58   1.1    jruoho {
     59   1.1    jruoho     ACPI_NS_NORMAL,                     /* 00 Any              */
     60   1.1    jruoho     ACPI_NS_NORMAL,                     /* 01 Number           */
     61   1.1    jruoho     ACPI_NS_NORMAL,                     /* 02 String           */
     62   1.1    jruoho     ACPI_NS_NORMAL,                     /* 03 Buffer           */
     63   1.1    jruoho     ACPI_NS_NORMAL,                     /* 04 Package          */
     64   1.1    jruoho     ACPI_NS_NORMAL,                     /* 05 FieldUnit        */
     65   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 06 Device           */
     66   1.1    jruoho     ACPI_NS_NORMAL,                     /* 07 Event            */
     67   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 08 Method           */
     68   1.1    jruoho     ACPI_NS_NORMAL,                     /* 09 Mutex            */
     69   1.1    jruoho     ACPI_NS_NORMAL,                     /* 10 Region           */
     70   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 11 Power            */
     71   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 12 Processor        */
     72   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 13 Thermal          */
     73   1.1    jruoho     ACPI_NS_NORMAL,                     /* 14 BufferField      */
     74   1.1    jruoho     ACPI_NS_NORMAL,                     /* 15 DdbHandle        */
     75   1.1    jruoho     ACPI_NS_NORMAL,                     /* 16 Debug Object     */
     76   1.1    jruoho     ACPI_NS_NORMAL,                     /* 17 DefField         */
     77   1.1    jruoho     ACPI_NS_NORMAL,                     /* 18 BankField        */
     78   1.1    jruoho     ACPI_NS_NORMAL,                     /* 19 IndexField       */
     79   1.1    jruoho     ACPI_NS_NORMAL,                     /* 20 Reference        */
     80   1.1    jruoho     ACPI_NS_NORMAL,                     /* 21 Alias            */
     81   1.1    jruoho     ACPI_NS_NORMAL,                     /* 22 MethodAlias      */
     82   1.1    jruoho     ACPI_NS_NORMAL,                     /* 23 Notify           */
     83   1.1    jruoho     ACPI_NS_NORMAL,                     /* 24 Address Handler  */
     84   1.1    jruoho     ACPI_NS_NEWSCOPE | ACPI_NS_LOCAL,   /* 25 Resource Desc    */
     85   1.1    jruoho     ACPI_NS_NEWSCOPE | ACPI_NS_LOCAL,   /* 26 Resource Field   */
     86   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 27 Scope            */
     87   1.1    jruoho     ACPI_NS_NORMAL,                     /* 28 Extra            */
     88   1.1    jruoho     ACPI_NS_NORMAL,                     /* 29 Data             */
     89   1.1    jruoho     ACPI_NS_NORMAL                      /* 30 Invalid          */
     90   1.1    jruoho };
     91   1.1    jruoho 
     92   1.1    jruoho 
     93   1.1    jruoho /*******************************************************************************
     94   1.1    jruoho  *
     95   1.1    jruoho  * FUNCTION:    AcpiUtGetRegionName
     96   1.1    jruoho  *
     97   1.1    jruoho  * PARAMETERS:  Space ID            - ID for the region
     98   1.1    jruoho  *
     99   1.1    jruoho  * RETURN:      Decoded region SpaceId name
    100   1.1    jruoho  *
    101   1.1    jruoho  * DESCRIPTION: Translate a Space ID into a name string (Debug only)
    102   1.1    jruoho  *
    103   1.1    jruoho  ******************************************************************************/
    104   1.1    jruoho 
    105   1.1    jruoho /* Region type decoding */
    106   1.1    jruoho 
    107   1.1    jruoho const char        *AcpiGbl_RegionTypes[ACPI_NUM_PREDEFINED_REGIONS] =
    108   1.1    jruoho {
    109   1.5  christos     "SystemMemory",     /* 0x00 */
    110   1.5  christos     "SystemIO",         /* 0x01 */
    111   1.5  christos     "PCI_Config",       /* 0x02 */
    112   1.5  christos     "EmbeddedControl",  /* 0x03 */
    113   1.5  christos     "SMBus",            /* 0x04 */
    114   1.5  christos     "SystemCMOS",       /* 0x05 */
    115   1.5  christos     "PCIBARTarget",     /* 0x06 */
    116   1.5  christos     "IPMI",             /* 0x07 */
    117   1.5  christos     "GeneralPurposeIo", /* 0x08 */
    118   1.5  christos     "GenericSerialBus", /* 0x09 */
    119   1.5  christos     "PCC"               /* 0x0A */
    120   1.1    jruoho };
    121   1.1    jruoho 
    122   1.1    jruoho 
    123   1.2    jruoho const char *
    124   1.1    jruoho AcpiUtGetRegionName (
    125   1.1    jruoho     UINT8                   SpaceId)
    126   1.1    jruoho {
    127   1.1    jruoho 
    128   1.1    jruoho     if (SpaceId >= ACPI_USER_REGION_BEGIN)
    129   1.1    jruoho     {
    130   1.1    jruoho         return ("UserDefinedRegion");
    131   1.1    jruoho     }
    132   1.4    jruoho     else if (SpaceId == ACPI_ADR_SPACE_DATA_TABLE)
    133   1.4    jruoho     {
    134   1.4    jruoho         return ("DataTable");
    135   1.4    jruoho     }
    136   1.1    jruoho     else if (SpaceId == ACPI_ADR_SPACE_FIXED_HARDWARE)
    137   1.1    jruoho     {
    138   1.1    jruoho         return ("FunctionalFixedHW");
    139   1.1    jruoho     }
    140   1.1    jruoho     else if (SpaceId >= ACPI_NUM_PREDEFINED_REGIONS)
    141   1.1    jruoho     {
    142   1.1    jruoho         return ("InvalidSpaceId");
    143   1.1    jruoho     }
    144   1.1    jruoho 
    145   1.8  christos     return (AcpiGbl_RegionTypes[SpaceId]);
    146   1.1    jruoho }
    147   1.1    jruoho 
    148   1.1    jruoho 
    149   1.1    jruoho /*******************************************************************************
    150   1.1    jruoho  *
    151   1.1    jruoho  * FUNCTION:    AcpiUtGetEventName
    152   1.1    jruoho  *
    153   1.1    jruoho  * PARAMETERS:  EventId             - Fixed event ID
    154   1.1    jruoho  *
    155   1.1    jruoho  * RETURN:      Decoded event ID name
    156   1.1    jruoho  *
    157   1.1    jruoho  * DESCRIPTION: Translate a Event ID into a name string (Debug only)
    158   1.1    jruoho  *
    159   1.1    jruoho  ******************************************************************************/
    160   1.1    jruoho 
    161   1.1    jruoho /* Event type decoding */
    162   1.1    jruoho 
    163   1.1    jruoho static const char        *AcpiGbl_EventTypes[ACPI_NUM_FIXED_EVENTS] =
    164   1.1    jruoho {
    165   1.1    jruoho     "PM_Timer",
    166   1.1    jruoho     "GlobalLock",
    167   1.1    jruoho     "PowerButton",
    168   1.1    jruoho     "SleepButton",
    169   1.1    jruoho     "RealTimeClock",
    170   1.1    jruoho };
    171   1.1    jruoho 
    172   1.1    jruoho 
    173   1.2    jruoho const char *
    174   1.1    jruoho AcpiUtGetEventName (
    175   1.1    jruoho     UINT32                  EventId)
    176   1.1    jruoho {
    177   1.1    jruoho 
    178   1.1    jruoho     if (EventId > ACPI_EVENT_MAX)
    179   1.1    jruoho     {
    180   1.1    jruoho         return ("InvalidEventID");
    181   1.1    jruoho     }
    182   1.1    jruoho 
    183   1.8  christos     return (AcpiGbl_EventTypes[EventId]);
    184   1.1    jruoho }
    185   1.1    jruoho 
    186   1.1    jruoho 
    187   1.1    jruoho /*******************************************************************************
    188   1.1    jruoho  *
    189   1.1    jruoho  * FUNCTION:    AcpiUtGetTypeName
    190   1.1    jruoho  *
    191   1.1    jruoho  * PARAMETERS:  Type                - An ACPI object type
    192   1.1    jruoho  *
    193   1.1    jruoho  * RETURN:      Decoded ACPI object type name
    194   1.1    jruoho  *
    195   1.1    jruoho  * DESCRIPTION: Translate a Type ID into a name string (Debug only)
    196   1.1    jruoho  *
    197   1.1    jruoho  ******************************************************************************/
    198   1.1    jruoho 
    199   1.1    jruoho /*
    200   1.1    jruoho  * Elements of AcpiGbl_NsTypeNames below must match
    201   1.1    jruoho  * one-to-one with values of ACPI_OBJECT_TYPE
    202   1.1    jruoho  *
    203   1.1    jruoho  * The type ACPI_TYPE_ANY (Untyped) is used as a "don't care" when searching;
    204   1.1    jruoho  * when stored in a table it really means that we have thus far seen no
    205   1.8  christos  * evidence to indicate what type is actually going to be stored for this
    206   1.8  christos  & entry.
    207   1.1    jruoho  */
    208   1.1    jruoho static const char           AcpiGbl_BadType[] = "UNDEFINED";
    209   1.1    jruoho 
    210   1.1    jruoho /* Printable names of the ACPI object types */
    211   1.1    jruoho 
    212   1.1    jruoho static const char           *AcpiGbl_NsTypeNames[] =
    213   1.1    jruoho {
    214   1.1    jruoho     /* 00 */ "Untyped",
    215   1.1    jruoho     /* 01 */ "Integer",
    216   1.1    jruoho     /* 02 */ "String",
    217   1.1    jruoho     /* 03 */ "Buffer",
    218   1.1    jruoho     /* 04 */ "Package",
    219   1.1    jruoho     /* 05 */ "FieldUnit",
    220   1.1    jruoho     /* 06 */ "Device",
    221   1.1    jruoho     /* 07 */ "Event",
    222   1.1    jruoho     /* 08 */ "Method",
    223   1.1    jruoho     /* 09 */ "Mutex",
    224   1.1    jruoho     /* 10 */ "Region",
    225   1.1    jruoho     /* 11 */ "Power",
    226   1.1    jruoho     /* 12 */ "Processor",
    227   1.1    jruoho     /* 13 */ "Thermal",
    228   1.1    jruoho     /* 14 */ "BufferField",
    229   1.1    jruoho     /* 15 */ "DdbHandle",
    230   1.1    jruoho     /* 16 */ "DebugObject",
    231   1.1    jruoho     /* 17 */ "RegionField",
    232   1.1    jruoho     /* 18 */ "BankField",
    233   1.1    jruoho     /* 19 */ "IndexField",
    234   1.1    jruoho     /* 20 */ "Reference",
    235   1.1    jruoho     /* 21 */ "Alias",
    236   1.1    jruoho     /* 22 */ "MethodAlias",
    237   1.1    jruoho     /* 23 */ "Notify",
    238   1.1    jruoho     /* 24 */ "AddrHandler",
    239   1.1    jruoho     /* 25 */ "ResourceDesc",
    240   1.1    jruoho     /* 26 */ "ResourceFld",
    241   1.1    jruoho     /* 27 */ "Scope",
    242   1.1    jruoho     /* 28 */ "Extra",
    243   1.1    jruoho     /* 29 */ "Data",
    244   1.1    jruoho     /* 30 */ "Invalid"
    245   1.1    jruoho };
    246   1.1    jruoho 
    247   1.1    jruoho 
    248   1.8  christos const char *
    249   1.1    jruoho AcpiUtGetTypeName (
    250   1.1    jruoho     ACPI_OBJECT_TYPE        Type)
    251   1.1    jruoho {
    252   1.1    jruoho 
    253   1.1    jruoho     if (Type > ACPI_TYPE_INVALID)
    254   1.1    jruoho     {
    255   1.8  christos         return (AcpiGbl_BadType);
    256   1.1    jruoho     }
    257   1.1    jruoho 
    258   1.8  christos     return (AcpiGbl_NsTypeNames[Type]);
    259   1.1    jruoho }
    260   1.1    jruoho 
    261   1.1    jruoho 
    262   1.2    jruoho const char *
    263   1.1    jruoho AcpiUtGetObjectTypeName (
    264   1.1    jruoho     ACPI_OPERAND_OBJECT     *ObjDesc)
    265   1.1    jruoho {
    266   1.8  christos     ACPI_FUNCTION_TRACE (UtGetObjectTypeName);
    267   1.8  christos 
    268   1.1    jruoho 
    269   1.1    jruoho     if (!ObjDesc)
    270   1.1    jruoho     {
    271   1.8  christos         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Null Object Descriptor\n"));
    272  1.11  christos         return_STR ("[NULL Object Descriptor]");
    273   1.8  christos     }
    274   1.8  christos 
    275   1.8  christos     /* These descriptor types share a common area */
    276   1.8  christos 
    277   1.8  christos     if ((ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_OPERAND) &&
    278   1.8  christos         (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_NAMED))
    279   1.8  christos     {
    280   1.8  christos         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC,
    281   1.8  christos             "Invalid object descriptor type: 0x%2.2X [%s] (%p)\n",
    282   1.8  christos             ACPI_GET_DESCRIPTOR_TYPE (ObjDesc),
    283   1.8  christos             AcpiUtGetDescriptorName (ObjDesc), ObjDesc));
    284   1.8  christos 
    285  1.11  christos         return_STR ("Invalid object");
    286   1.1    jruoho     }
    287   1.1    jruoho 
    288  1.10  christos     return_STR (AcpiUtGetTypeName (ObjDesc->Common.Type));
    289   1.1    jruoho }
    290   1.1    jruoho 
    291   1.1    jruoho 
    292   1.1    jruoho /*******************************************************************************
    293   1.1    jruoho  *
    294   1.1    jruoho  * FUNCTION:    AcpiUtGetNodeName
    295   1.1    jruoho  *
    296   1.1    jruoho  * PARAMETERS:  Object               - A namespace node
    297   1.1    jruoho  *
    298   1.1    jruoho  * RETURN:      ASCII name of the node
    299   1.1    jruoho  *
    300   1.1    jruoho  * DESCRIPTION: Validate the node and return the node's ACPI name.
    301   1.1    jruoho  *
    302   1.1    jruoho  ******************************************************************************/
    303   1.1    jruoho 
    304   1.2    jruoho const char *
    305   1.1    jruoho AcpiUtGetNodeName (
    306   1.1    jruoho     void                    *Object)
    307   1.1    jruoho {
    308   1.1    jruoho     ACPI_NAMESPACE_NODE     *Node = (ACPI_NAMESPACE_NODE *) Object;
    309   1.1    jruoho 
    310   1.1    jruoho 
    311   1.1    jruoho     /* Must return a string of exactly 4 characters == ACPI_NAME_SIZE */
    312   1.1    jruoho 
    313   1.1    jruoho     if (!Object)
    314   1.1    jruoho     {
    315   1.1    jruoho         return ("NULL");
    316   1.1    jruoho     }
    317   1.1    jruoho 
    318   1.1    jruoho     /* Check for Root node */
    319   1.1    jruoho 
    320   1.1    jruoho     if ((Object == ACPI_ROOT_OBJECT) ||
    321   1.1    jruoho         (Object == AcpiGbl_RootNode))
    322   1.1    jruoho     {
    323   1.1    jruoho         return ("\"\\\" ");
    324   1.1    jruoho     }
    325   1.1    jruoho 
    326   1.1    jruoho     /* Descriptor must be a namespace node */
    327   1.1    jruoho 
    328   1.1    jruoho     if (ACPI_GET_DESCRIPTOR_TYPE (Node) != ACPI_DESC_TYPE_NAMED)
    329   1.1    jruoho     {
    330   1.1    jruoho         return ("####");
    331   1.1    jruoho     }
    332   1.1    jruoho 
    333   1.1    jruoho     /*
    334   1.1    jruoho      * Ensure name is valid. The name was validated/repaired when the node
    335   1.1    jruoho      * was created, but make sure it has not been corrupted.
    336   1.1    jruoho      */
    337   1.1    jruoho     AcpiUtRepairName (Node->Name.Ascii);
    338   1.1    jruoho 
    339   1.1    jruoho     /* Return the name */
    340   1.1    jruoho 
    341   1.1    jruoho     return (Node->Name.Ascii);
    342   1.1    jruoho }
    343   1.1    jruoho 
    344   1.1    jruoho 
    345   1.1    jruoho /*******************************************************************************
    346   1.1    jruoho  *
    347   1.1    jruoho  * FUNCTION:    AcpiUtGetDescriptorName
    348   1.1    jruoho  *
    349   1.1    jruoho  * PARAMETERS:  Object               - An ACPI object
    350   1.1    jruoho  *
    351   1.1    jruoho  * RETURN:      Decoded name of the descriptor type
    352   1.1    jruoho  *
    353   1.1    jruoho  * DESCRIPTION: Validate object and return the descriptor type
    354   1.1    jruoho  *
    355   1.1    jruoho  ******************************************************************************/
    356   1.1    jruoho 
    357   1.1    jruoho /* Printable names of object descriptor types */
    358   1.1    jruoho 
    359   1.1    jruoho static const char           *AcpiGbl_DescTypeNames[] =
    360   1.1    jruoho {
    361   1.1    jruoho     /* 00 */ "Not a Descriptor",
    362   1.1    jruoho     /* 01 */ "Cached",
    363   1.1    jruoho     /* 02 */ "State-Generic",
    364   1.1    jruoho     /* 03 */ "State-Update",
    365   1.1    jruoho     /* 04 */ "State-Package",
    366   1.1    jruoho     /* 05 */ "State-Control",
    367   1.1    jruoho     /* 06 */ "State-RootParseScope",
    368   1.1    jruoho     /* 07 */ "State-ParseScope",
    369   1.1    jruoho     /* 08 */ "State-WalkScope",
    370   1.1    jruoho     /* 09 */ "State-Result",
    371   1.1    jruoho     /* 10 */ "State-Notify",
    372   1.1    jruoho     /* 11 */ "State-Thread",
    373   1.1    jruoho     /* 12 */ "Walk",
    374   1.1    jruoho     /* 13 */ "Parser",
    375   1.1    jruoho     /* 14 */ "Operand",
    376   1.1    jruoho     /* 15 */ "Node"
    377   1.1    jruoho };
    378   1.1    jruoho 
    379   1.1    jruoho 
    380   1.2    jruoho const char *
    381   1.1    jruoho AcpiUtGetDescriptorName (
    382   1.1    jruoho     void                    *Object)
    383   1.1    jruoho {
    384   1.1    jruoho 
    385   1.1    jruoho     if (!Object)
    386   1.1    jruoho     {
    387   1.1    jruoho         return ("NULL OBJECT");
    388   1.1    jruoho     }
    389   1.1    jruoho 
    390   1.1    jruoho     if (ACPI_GET_DESCRIPTOR_TYPE (Object) > ACPI_DESC_TYPE_MAX)
    391   1.1    jruoho     {
    392   1.1    jruoho         return ("Not a Descriptor");
    393   1.1    jruoho     }
    394   1.1    jruoho 
    395   1.8  christos     return (AcpiGbl_DescTypeNames[ACPI_GET_DESCRIPTOR_TYPE (Object)]);
    396   1.1    jruoho }
    397   1.1    jruoho 
    398   1.1    jruoho 
    399   1.1    jruoho /*******************************************************************************
    400   1.1    jruoho  *
    401   1.1    jruoho  * FUNCTION:    AcpiUtGetReferenceName
    402   1.1    jruoho  *
    403   1.1    jruoho  * PARAMETERS:  Object               - An ACPI reference object
    404   1.1    jruoho  *
    405   1.1    jruoho  * RETURN:      Decoded name of the type of reference
    406   1.1    jruoho  *
    407   1.1    jruoho  * DESCRIPTION: Decode a reference object sub-type to a string.
    408   1.1    jruoho  *
    409   1.1    jruoho  ******************************************************************************/
    410   1.1    jruoho 
    411   1.1    jruoho /* Printable names of reference object sub-types */
    412   1.1    jruoho 
    413   1.1    jruoho static const char           *AcpiGbl_RefClassNames[] =
    414   1.1    jruoho {
    415   1.1    jruoho     /* 00 */ "Local",
    416   1.1    jruoho     /* 01 */ "Argument",
    417   1.1    jruoho     /* 02 */ "RefOf",
    418   1.1    jruoho     /* 03 */ "Index",
    419   1.1    jruoho     /* 04 */ "DdbHandle",
    420   1.1    jruoho     /* 05 */ "Named Object",
    421   1.1    jruoho     /* 06 */ "Debug"
    422   1.1    jruoho };
    423   1.1    jruoho 
    424   1.1    jruoho const char *
    425   1.1    jruoho AcpiUtGetReferenceName (
    426   1.1    jruoho     ACPI_OPERAND_OBJECT     *Object)
    427   1.1    jruoho {
    428   1.1    jruoho 
    429   1.1    jruoho     if (!Object)
    430   1.1    jruoho     {
    431   1.1    jruoho         return ("NULL Object");
    432   1.1    jruoho     }
    433   1.1    jruoho 
    434   1.1    jruoho     if (ACPI_GET_DESCRIPTOR_TYPE (Object) != ACPI_DESC_TYPE_OPERAND)
    435   1.1    jruoho     {
    436   1.1    jruoho         return ("Not an Operand object");
    437   1.1    jruoho     }
    438   1.1    jruoho 
    439   1.1    jruoho     if (Object->Common.Type != ACPI_TYPE_LOCAL_REFERENCE)
    440   1.1    jruoho     {
    441   1.1    jruoho         return ("Not a Reference object");
    442   1.1    jruoho     }
    443   1.1    jruoho 
    444   1.1    jruoho     if (Object->Reference.Class > ACPI_REFCLASS_MAX)
    445   1.1    jruoho     {
    446   1.1    jruoho         return ("Unknown Reference class");
    447   1.1    jruoho     }
    448   1.1    jruoho 
    449   1.1    jruoho     return (AcpiGbl_RefClassNames[Object->Reference.Class]);
    450   1.1    jruoho }
    451   1.1    jruoho 
    452   1.1    jruoho 
    453   1.1    jruoho /*******************************************************************************
    454   1.1    jruoho  *
    455   1.1    jruoho  * FUNCTION:    AcpiUtGetMutexName
    456   1.1    jruoho  *
    457   1.1    jruoho  * PARAMETERS:  MutexId         - The predefined ID for this mutex.
    458   1.1    jruoho  *
    459   1.1    jruoho  * RETURN:      Decoded name of the internal mutex
    460   1.1    jruoho  *
    461   1.1    jruoho  * DESCRIPTION: Translate a mutex ID into a name string (Debug only)
    462   1.1    jruoho  *
    463   1.1    jruoho  ******************************************************************************/
    464   1.1    jruoho 
    465   1.1    jruoho /* Names for internal mutex objects, used for debug output */
    466   1.1    jruoho 
    467   1.8  christos static const char           *AcpiGbl_MutexNames[ACPI_NUM_MUTEX] =
    468   1.1    jruoho {
    469   1.1    jruoho     "ACPI_MTX_Interpreter",
    470   1.1    jruoho     "ACPI_MTX_Namespace",
    471   1.1    jruoho     "ACPI_MTX_Tables",
    472   1.1    jruoho     "ACPI_MTX_Events",
    473   1.1    jruoho     "ACPI_MTX_Caches",
    474   1.1    jruoho     "ACPI_MTX_Memory",
    475   1.1    jruoho };
    476   1.1    jruoho 
    477   1.2    jruoho const char *
    478   1.1    jruoho AcpiUtGetMutexName (
    479   1.1    jruoho     UINT32                  MutexId)
    480   1.1    jruoho {
    481   1.1    jruoho 
    482   1.1    jruoho     if (MutexId > ACPI_MAX_MUTEX)
    483   1.1    jruoho     {
    484   1.1    jruoho         return ("Invalid Mutex ID");
    485   1.1    jruoho     }
    486   1.1    jruoho 
    487   1.1    jruoho     return (AcpiGbl_MutexNames[MutexId]);
    488   1.1    jruoho }
    489   1.1    jruoho 
    490   1.1    jruoho 
    491  1.13  christos #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)
    492  1.13  christos 
    493  1.13  christos /*
    494  1.13  christos  * Strings and procedures used for debug only
    495  1.13  christos  */
    496  1.13  christos 
    497   1.1    jruoho /*******************************************************************************
    498   1.1    jruoho  *
    499   1.1    jruoho  * FUNCTION:    AcpiUtGetNotifyName
    500   1.1    jruoho  *
    501   1.1    jruoho  * PARAMETERS:  NotifyValue     - Value from the Notify() request
    502   1.1    jruoho  *
    503   1.1    jruoho  * RETURN:      Decoded name for the notify value
    504   1.1    jruoho  *
    505   1.1    jruoho  * DESCRIPTION: Translate a Notify Value to a notify namestring.
    506   1.1    jruoho  *
    507   1.1    jruoho  ******************************************************************************/
    508   1.1    jruoho 
    509   1.1    jruoho /* Names for Notify() values, used for debug output */
    510   1.1    jruoho 
    511   1.9  christos static const char           *AcpiGbl_GenericNotify[ACPI_GENERIC_NOTIFY_MAX + 1] =
    512   1.1    jruoho {
    513   1.5  christos     /* 00 */ "Bus Check",
    514   1.5  christos     /* 01 */ "Device Check",
    515   1.5  christos     /* 02 */ "Device Wake",
    516   1.5  christos     /* 03 */ "Eject Request",
    517   1.5  christos     /* 04 */ "Device Check Light",
    518   1.5  christos     /* 05 */ "Frequency Mismatch",
    519   1.5  christos     /* 06 */ "Bus Mode Mismatch",
    520   1.5  christos     /* 07 */ "Power Fault",
    521   1.5  christos     /* 08 */ "Capabilities Check",
    522   1.5  christos     /* 09 */ "Device PLD Check",
    523   1.6  christos     /* 0A */ "Reserved",
    524   1.6  christos     /* 0B */ "System Locality Update",
    525  1.12  christos     /* 0C */ "Reserved (was previously Shutdown Request)",  /* Reserved in ACPI 6.0 */
    526  1.12  christos     /* 0D */ "System Resource Affinity Update",
    527  1.12  christos     /* 0E */ "Heterogeneous Memory Attributes Update"       /* ACPI 6.2 */
    528   1.6  christos };
    529   1.6  christos 
    530   1.9  christos static const char           *AcpiGbl_DeviceNotify[5] =
    531   1.6  christos {
    532   1.6  christos     /* 80 */ "Status Change",
    533   1.6  christos     /* 81 */ "Information Change",
    534   1.6  christos     /* 82 */ "Device-Specific Change",
    535   1.9  christos     /* 83 */ "Device-Specific Change",
    536   1.9  christos     /* 84 */ "Reserved"
    537   1.1    jruoho };
    538   1.1    jruoho 
    539   1.9  christos static const char           *AcpiGbl_ProcessorNotify[5] =
    540   1.6  christos {
    541   1.6  christos     /* 80 */ "Performance Capability Change",
    542   1.6  christos     /* 81 */ "C-State Change",
    543   1.6  christos     /* 82 */ "Throttling Capability Change",
    544   1.9  christos     /* 83 */ "Guaranteed Change",
    545   1.9  christos     /* 84 */ "Minimum Excursion"
    546   1.6  christos };
    547   1.6  christos 
    548   1.9  christos static const char           *AcpiGbl_ThermalNotify[5] =
    549   1.6  christos {
    550   1.6  christos     /* 80 */ "Thermal Status Change",
    551   1.6  christos     /* 81 */ "Thermal Trip Point Change",
    552   1.6  christos     /* 82 */ "Thermal Device List Change",
    553   1.9  christos     /* 83 */ "Thermal Relationship Change",
    554   1.9  christos     /* 84 */ "Reserved"
    555   1.6  christos };
    556   1.6  christos 
    557   1.6  christos 
    558   1.1    jruoho const char *
    559   1.1    jruoho AcpiUtGetNotifyName (
    560   1.6  christos     UINT32                  NotifyValue,
    561   1.6  christos     ACPI_OBJECT_TYPE        Type)
    562   1.1    jruoho {
    563   1.1    jruoho 
    564   1.9  christos     /* 00 - 0D are "common to all object types" (from ACPI Spec) */
    565   1.6  christos 
    566   1.9  christos     if (NotifyValue <= ACPI_GENERIC_NOTIFY_MAX)
    567   1.1    jruoho     {
    568   1.6  christos         return (AcpiGbl_GenericNotify[NotifyValue]);
    569   1.1    jruoho     }
    570   1.6  christos 
    571   1.9  christos     /* 0E - 7F are reserved */
    572   1.6  christos 
    573   1.6  christos     if (NotifyValue <= ACPI_MAX_SYS_NOTIFY)
    574   1.1    jruoho     {
    575   1.1    jruoho         return ("Reserved");
    576   1.1    jruoho     }
    577   1.6  christos 
    578   1.9  christos     /* 80 - 84 are per-object-type */
    579   1.6  christos 
    580   1.9  christos     if (NotifyValue <= ACPI_SPECIFIC_NOTIFY_MAX)
    581   1.5  christos     {
    582   1.6  christos         switch (Type)
    583   1.6  christos         {
    584   1.6  christos         case ACPI_TYPE_ANY:
    585   1.6  christos         case ACPI_TYPE_DEVICE:
    586   1.6  christos             return (AcpiGbl_DeviceNotify [NotifyValue - 0x80]);
    587   1.6  christos 
    588   1.6  christos         case ACPI_TYPE_PROCESSOR:
    589   1.6  christos             return (AcpiGbl_ProcessorNotify [NotifyValue - 0x80]);
    590   1.6  christos 
    591   1.6  christos         case ACPI_TYPE_THERMAL:
    592   1.6  christos             return (AcpiGbl_ThermalNotify [NotifyValue - 0x80]);
    593   1.6  christos 
    594   1.6  christos         default:
    595   1.6  christos             return ("Target object type does not support notifies");
    596   1.6  christos         }
    597   1.5  christos     }
    598   1.6  christos 
    599   1.6  christos     /* 84 - BF are device-specific */
    600   1.6  christos 
    601   1.6  christos     if (NotifyValue <= ACPI_MAX_DEVICE_SPECIFIC_NOTIFY)
    602   1.1    jruoho     {
    603   1.6  christos         return ("Device-Specific");
    604   1.1    jruoho     }
    605   1.6  christos 
    606   1.6  christos     /* C0 and above are hardware-specific */
    607   1.6  christos 
    608   1.6  christos     return ("Hardware-Specific");
    609   1.1    jruoho }
    610  1.11  christos 
    611  1.11  christos 
    612  1.11  christos /*******************************************************************************
    613  1.11  christos  *
    614  1.11  christos  * FUNCTION:    AcpiUtGetArgumentTypeName
    615  1.11  christos  *
    616  1.11  christos  * PARAMETERS:  ArgType             - an ARGP_* parser argument type
    617  1.11  christos  *
    618  1.11  christos  * RETURN:      Decoded ARGP_* type
    619  1.11  christos  *
    620  1.11  christos  * DESCRIPTION: Decode an ARGP_* parser type, as defined in the amlcode.h file,
    621  1.11  christos  *              and used in the acopcode.h file. For example, ARGP_TERMARG.
    622  1.11  christos  *              Used for debug only.
    623  1.11  christos  *
    624  1.11  christos  ******************************************************************************/
    625  1.11  christos 
    626  1.11  christos static const char           *AcpiGbl_ArgumentType[20] =
    627  1.11  christos {
    628  1.11  christos     /* 00 */ "Unknown ARGP",
    629  1.11  christos     /* 01 */ "ByteData",
    630  1.11  christos     /* 02 */ "ByteList",
    631  1.11  christos     /* 03 */ "CharList",
    632  1.11  christos     /* 04 */ "DataObject",
    633  1.11  christos     /* 05 */ "DataObjectList",
    634  1.11  christos     /* 06 */ "DWordData",
    635  1.11  christos     /* 07 */ "FieldList",
    636  1.11  christos     /* 08 */ "Name",
    637  1.11  christos     /* 09 */ "NameString",
    638  1.11  christos     /* 0A */ "ObjectList",
    639  1.11  christos     /* 0B */ "PackageLength",
    640  1.11  christos     /* 0C */ "SuperName",
    641  1.11  christos     /* 0D */ "Target",
    642  1.11  christos     /* 0E */ "TermArg",
    643  1.11  christos     /* 0F */ "TermList",
    644  1.11  christos     /* 10 */ "WordData",
    645  1.11  christos     /* 11 */ "QWordData",
    646  1.11  christos     /* 12 */ "SimpleName",
    647  1.11  christos     /* 13 */ "NameOrRef"
    648  1.11  christos };
    649  1.11  christos 
    650  1.11  christos const char *
    651  1.11  christos AcpiUtGetArgumentTypeName (
    652  1.11  christos     UINT32                  ArgType)
    653  1.11  christos {
    654  1.11  christos 
    655  1.11  christos     if (ArgType > ARGP_MAX)
    656  1.11  christos     {
    657  1.11  christos         return ("Unknown ARGP");
    658  1.11  christos     }
    659  1.11  christos 
    660  1.11  christos     return (AcpiGbl_ArgumentType[ArgType]);
    661  1.11  christos }
    662  1.11  christos 
    663   1.1    jruoho #endif
    664   1.1    jruoho 
    665   1.1    jruoho 
    666   1.1    jruoho /*******************************************************************************
    667   1.1    jruoho  *
    668   1.1    jruoho  * FUNCTION:    AcpiUtValidObjectType
    669   1.1    jruoho  *
    670   1.1    jruoho  * PARAMETERS:  Type            - Object type to be validated
    671   1.1    jruoho  *
    672   1.1    jruoho  * RETURN:      TRUE if valid object type, FALSE otherwise
    673   1.1    jruoho  *
    674   1.1    jruoho  * DESCRIPTION: Validate an object type
    675   1.1    jruoho  *
    676   1.1    jruoho  ******************************************************************************/
    677   1.1    jruoho 
    678   1.1    jruoho BOOLEAN
    679   1.1    jruoho AcpiUtValidObjectType (
    680   1.1    jruoho     ACPI_OBJECT_TYPE        Type)
    681   1.1    jruoho {
    682   1.1    jruoho 
    683   1.1    jruoho     if (Type > ACPI_TYPE_LOCAL_MAX)
    684   1.1    jruoho     {
    685   1.1    jruoho         /* Note: Assumes all TYPEs are contiguous (external/local) */
    686   1.1    jruoho 
    687   1.1    jruoho         return (FALSE);
    688   1.1    jruoho     }
    689   1.1    jruoho 
    690   1.1    jruoho     return (TRUE);
    691   1.1    jruoho }
    692