Home | History | Annotate | Line # | Download | only in utilities
utdecode.c revision 1.10
      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.8  christos  * Copyright (C) 2000 - 2016, 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.1    jruoho 
     48   1.1    jruoho #define _COMPONENT          ACPI_UTILITIES
     49   1.1    jruoho         ACPI_MODULE_NAME    ("utdecode")
     50   1.1    jruoho 
     51   1.1    jruoho 
     52   1.1    jruoho /*
     53   1.1    jruoho  * Properties of the ACPI Object Types, both internal and external.
     54   1.1    jruoho  * The table is indexed by values of ACPI_OBJECT_TYPE
     55   1.1    jruoho  */
     56   1.1    jruoho const UINT8                     AcpiGbl_NsProperties[ACPI_NUM_NS_TYPES] =
     57   1.1    jruoho {
     58   1.1    jruoho     ACPI_NS_NORMAL,                     /* 00 Any              */
     59   1.1    jruoho     ACPI_NS_NORMAL,                     /* 01 Number           */
     60   1.1    jruoho     ACPI_NS_NORMAL,                     /* 02 String           */
     61   1.1    jruoho     ACPI_NS_NORMAL,                     /* 03 Buffer           */
     62   1.1    jruoho     ACPI_NS_NORMAL,                     /* 04 Package          */
     63   1.1    jruoho     ACPI_NS_NORMAL,                     /* 05 FieldUnit        */
     64   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 06 Device           */
     65   1.1    jruoho     ACPI_NS_NORMAL,                     /* 07 Event            */
     66   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 08 Method           */
     67   1.1    jruoho     ACPI_NS_NORMAL,                     /* 09 Mutex            */
     68   1.1    jruoho     ACPI_NS_NORMAL,                     /* 10 Region           */
     69   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 11 Power            */
     70   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 12 Processor        */
     71   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 13 Thermal          */
     72   1.1    jruoho     ACPI_NS_NORMAL,                     /* 14 BufferField      */
     73   1.1    jruoho     ACPI_NS_NORMAL,                     /* 15 DdbHandle        */
     74   1.1    jruoho     ACPI_NS_NORMAL,                     /* 16 Debug Object     */
     75   1.1    jruoho     ACPI_NS_NORMAL,                     /* 17 DefField         */
     76   1.1    jruoho     ACPI_NS_NORMAL,                     /* 18 BankField        */
     77   1.1    jruoho     ACPI_NS_NORMAL,                     /* 19 IndexField       */
     78   1.1    jruoho     ACPI_NS_NORMAL,                     /* 20 Reference        */
     79   1.1    jruoho     ACPI_NS_NORMAL,                     /* 21 Alias            */
     80   1.1    jruoho     ACPI_NS_NORMAL,                     /* 22 MethodAlias      */
     81   1.1    jruoho     ACPI_NS_NORMAL,                     /* 23 Notify           */
     82   1.1    jruoho     ACPI_NS_NORMAL,                     /* 24 Address Handler  */
     83   1.1    jruoho     ACPI_NS_NEWSCOPE | ACPI_NS_LOCAL,   /* 25 Resource Desc    */
     84   1.1    jruoho     ACPI_NS_NEWSCOPE | ACPI_NS_LOCAL,   /* 26 Resource Field   */
     85   1.1    jruoho     ACPI_NS_NEWSCOPE,                   /* 27 Scope            */
     86   1.1    jruoho     ACPI_NS_NORMAL,                     /* 28 Extra            */
     87   1.1    jruoho     ACPI_NS_NORMAL,                     /* 29 Data             */
     88   1.1    jruoho     ACPI_NS_NORMAL                      /* 30 Invalid          */
     89   1.1    jruoho };
     90   1.1    jruoho 
     91   1.1    jruoho 
     92   1.1    jruoho /*******************************************************************************
     93   1.1    jruoho  *
     94   1.1    jruoho  * FUNCTION:    AcpiUtGetRegionName
     95   1.1    jruoho  *
     96   1.1    jruoho  * PARAMETERS:  Space ID            - ID for the region
     97   1.1    jruoho  *
     98   1.1    jruoho  * RETURN:      Decoded region SpaceId name
     99   1.1    jruoho  *
    100   1.1    jruoho  * DESCRIPTION: Translate a Space ID into a name string (Debug only)
    101   1.1    jruoho  *
    102   1.1    jruoho  ******************************************************************************/
    103   1.1    jruoho 
    104   1.1    jruoho /* Region type decoding */
    105   1.1    jruoho 
    106   1.1    jruoho const char        *AcpiGbl_RegionTypes[ACPI_NUM_PREDEFINED_REGIONS] =
    107   1.1    jruoho {
    108   1.5  christos     "SystemMemory",     /* 0x00 */
    109   1.5  christos     "SystemIO",         /* 0x01 */
    110   1.5  christos     "PCI_Config",       /* 0x02 */
    111   1.5  christos     "EmbeddedControl",  /* 0x03 */
    112   1.5  christos     "SMBus",            /* 0x04 */
    113   1.5  christos     "SystemCMOS",       /* 0x05 */
    114   1.5  christos     "PCIBARTarget",     /* 0x06 */
    115   1.5  christos     "IPMI",             /* 0x07 */
    116   1.5  christos     "GeneralPurposeIo", /* 0x08 */
    117   1.5  christos     "GenericSerialBus", /* 0x09 */
    118   1.5  christos     "PCC"               /* 0x0A */
    119   1.1    jruoho };
    120   1.1    jruoho 
    121   1.1    jruoho 
    122   1.2    jruoho const char *
    123   1.1    jruoho AcpiUtGetRegionName (
    124   1.1    jruoho     UINT8                   SpaceId)
    125   1.1    jruoho {
    126   1.1    jruoho 
    127   1.1    jruoho     if (SpaceId >= ACPI_USER_REGION_BEGIN)
    128   1.1    jruoho     {
    129   1.1    jruoho         return ("UserDefinedRegion");
    130   1.1    jruoho     }
    131   1.4    jruoho     else if (SpaceId == ACPI_ADR_SPACE_DATA_TABLE)
    132   1.4    jruoho     {
    133   1.4    jruoho         return ("DataTable");
    134   1.4    jruoho     }
    135   1.1    jruoho     else if (SpaceId == ACPI_ADR_SPACE_FIXED_HARDWARE)
    136   1.1    jruoho     {
    137   1.1    jruoho         return ("FunctionalFixedHW");
    138   1.1    jruoho     }
    139   1.1    jruoho     else if (SpaceId >= ACPI_NUM_PREDEFINED_REGIONS)
    140   1.1    jruoho     {
    141   1.1    jruoho         return ("InvalidSpaceId");
    142   1.1    jruoho     }
    143   1.1    jruoho 
    144   1.8  christos     return (AcpiGbl_RegionTypes[SpaceId]);
    145   1.1    jruoho }
    146   1.1    jruoho 
    147   1.1    jruoho 
    148   1.1    jruoho /*******************************************************************************
    149   1.1    jruoho  *
    150   1.1    jruoho  * FUNCTION:    AcpiUtGetEventName
    151   1.1    jruoho  *
    152   1.1    jruoho  * PARAMETERS:  EventId             - Fixed event ID
    153   1.1    jruoho  *
    154   1.1    jruoho  * RETURN:      Decoded event ID name
    155   1.1    jruoho  *
    156   1.1    jruoho  * DESCRIPTION: Translate a Event ID into a name string (Debug only)
    157   1.1    jruoho  *
    158   1.1    jruoho  ******************************************************************************/
    159   1.1    jruoho 
    160   1.1    jruoho /* Event type decoding */
    161   1.1    jruoho 
    162   1.1    jruoho static const char        *AcpiGbl_EventTypes[ACPI_NUM_FIXED_EVENTS] =
    163   1.1    jruoho {
    164   1.1    jruoho     "PM_Timer",
    165   1.1    jruoho     "GlobalLock",
    166   1.1    jruoho     "PowerButton",
    167   1.1    jruoho     "SleepButton",
    168   1.1    jruoho     "RealTimeClock",
    169   1.1    jruoho };
    170   1.1    jruoho 
    171   1.1    jruoho 
    172   1.2    jruoho const char *
    173   1.1    jruoho AcpiUtGetEventName (
    174   1.1    jruoho     UINT32                  EventId)
    175   1.1    jruoho {
    176   1.1    jruoho 
    177   1.1    jruoho     if (EventId > ACPI_EVENT_MAX)
    178   1.1    jruoho     {
    179   1.1    jruoho         return ("InvalidEventID");
    180   1.1    jruoho     }
    181   1.1    jruoho 
    182   1.8  christos     return (AcpiGbl_EventTypes[EventId]);
    183   1.1    jruoho }
    184   1.1    jruoho 
    185   1.1    jruoho 
    186   1.1    jruoho /*******************************************************************************
    187   1.1    jruoho  *
    188   1.1    jruoho  * FUNCTION:    AcpiUtGetTypeName
    189   1.1    jruoho  *
    190   1.1    jruoho  * PARAMETERS:  Type                - An ACPI object type
    191   1.1    jruoho  *
    192   1.1    jruoho  * RETURN:      Decoded ACPI object type name
    193   1.1    jruoho  *
    194   1.1    jruoho  * DESCRIPTION: Translate a Type ID into a name string (Debug only)
    195   1.1    jruoho  *
    196   1.1    jruoho  ******************************************************************************/
    197   1.1    jruoho 
    198   1.1    jruoho /*
    199   1.1    jruoho  * Elements of AcpiGbl_NsTypeNames below must match
    200   1.1    jruoho  * one-to-one with values of ACPI_OBJECT_TYPE
    201   1.1    jruoho  *
    202   1.1    jruoho  * The type ACPI_TYPE_ANY (Untyped) is used as a "don't care" when searching;
    203   1.1    jruoho  * when stored in a table it really means that we have thus far seen no
    204   1.8  christos  * evidence to indicate what type is actually going to be stored for this
    205   1.8  christos  & entry.
    206   1.1    jruoho  */
    207   1.1    jruoho static const char           AcpiGbl_BadType[] = "UNDEFINED";
    208   1.1    jruoho 
    209   1.1    jruoho /* Printable names of the ACPI object types */
    210   1.1    jruoho 
    211   1.1    jruoho static const char           *AcpiGbl_NsTypeNames[] =
    212   1.1    jruoho {
    213   1.1    jruoho     /* 00 */ "Untyped",
    214   1.1    jruoho     /* 01 */ "Integer",
    215   1.1    jruoho     /* 02 */ "String",
    216   1.1    jruoho     /* 03 */ "Buffer",
    217   1.1    jruoho     /* 04 */ "Package",
    218   1.1    jruoho     /* 05 */ "FieldUnit",
    219   1.1    jruoho     /* 06 */ "Device",
    220   1.1    jruoho     /* 07 */ "Event",
    221   1.1    jruoho     /* 08 */ "Method",
    222   1.1    jruoho     /* 09 */ "Mutex",
    223   1.1    jruoho     /* 10 */ "Region",
    224   1.1    jruoho     /* 11 */ "Power",
    225   1.1    jruoho     /* 12 */ "Processor",
    226   1.1    jruoho     /* 13 */ "Thermal",
    227   1.1    jruoho     /* 14 */ "BufferField",
    228   1.1    jruoho     /* 15 */ "DdbHandle",
    229   1.1    jruoho     /* 16 */ "DebugObject",
    230   1.1    jruoho     /* 17 */ "RegionField",
    231   1.1    jruoho     /* 18 */ "BankField",
    232   1.1    jruoho     /* 19 */ "IndexField",
    233   1.1    jruoho     /* 20 */ "Reference",
    234   1.1    jruoho     /* 21 */ "Alias",
    235   1.1    jruoho     /* 22 */ "MethodAlias",
    236   1.1    jruoho     /* 23 */ "Notify",
    237   1.1    jruoho     /* 24 */ "AddrHandler",
    238   1.1    jruoho     /* 25 */ "ResourceDesc",
    239   1.1    jruoho     /* 26 */ "ResourceFld",
    240   1.1    jruoho     /* 27 */ "Scope",
    241   1.1    jruoho     /* 28 */ "Extra",
    242   1.1    jruoho     /* 29 */ "Data",
    243   1.1    jruoho     /* 30 */ "Invalid"
    244   1.1    jruoho };
    245   1.1    jruoho 
    246   1.1    jruoho 
    247   1.8  christos const char *
    248   1.1    jruoho AcpiUtGetTypeName (
    249   1.1    jruoho     ACPI_OBJECT_TYPE        Type)
    250   1.1    jruoho {
    251   1.1    jruoho 
    252   1.1    jruoho     if (Type > ACPI_TYPE_INVALID)
    253   1.1    jruoho     {
    254   1.8  christos         return (AcpiGbl_BadType);
    255   1.1    jruoho     }
    256   1.1    jruoho 
    257   1.8  christos     return (AcpiGbl_NsTypeNames[Type]);
    258   1.1    jruoho }
    259   1.1    jruoho 
    260   1.1    jruoho 
    261   1.2    jruoho const char *
    262   1.1    jruoho AcpiUtGetObjectTypeName (
    263   1.1    jruoho     ACPI_OPERAND_OBJECT     *ObjDesc)
    264   1.1    jruoho {
    265   1.8  christos     ACPI_FUNCTION_TRACE (UtGetObjectTypeName);
    266   1.8  christos 
    267   1.1    jruoho 
    268   1.1    jruoho     if (!ObjDesc)
    269   1.1    jruoho     {
    270   1.8  christos         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Null Object Descriptor\n"));
    271   1.8  christos         return_PTR (__UNCONST("[NULL Object Descriptor]"));
    272   1.8  christos     }
    273   1.8  christos 
    274   1.8  christos     /* These descriptor types share a common area */
    275   1.8  christos 
    276   1.8  christos     if ((ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_OPERAND) &&
    277   1.8  christos         (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_NAMED))
    278   1.8  christos     {
    279   1.8  christos         ACPI_DEBUG_PRINT ((ACPI_DB_EXEC,
    280   1.8  christos             "Invalid object descriptor type: 0x%2.2X [%s] (%p)\n",
    281   1.8  christos             ACPI_GET_DESCRIPTOR_TYPE (ObjDesc),
    282   1.8  christos             AcpiUtGetDescriptorName (ObjDesc), ObjDesc));
    283   1.8  christos 
    284   1.8  christos         return_PTR (__UNCONST("Invalid object"));
    285   1.1    jruoho     }
    286   1.1    jruoho 
    287  1.10  christos     return_STR (AcpiUtGetTypeName (ObjDesc->Common.Type));
    288   1.1    jruoho }
    289   1.1    jruoho 
    290   1.1    jruoho 
    291   1.1    jruoho /*******************************************************************************
    292   1.1    jruoho  *
    293   1.1    jruoho  * FUNCTION:    AcpiUtGetNodeName
    294   1.1    jruoho  *
    295   1.1    jruoho  * PARAMETERS:  Object               - A namespace node
    296   1.1    jruoho  *
    297   1.1    jruoho  * RETURN:      ASCII name of the node
    298   1.1    jruoho  *
    299   1.1    jruoho  * DESCRIPTION: Validate the node and return the node's ACPI name.
    300   1.1    jruoho  *
    301   1.1    jruoho  ******************************************************************************/
    302   1.1    jruoho 
    303   1.2    jruoho const char *
    304   1.1    jruoho AcpiUtGetNodeName (
    305   1.1    jruoho     void                    *Object)
    306   1.1    jruoho {
    307   1.1    jruoho     ACPI_NAMESPACE_NODE     *Node = (ACPI_NAMESPACE_NODE *) Object;
    308   1.1    jruoho 
    309   1.1    jruoho 
    310   1.1    jruoho     /* Must return a string of exactly 4 characters == ACPI_NAME_SIZE */
    311   1.1    jruoho 
    312   1.1    jruoho     if (!Object)
    313   1.1    jruoho     {
    314   1.1    jruoho         return ("NULL");
    315   1.1    jruoho     }
    316   1.1    jruoho 
    317   1.1    jruoho     /* Check for Root node */
    318   1.1    jruoho 
    319   1.1    jruoho     if ((Object == ACPI_ROOT_OBJECT) ||
    320   1.1    jruoho         (Object == AcpiGbl_RootNode))
    321   1.1    jruoho     {
    322   1.1    jruoho         return ("\"\\\" ");
    323   1.1    jruoho     }
    324   1.1    jruoho 
    325   1.1    jruoho     /* Descriptor must be a namespace node */
    326   1.1    jruoho 
    327   1.1    jruoho     if (ACPI_GET_DESCRIPTOR_TYPE (Node) != ACPI_DESC_TYPE_NAMED)
    328   1.1    jruoho     {
    329   1.1    jruoho         return ("####");
    330   1.1    jruoho     }
    331   1.1    jruoho 
    332   1.1    jruoho     /*
    333   1.1    jruoho      * Ensure name is valid. The name was validated/repaired when the node
    334   1.1    jruoho      * was created, but make sure it has not been corrupted.
    335   1.1    jruoho      */
    336   1.1    jruoho     AcpiUtRepairName (Node->Name.Ascii);
    337   1.1    jruoho 
    338   1.1    jruoho     /* Return the name */
    339   1.1    jruoho 
    340   1.1    jruoho     return (Node->Name.Ascii);
    341   1.1    jruoho }
    342   1.1    jruoho 
    343   1.1    jruoho 
    344   1.1    jruoho /*******************************************************************************
    345   1.1    jruoho  *
    346   1.1    jruoho  * FUNCTION:    AcpiUtGetDescriptorName
    347   1.1    jruoho  *
    348   1.1    jruoho  * PARAMETERS:  Object               - An ACPI object
    349   1.1    jruoho  *
    350   1.1    jruoho  * RETURN:      Decoded name of the descriptor type
    351   1.1    jruoho  *
    352   1.1    jruoho  * DESCRIPTION: Validate object and return the descriptor type
    353   1.1    jruoho  *
    354   1.1    jruoho  ******************************************************************************/
    355   1.1    jruoho 
    356   1.1    jruoho /* Printable names of object descriptor types */
    357   1.1    jruoho 
    358   1.1    jruoho static const char           *AcpiGbl_DescTypeNames[] =
    359   1.1    jruoho {
    360   1.1    jruoho     /* 00 */ "Not a Descriptor",
    361   1.1    jruoho     /* 01 */ "Cached",
    362   1.1    jruoho     /* 02 */ "State-Generic",
    363   1.1    jruoho     /* 03 */ "State-Update",
    364   1.1    jruoho     /* 04 */ "State-Package",
    365   1.1    jruoho     /* 05 */ "State-Control",
    366   1.1    jruoho     /* 06 */ "State-RootParseScope",
    367   1.1    jruoho     /* 07 */ "State-ParseScope",
    368   1.1    jruoho     /* 08 */ "State-WalkScope",
    369   1.1    jruoho     /* 09 */ "State-Result",
    370   1.1    jruoho     /* 10 */ "State-Notify",
    371   1.1    jruoho     /* 11 */ "State-Thread",
    372   1.1    jruoho     /* 12 */ "Walk",
    373   1.1    jruoho     /* 13 */ "Parser",
    374   1.1    jruoho     /* 14 */ "Operand",
    375   1.1    jruoho     /* 15 */ "Node"
    376   1.1    jruoho };
    377   1.1    jruoho 
    378   1.1    jruoho 
    379   1.2    jruoho const char *
    380   1.1    jruoho AcpiUtGetDescriptorName (
    381   1.1    jruoho     void                    *Object)
    382   1.1    jruoho {
    383   1.1    jruoho 
    384   1.1    jruoho     if (!Object)
    385   1.1    jruoho     {
    386   1.1    jruoho         return ("NULL OBJECT");
    387   1.1    jruoho     }
    388   1.1    jruoho 
    389   1.1    jruoho     if (ACPI_GET_DESCRIPTOR_TYPE (Object) > ACPI_DESC_TYPE_MAX)
    390   1.1    jruoho     {
    391   1.1    jruoho         return ("Not a Descriptor");
    392   1.1    jruoho     }
    393   1.1    jruoho 
    394   1.8  christos     return (AcpiGbl_DescTypeNames[ACPI_GET_DESCRIPTOR_TYPE (Object)]);
    395   1.1    jruoho }
    396   1.1    jruoho 
    397   1.1    jruoho 
    398   1.1    jruoho /*******************************************************************************
    399   1.1    jruoho  *
    400   1.1    jruoho  * FUNCTION:    AcpiUtGetReferenceName
    401   1.1    jruoho  *
    402   1.1    jruoho  * PARAMETERS:  Object               - An ACPI reference object
    403   1.1    jruoho  *
    404   1.1    jruoho  * RETURN:      Decoded name of the type of reference
    405   1.1    jruoho  *
    406   1.1    jruoho  * DESCRIPTION: Decode a reference object sub-type to a string.
    407   1.1    jruoho  *
    408   1.1    jruoho  ******************************************************************************/
    409   1.1    jruoho 
    410   1.1    jruoho /* Printable names of reference object sub-types */
    411   1.1    jruoho 
    412   1.1    jruoho static const char           *AcpiGbl_RefClassNames[] =
    413   1.1    jruoho {
    414   1.1    jruoho     /* 00 */ "Local",
    415   1.1    jruoho     /* 01 */ "Argument",
    416   1.1    jruoho     /* 02 */ "RefOf",
    417   1.1    jruoho     /* 03 */ "Index",
    418   1.1    jruoho     /* 04 */ "DdbHandle",
    419   1.1    jruoho     /* 05 */ "Named Object",
    420   1.1    jruoho     /* 06 */ "Debug"
    421   1.1    jruoho };
    422   1.1    jruoho 
    423   1.1    jruoho const char *
    424   1.1    jruoho AcpiUtGetReferenceName (
    425   1.1    jruoho     ACPI_OPERAND_OBJECT     *Object)
    426   1.1    jruoho {
    427   1.1    jruoho 
    428   1.1    jruoho     if (!Object)
    429   1.1    jruoho     {
    430   1.1    jruoho         return ("NULL Object");
    431   1.1    jruoho     }
    432   1.1    jruoho 
    433   1.1    jruoho     if (ACPI_GET_DESCRIPTOR_TYPE (Object) != ACPI_DESC_TYPE_OPERAND)
    434   1.1    jruoho     {
    435   1.1    jruoho         return ("Not an Operand object");
    436   1.1    jruoho     }
    437   1.1    jruoho 
    438   1.1    jruoho     if (Object->Common.Type != ACPI_TYPE_LOCAL_REFERENCE)
    439   1.1    jruoho     {
    440   1.1    jruoho         return ("Not a Reference object");
    441   1.1    jruoho     }
    442   1.1    jruoho 
    443   1.1    jruoho     if (Object->Reference.Class > ACPI_REFCLASS_MAX)
    444   1.1    jruoho     {
    445   1.1    jruoho         return ("Unknown Reference class");
    446   1.1    jruoho     }
    447   1.1    jruoho 
    448   1.1    jruoho     return (AcpiGbl_RefClassNames[Object->Reference.Class]);
    449   1.1    jruoho }
    450   1.1    jruoho 
    451   1.1    jruoho 
    452   1.1    jruoho #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)
    453   1.1    jruoho /*
    454   1.1    jruoho  * Strings and procedures used for debug only
    455   1.1    jruoho  */
    456   1.1    jruoho 
    457   1.1    jruoho /*******************************************************************************
    458   1.1    jruoho  *
    459   1.1    jruoho  * FUNCTION:    AcpiUtGetMutexName
    460   1.1    jruoho  *
    461   1.1    jruoho  * PARAMETERS:  MutexId         - The predefined ID for this mutex.
    462   1.1    jruoho  *
    463   1.1    jruoho  * RETURN:      Decoded name of the internal mutex
    464   1.1    jruoho  *
    465   1.1    jruoho  * DESCRIPTION: Translate a mutex ID into a name string (Debug only)
    466   1.1    jruoho  *
    467   1.1    jruoho  ******************************************************************************/
    468   1.1    jruoho 
    469   1.1    jruoho /* Names for internal mutex objects, used for debug output */
    470   1.1    jruoho 
    471   1.8  christos static const char           *AcpiGbl_MutexNames[ACPI_NUM_MUTEX] =
    472   1.1    jruoho {
    473   1.1    jruoho     "ACPI_MTX_Interpreter",
    474   1.1    jruoho     "ACPI_MTX_Namespace",
    475   1.1    jruoho     "ACPI_MTX_Tables",
    476   1.1    jruoho     "ACPI_MTX_Events",
    477   1.1    jruoho     "ACPI_MTX_Caches",
    478   1.1    jruoho     "ACPI_MTX_Memory",
    479   1.1    jruoho };
    480   1.1    jruoho 
    481   1.2    jruoho const char *
    482   1.1    jruoho AcpiUtGetMutexName (
    483   1.1    jruoho     UINT32                  MutexId)
    484   1.1    jruoho {
    485   1.1    jruoho 
    486   1.1    jruoho     if (MutexId > ACPI_MAX_MUTEX)
    487   1.1    jruoho     {
    488   1.1    jruoho         return ("Invalid Mutex ID");
    489   1.1    jruoho     }
    490   1.1    jruoho 
    491   1.1    jruoho     return (AcpiGbl_MutexNames[MutexId]);
    492   1.1    jruoho }
    493   1.1    jruoho 
    494   1.1    jruoho 
    495   1.1    jruoho /*******************************************************************************
    496   1.1    jruoho  *
    497   1.1    jruoho  * FUNCTION:    AcpiUtGetNotifyName
    498   1.1    jruoho  *
    499   1.1    jruoho  * PARAMETERS:  NotifyValue     - Value from the Notify() request
    500   1.1    jruoho  *
    501   1.1    jruoho  * RETURN:      Decoded name for the notify value
    502   1.1    jruoho  *
    503   1.1    jruoho  * DESCRIPTION: Translate a Notify Value to a notify namestring.
    504   1.1    jruoho  *
    505   1.1    jruoho  ******************************************************************************/
    506   1.1    jruoho 
    507   1.1    jruoho /* Names for Notify() values, used for debug output */
    508   1.1    jruoho 
    509   1.9  christos static const char           *AcpiGbl_GenericNotify[ACPI_GENERIC_NOTIFY_MAX + 1] =
    510   1.1    jruoho {
    511   1.5  christos     /* 00 */ "Bus Check",
    512   1.5  christos     /* 01 */ "Device Check",
    513   1.5  christos     /* 02 */ "Device Wake",
    514   1.5  christos     /* 03 */ "Eject Request",
    515   1.5  christos     /* 04 */ "Device Check Light",
    516   1.5  christos     /* 05 */ "Frequency Mismatch",
    517   1.5  christos     /* 06 */ "Bus Mode Mismatch",
    518   1.5  christos     /* 07 */ "Power Fault",
    519   1.5  christos     /* 08 */ "Capabilities Check",
    520   1.5  christos     /* 09 */ "Device PLD Check",
    521   1.6  christos     /* 0A */ "Reserved",
    522   1.6  christos     /* 0B */ "System Locality Update",
    523   1.9  christos     /* 0C */ "Shutdown Request", /* Reserved in ACPI 6.0 */
    524   1.6  christos     /* 0D */ "System Resource Affinity Update"
    525   1.6  christos };
    526   1.6  christos 
    527   1.9  christos static const char           *AcpiGbl_DeviceNotify[5] =
    528   1.6  christos {
    529   1.6  christos     /* 80 */ "Status Change",
    530   1.6  christos     /* 81 */ "Information Change",
    531   1.6  christos     /* 82 */ "Device-Specific Change",
    532   1.9  christos     /* 83 */ "Device-Specific Change",
    533   1.9  christos     /* 84 */ "Reserved"
    534   1.1    jruoho };
    535   1.1    jruoho 
    536   1.9  christos static const char           *AcpiGbl_ProcessorNotify[5] =
    537   1.6  christos {
    538   1.6  christos     /* 80 */ "Performance Capability Change",
    539   1.6  christos     /* 81 */ "C-State Change",
    540   1.6  christos     /* 82 */ "Throttling Capability Change",
    541   1.9  christos     /* 83 */ "Guaranteed Change",
    542   1.9  christos     /* 84 */ "Minimum Excursion"
    543   1.6  christos };
    544   1.6  christos 
    545   1.9  christos static const char           *AcpiGbl_ThermalNotify[5] =
    546   1.6  christos {
    547   1.6  christos     /* 80 */ "Thermal Status Change",
    548   1.6  christos     /* 81 */ "Thermal Trip Point Change",
    549   1.6  christos     /* 82 */ "Thermal Device List Change",
    550   1.9  christos     /* 83 */ "Thermal Relationship Change",
    551   1.9  christos     /* 84 */ "Reserved"
    552   1.6  christos };
    553   1.6  christos 
    554   1.6  christos 
    555   1.1    jruoho const char *
    556   1.1    jruoho AcpiUtGetNotifyName (
    557   1.6  christos     UINT32                  NotifyValue,
    558   1.6  christos     ACPI_OBJECT_TYPE        Type)
    559   1.1    jruoho {
    560   1.1    jruoho 
    561   1.9  christos     /* 00 - 0D are "common to all object types" (from ACPI Spec) */
    562   1.6  christos 
    563   1.9  christos     if (NotifyValue <= ACPI_GENERIC_NOTIFY_MAX)
    564   1.1    jruoho     {
    565   1.6  christos         return (AcpiGbl_GenericNotify[NotifyValue]);
    566   1.1    jruoho     }
    567   1.6  christos 
    568   1.9  christos     /* 0E - 7F are reserved */
    569   1.6  christos 
    570   1.6  christos     if (NotifyValue <= ACPI_MAX_SYS_NOTIFY)
    571   1.1    jruoho     {
    572   1.1    jruoho         return ("Reserved");
    573   1.1    jruoho     }
    574   1.6  christos 
    575   1.9  christos     /* 80 - 84 are per-object-type */
    576   1.6  christos 
    577   1.9  christos     if (NotifyValue <= ACPI_SPECIFIC_NOTIFY_MAX)
    578   1.5  christos     {
    579   1.6  christos         switch (Type)
    580   1.6  christos         {
    581   1.6  christos         case ACPI_TYPE_ANY:
    582   1.6  christos         case ACPI_TYPE_DEVICE:
    583   1.6  christos             return (AcpiGbl_DeviceNotify [NotifyValue - 0x80]);
    584   1.6  christos 
    585   1.6  christos         case ACPI_TYPE_PROCESSOR:
    586   1.6  christos             return (AcpiGbl_ProcessorNotify [NotifyValue - 0x80]);
    587   1.6  christos 
    588   1.6  christos         case ACPI_TYPE_THERMAL:
    589   1.6  christos             return (AcpiGbl_ThermalNotify [NotifyValue - 0x80]);
    590   1.6  christos 
    591   1.6  christos         default:
    592   1.6  christos             return ("Target object type does not support notifies");
    593   1.6  christos         }
    594   1.5  christos     }
    595   1.6  christos 
    596   1.6  christos     /* 84 - BF are device-specific */
    597   1.6  christos 
    598   1.6  christos     if (NotifyValue <= ACPI_MAX_DEVICE_SPECIFIC_NOTIFY)
    599   1.1    jruoho     {
    600   1.6  christos         return ("Device-Specific");
    601   1.1    jruoho     }
    602   1.6  christos 
    603   1.6  christos     /* C0 and above are hardware-specific */
    604   1.6  christos 
    605   1.6  christos     return ("Hardware-Specific");
    606   1.1    jruoho }
    607   1.1    jruoho #endif
    608   1.1    jruoho 
    609   1.1    jruoho 
    610   1.1    jruoho /*******************************************************************************
    611   1.1    jruoho  *
    612   1.1    jruoho  * FUNCTION:    AcpiUtValidObjectType
    613   1.1    jruoho  *
    614   1.1    jruoho  * PARAMETERS:  Type            - Object type to be validated
    615   1.1    jruoho  *
    616   1.1    jruoho  * RETURN:      TRUE if valid object type, FALSE otherwise
    617   1.1    jruoho  *
    618   1.1    jruoho  * DESCRIPTION: Validate an object type
    619   1.1    jruoho  *
    620   1.1    jruoho  ******************************************************************************/
    621   1.1    jruoho 
    622   1.1    jruoho BOOLEAN
    623   1.1    jruoho AcpiUtValidObjectType (
    624   1.1    jruoho     ACPI_OBJECT_TYPE        Type)
    625   1.1    jruoho {
    626   1.1    jruoho 
    627   1.1    jruoho     if (Type > ACPI_TYPE_LOCAL_MAX)
    628   1.1    jruoho     {
    629   1.1    jruoho         /* Note: Assumes all TYPEs are contiguous (external/local) */
    630   1.1    jruoho 
    631   1.1    jruoho         return (FALSE);
    632   1.1    jruoho     }
    633   1.1    jruoho 
    634   1.1    jruoho     return (TRUE);
    635   1.1    jruoho }
    636