2018-03-14 16:13:07 -07:00
// SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
2011-02-14 16:00:21 +08:00
/******************************************************************************
*
* Module Name : utdecode - Utility decoding routines ( value - to - string )
*
2019-01-14 09:55:25 -08:00
* Copyright ( C ) 2000 - 2019 , Intel Corp .
2011-02-14 16:00:21 +08:00
*
2018-03-14 16:13:07 -07:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2011-02-14 16:00:21 +08:00
# include <acpi/acpi.h>
# include "accommon.h"
# include "acnamesp.h"
2016-11-30 15:21:57 +08:00
# include "amlcode.h"
2011-02-14 16:00:21 +08:00
# define _COMPONENT ACPI_UTILITIES
ACPI_MODULE_NAME ( " utdecode " )
/*
* Properties of the ACPI Object Types , both internal and external .
* The table is indexed by values of acpi_object_type
*/
const u8 acpi_gbl_ns_properties [ ACPI_NUM_NS_TYPES ] = {
ACPI_NS_NORMAL , /* 00 Any */
ACPI_NS_NORMAL , /* 01 Number */
ACPI_NS_NORMAL , /* 02 String */
ACPI_NS_NORMAL , /* 03 Buffer */
ACPI_NS_NORMAL , /* 04 Package */
ACPI_NS_NORMAL , /* 05 field_unit */
ACPI_NS_NEWSCOPE , /* 06 Device */
ACPI_NS_NORMAL , /* 07 Event */
ACPI_NS_NEWSCOPE , /* 08 Method */
ACPI_NS_NORMAL , /* 09 Mutex */
ACPI_NS_NORMAL , /* 10 Region */
ACPI_NS_NEWSCOPE , /* 11 Power */
ACPI_NS_NEWSCOPE , /* 12 Processor */
ACPI_NS_NEWSCOPE , /* 13 Thermal */
ACPI_NS_NORMAL , /* 14 buffer_field */
ACPI_NS_NORMAL , /* 15 ddb_handle */
ACPI_NS_NORMAL , /* 16 Debug Object */
ACPI_NS_NORMAL , /* 17 def_field */
ACPI_NS_NORMAL , /* 18 bank_field */
ACPI_NS_NORMAL , /* 19 index_field */
ACPI_NS_NORMAL , /* 20 Reference */
ACPI_NS_NORMAL , /* 21 Alias */
ACPI_NS_NORMAL , /* 22 method_alias */
ACPI_NS_NORMAL , /* 23 Notify */
ACPI_NS_NORMAL , /* 24 Address Handler */
ACPI_NS_NEWSCOPE | ACPI_NS_LOCAL , /* 25 Resource Desc */
ACPI_NS_NEWSCOPE | ACPI_NS_LOCAL , /* 26 Resource Field */
ACPI_NS_NEWSCOPE , /* 27 Scope */
ACPI_NS_NORMAL , /* 28 Extra */
ACPI_NS_NORMAL , /* 29 Data */
ACPI_NS_NORMAL /* 30 Invalid */
} ;
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_region_name
*
* PARAMETERS : Space ID - ID for the region
*
* RETURN : Decoded region space_id name
*
* DESCRIPTION : Translate a Space ID into a name string ( Debug only )
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/* Region type decoding */
const char * acpi_gbl_region_types [ ACPI_NUM_PREDEFINED_REGIONS ] = {
2012-07-16 10:01:36 +08:00
" SystemMemory " , /* 0x00 */
" SystemIO " , /* 0x01 */
" PCI_Config " , /* 0x02 */
" EmbeddedControl " , /* 0x03 */
" SMBus " , /* 0x04 */
" SystemCMOS " , /* 0x05 */
" PCIBARTarget " , /* 0x06 */
" IPMI " , /* 0x07 */
" GeneralPurposeIo " , /* 0x08 */
" GenericSerialBus " , /* 0x09 */
2019-04-08 13:42:27 -07:00
" PlatformCommChannel " /* 0x0A */
2011-02-14 16:00:21 +08:00
} ;
2015-12-29 13:54:04 +08:00
const char * acpi_ut_get_region_name ( u8 space_id )
2011-02-14 16:00:21 +08:00
{
if ( space_id > = ACPI_USER_REGION_BEGIN ) {
return ( " UserDefinedRegion " ) ;
2011-04-13 13:19:35 +08:00
} else if ( space_id = = ACPI_ADR_SPACE_DATA_TABLE ) {
return ( " DataTable " ) ;
2011-02-14 16:11:43 +08:00
} else if ( space_id = = ACPI_ADR_SPACE_FIXED_HARDWARE ) {
return ( " FunctionalFixedHW " ) ;
2011-02-14 16:00:21 +08:00
} else if ( space_id > = ACPI_NUM_PREDEFINED_REGIONS ) {
return ( " InvalidSpaceId " ) ;
}
2015-12-29 13:54:04 +08:00
return ( acpi_gbl_region_types [ space_id ] ) ;
2011-02-14 16:00:21 +08:00
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_event_name
*
* PARAMETERS : event_id - Fixed event ID
*
* RETURN : Decoded event ID name
*
* DESCRIPTION : Translate a Event ID into a name string ( Debug only )
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/* Event type decoding */
static const char * acpi_gbl_event_types [ ACPI_NUM_FIXED_EVENTS ] = {
" PM_Timer " ,
" GlobalLock " ,
" PowerButton " ,
" SleepButton " ,
" RealTimeClock " ,
} ;
2015-12-29 13:54:04 +08:00
const char * acpi_ut_get_event_name ( u32 event_id )
2011-02-14 16:00:21 +08:00
{
if ( event_id > ACPI_EVENT_MAX ) {
return ( " InvalidEventID " ) ;
}
2015-12-29 13:54:04 +08:00
return ( acpi_gbl_event_types [ event_id ] ) ;
2011-02-14 16:00:21 +08:00
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_type_name
*
2012-07-12 09:40:10 +08:00
* PARAMETERS : type - An ACPI object type
2011-02-14 16:00:21 +08:00
*
* RETURN : Decoded ACPI object type name
*
* DESCRIPTION : Translate a Type ID into a name string ( Debug only )
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
* Elements of acpi_gbl_ns_type_names below must match
* one - to - one with values of acpi_object_type
*
* The type ACPI_TYPE_ANY ( Untyped ) is used as a " don't care " when searching ;
* when stored in a table it really means that we have thus far seen no
2015-12-29 13:54:36 +08:00
* evidence to indicate what type is actually going to be stored for this
& entry .
2011-02-14 16:00:21 +08:00
*/
static const char acpi_gbl_bad_type [ ] = " UNDEFINED " ;
/* Printable names of the ACPI object types */
static const char * acpi_gbl_ns_type_names [ ] = {
/* 00 */ " Untyped " ,
/* 01 */ " Integer " ,
/* 02 */ " String " ,
/* 03 */ " Buffer " ,
/* 04 */ " Package " ,
/* 05 */ " FieldUnit " ,
/* 06 */ " Device " ,
/* 07 */ " Event " ,
/* 08 */ " Method " ,
/* 09 */ " Mutex " ,
/* 10 */ " Region " ,
/* 11 */ " Power " ,
/* 12 */ " Processor " ,
/* 13 */ " Thermal " ,
/* 14 */ " BufferField " ,
/* 15 */ " DdbHandle " ,
/* 16 */ " DebugObject " ,
/* 17 */ " RegionField " ,
/* 18 */ " BankField " ,
/* 19 */ " IndexField " ,
/* 20 */ " Reference " ,
/* 21 */ " Alias " ,
/* 22 */ " MethodAlias " ,
/* 23 */ " Notify " ,
/* 24 */ " AddrHandler " ,
/* 25 */ " ResourceDesc " ,
/* 26 */ " ResourceFld " ,
/* 27 */ " Scope " ,
/* 28 */ " Extra " ,
/* 29 */ " Data " ,
/* 30 */ " Invalid "
} ;
2015-12-29 13:54:04 +08:00
const char * acpi_ut_get_type_name ( acpi_object_type type )
2011-02-14 16:00:21 +08:00
{
if ( type > ACPI_TYPE_INVALID ) {
2015-12-29 13:54:04 +08:00
return ( acpi_gbl_bad_type ) ;
2011-02-14 16:00:21 +08:00
}
2015-12-29 13:54:04 +08:00
return ( acpi_gbl_ns_type_names [ type ] ) ;
2011-02-14 16:00:21 +08:00
}
2015-12-29 13:54:04 +08:00
const char * acpi_ut_get_object_type_name ( union acpi_operand_object * obj_desc )
2011-02-14 16:00:21 +08:00
{
2015-10-19 10:24:58 +08:00
ACPI_FUNCTION_TRACE ( ut_get_object_type_name ) ;
2011-02-14 16:00:21 +08:00
if ( ! obj_desc ) {
2015-10-19 10:24:58 +08:00
ACPI_DEBUG_PRINT ( ( ACPI_DB_EXEC , " Null Object Descriptor \n " ) ) ;
2016-12-28 15:29:22 +08:00
return_STR ( " [NULL Object Descriptor] " ) ;
2011-02-14 16:00:21 +08:00
}
2015-10-19 10:24:58 +08:00
/* These descriptor types share a common area */
if ( ( ACPI_GET_DESCRIPTOR_TYPE ( obj_desc ) ! = ACPI_DESC_TYPE_OPERAND ) & &
( ACPI_GET_DESCRIPTOR_TYPE ( obj_desc ) ! = ACPI_DESC_TYPE_NAMED ) ) {
ACPI_DEBUG_PRINT ( ( ACPI_DB_EXEC ,
" Invalid object descriptor type: 0x%2.2X [%s] (%p) \n " ,
ACPI_GET_DESCRIPTOR_TYPE ( obj_desc ) ,
acpi_ut_get_descriptor_name ( obj_desc ) ,
obj_desc ) ) ;
2016-12-28 15:29:22 +08:00
return_STR ( " Invalid object " ) ;
2015-10-19 10:24:58 +08:00
}
2016-08-04 16:42:19 +08:00
return_STR ( acpi_ut_get_type_name ( obj_desc - > common . type ) ) ;
2011-02-14 16:00:21 +08:00
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_node_name
*
2012-07-12 09:40:10 +08:00
* PARAMETERS : object - A namespace node
2011-02-14 16:00:21 +08:00
*
* RETURN : ASCII name of the node
*
* DESCRIPTION : Validate the node and return the node ' s ACPI name .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2015-12-29 13:54:04 +08:00
const char * acpi_ut_get_node_name ( void * object )
2011-02-14 16:00:21 +08:00
{
struct acpi_namespace_node * node = ( struct acpi_namespace_node * ) object ;
2019-04-08 13:42:25 -07:00
/* Must return a string of exactly 4 characters == ACPI_NAMESEG_SIZE */
2011-02-14 16:00:21 +08:00
if ( ! object ) {
return ( " NULL " ) ;
}
/* Check for Root node */
if ( ( object = = ACPI_ROOT_OBJECT ) | | ( object = = acpi_gbl_root_node ) ) {
return ( " \" \\ \" " ) ;
}
/* Descriptor must be a namespace node */
if ( ACPI_GET_DESCRIPTOR_TYPE ( node ) ! = ACPI_DESC_TYPE_NAMED ) {
return ( " #### " ) ;
}
/*
* Ensure name is valid . The name was validated / repaired when the node
* was created , but make sure it has not been corrupted .
*/
acpi_ut_repair_name ( node - > name . ascii ) ;
/* Return the name */
return ( node - > name . ascii ) ;
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_descriptor_name
*
2012-07-12 09:40:10 +08:00
* PARAMETERS : object - An ACPI object
2011-02-14 16:00:21 +08:00
*
* RETURN : Decoded name of the descriptor type
*
* DESCRIPTION : Validate object and return the descriptor type
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/* Printable names of object descriptor types */
static const char * acpi_gbl_desc_type_names [ ] = {
/* 00 */ " Not a Descriptor " ,
2019-01-14 09:55:24 -08:00
/* 01 */ " Cached Object " ,
2011-02-14 16:00:21 +08:00
/* 02 */ " State-Generic " ,
/* 03 */ " State-Update " ,
/* 04 */ " State-Package " ,
/* 05 */ " State-Control " ,
/* 06 */ " State-RootParseScope " ,
/* 07 */ " State-ParseScope " ,
/* 08 */ " State-WalkScope " ,
/* 09 */ " State-Result " ,
/* 10 */ " State-Notify " ,
/* 11 */ " State-Thread " ,
2019-01-14 09:55:24 -08:00
/* 12 */ " Tree Walk State " ,
/* 13 */ " Parse Tree Op " ,
/* 14 */ " Operand Object " ,
/* 15 */ " Namespace Node "
2011-02-14 16:00:21 +08:00
} ;
2015-12-29 13:54:04 +08:00
const char * acpi_ut_get_descriptor_name ( void * object )
2011-02-14 16:00:21 +08:00
{
if ( ! object ) {
return ( " NULL OBJECT " ) ;
}
if ( ACPI_GET_DESCRIPTOR_TYPE ( object ) > ACPI_DESC_TYPE_MAX ) {
return ( " Not a Descriptor " ) ;
}
2015-12-29 13:54:04 +08:00
return ( acpi_gbl_desc_type_names [ ACPI_GET_DESCRIPTOR_TYPE ( object ) ] ) ;
2011-02-14 16:00:21 +08:00
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_reference_name
*
2012-07-12 09:40:10 +08:00
* PARAMETERS : object - An ACPI reference object
2011-02-14 16:00:21 +08:00
*
* RETURN : Decoded name of the type of reference
*
* DESCRIPTION : Decode a reference object sub - type to a string .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/* Printable names of reference object sub-types */
static const char * acpi_gbl_ref_class_names [ ] = {
/* 00 */ " Local " ,
/* 01 */ " Argument " ,
/* 02 */ " RefOf " ,
/* 03 */ " Index " ,
/* 04 */ " DdbHandle " ,
/* 05 */ " Named Object " ,
/* 06 */ " Debug "
} ;
const char * acpi_ut_get_reference_name ( union acpi_operand_object * object )
{
if ( ! object ) {
return ( " NULL Object " ) ;
}
if ( ACPI_GET_DESCRIPTOR_TYPE ( object ) ! = ACPI_DESC_TYPE_OPERAND ) {
return ( " Not an Operand object " ) ;
}
if ( object - > common . type ! = ACPI_TYPE_LOCAL_REFERENCE ) {
return ( " Not a Reference object " ) ;
}
if ( object - > reference . class > ACPI_REFCLASS_MAX ) {
return ( " Unknown Reference class " ) ;
}
return ( acpi_gbl_ref_class_names [ object - > reference . class ] ) ;
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_mutex_name
*
* PARAMETERS : mutex_id - The predefined ID for this mutex .
*
* RETURN : Decoded name of the internal mutex
*
* DESCRIPTION : Translate a mutex ID into a name string ( Debug only )
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/* Names for internal mutex objects, used for debug output */
2015-12-29 13:54:04 +08:00
static const char * acpi_gbl_mutex_names [ ACPI_NUM_MUTEX ] = {
2011-02-14 16:00:21 +08:00
" ACPI_MTX_Interpreter " ,
" ACPI_MTX_Namespace " ,
" ACPI_MTX_Tables " ,
" ACPI_MTX_Events " ,
" ACPI_MTX_Caches " ,
" ACPI_MTX_Memory " ,
} ;
2015-12-29 13:54:04 +08:00
const char * acpi_ut_get_mutex_name ( u32 mutex_id )
2011-02-14 16:00:21 +08:00
{
if ( mutex_id > ACPI_MAX_MUTEX ) {
return ( " Invalid Mutex ID " ) ;
}
return ( acpi_gbl_mutex_names [ mutex_id ] ) ;
}
2017-11-17 15:42:28 -08:00
# if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)
/*
* Strings and procedures used for debug only
*/
2011-02-14 16:00:21 +08:00
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_notify_name
*
* PARAMETERS : notify_value - Value from the Notify ( ) request
*
* RETURN : Decoded name for the notify value
*
* DESCRIPTION : Translate a Notify Value to a notify namestring .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/* Names for Notify() values, used for debug output */
2016-03-24 09:39:36 +08:00
static const char * acpi_gbl_generic_notify [ ACPI_GENERIC_NOTIFY_MAX + 1 ] = {
2012-02-14 18:23:39 +08:00
/* 00 */ " Bus Check " ,
/* 01 */ " Device Check " ,
/* 02 */ " Device Wake " ,
/* 03 */ " Eject Request " ,
/* 04 */ " Device Check Light " ,
/* 05 */ " Frequency Mismatch " ,
/* 06 */ " Bus Mode Mismatch " ,
/* 07 */ " Power Fault " ,
/* 08 */ " Capabilities Check " ,
/* 09 */ " Device PLD Check " ,
2014-04-04 12:37:44 +08:00
/* 0A */ " Reserved " ,
/* 0B */ " System Locality Update " ,
2017-06-05 16:45:22 +08:00
/* 0C */ " Reserved (was previously Shutdown Request) " ,
/* Reserved in ACPI 6.0 */
2017-06-05 16:37:23 +08:00
/* 0D */ " System Resource Affinity Update " ,
2019-02-19 11:33:40 -08:00
/* 0E */ " Heterogeneous Memory Attributes Update " ,
2017-06-05 16:37:23 +08:00
/* ACPI 6.2 */
2019-02-19 11:33:40 -08:00
/* 0F */ " Error Disconnect Recover "
/* ACPI 6.3 */
2011-02-14 16:00:21 +08:00
} ;
2016-03-24 09:39:36 +08:00
static const char * acpi_gbl_device_notify [ 5 ] = {
2014-04-04 12:37:44 +08:00
/* 80 */ " Status Change " ,
/* 81 */ " Information Change " ,
/* 82 */ " Device-Specific Change " ,
2016-03-24 09:39:36 +08:00
/* 83 */ " Device-Specific Change " ,
/* 84 */ " Reserved "
2014-04-04 12:37:44 +08:00
} ;
2016-03-24 09:39:36 +08:00
static const char * acpi_gbl_processor_notify [ 5 ] = {
2014-04-04 12:37:44 +08:00
/* 80 */ " Performance Capability Change " ,
/* 81 */ " C-State Change " ,
/* 82 */ " Throttling Capability Change " ,
2016-03-24 09:39:36 +08:00
/* 83 */ " Guaranteed Change " ,
/* 84 */ " Minimum Excursion "
2014-04-04 12:37:44 +08:00
} ;
2016-03-24 09:39:36 +08:00
static const char * acpi_gbl_thermal_notify [ 5 ] = {
2014-04-04 12:37:44 +08:00
/* 80 */ " Thermal Status Change " ,
/* 81 */ " Thermal Trip Point Change " ,
/* 82 */ " Thermal Device List Change " ,
2016-03-24 09:39:36 +08:00
/* 83 */ " Thermal Relationship Change " ,
/* 84 */ " Reserved "
2014-04-04 12:37:44 +08:00
} ;
const char * acpi_ut_get_notify_name ( u32 notify_value , acpi_object_type type )
2011-02-14 16:00:21 +08:00
{
2019-02-19 11:33:40 -08:00
/* 00 - 0F are "common to all object types" (from ACPI Spec) */
2014-04-04 12:37:44 +08:00
2016-03-24 09:39:36 +08:00
if ( notify_value < = ACPI_GENERIC_NOTIFY_MAX ) {
2014-04-04 12:37:44 +08:00
return ( acpi_gbl_generic_notify [ notify_value ] ) ;
}
2019-02-19 11:33:40 -08:00
/* 10 - 7F are reserved */
2014-04-04 12:37:44 +08:00
if ( notify_value < = ACPI_MAX_SYS_NOTIFY ) {
2011-02-14 16:00:21 +08:00
return ( " Reserved " ) ;
}
2014-04-04 12:37:44 +08:00
2016-03-24 09:39:36 +08:00
/* 80 - 84 are per-object-type */
2014-04-04 12:37:44 +08:00
2016-03-24 09:39:36 +08:00
if ( notify_value < = ACPI_SPECIFIC_NOTIFY_MAX ) {
2014-04-04 12:37:44 +08:00
switch ( type ) {
case ACPI_TYPE_ANY :
case ACPI_TYPE_DEVICE :
return ( acpi_gbl_device_notify [ notify_value - 0x80 ] ) ;
case ACPI_TYPE_PROCESSOR :
return ( acpi_gbl_processor_notify [ notify_value - 0x80 ] ) ;
case ACPI_TYPE_THERMAL :
return ( acpi_gbl_thermal_notify [ notify_value - 0x80 ] ) ;
default :
return ( " Target object type does not support notifies " ) ;
}
}
/* 84 - BF are device-specific */
if ( notify_value < = ACPI_MAX_DEVICE_SPECIFIC_NOTIFY ) {
return ( " Device-Specific " ) ;
}
/* C0 and above are hardware-specific */
return ( " Hardware-Specific " ) ;
2011-02-14 16:00:21 +08:00
}
2016-11-30 15:21:57 +08:00
/*******************************************************************************
*
* FUNCTION : acpi_ut_get_argument_type_name
*
* PARAMETERS : arg_type - an ARGP_ * parser argument type
*
* RETURN : Decoded ARGP_ * type
*
* DESCRIPTION : Decode an ARGP_ * parser type , as defined in the amlcode . h file ,
* and used in the acopcode . h file . For example , ARGP_TERMARG .
* Used for debug only .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static const char * acpi_gbl_argument_type [ 20 ] = {
/* 00 */ " Unknown ARGP " ,
/* 01 */ " ByteData " ,
/* 02 */ " ByteList " ,
/* 03 */ " CharList " ,
/* 04 */ " DataObject " ,
/* 05 */ " DataObjectList " ,
/* 06 */ " DWordData " ,
/* 07 */ " FieldList " ,
/* 08 */ " Name " ,
/* 09 */ " NameString " ,
/* 0A */ " ObjectList " ,
/* 0B */ " PackageLength " ,
/* 0C */ " SuperName " ,
/* 0D */ " Target " ,
/* 0E */ " TermArg " ,
/* 0F */ " TermList " ,
/* 10 */ " WordData " ,
/* 11 */ " QWordData " ,
/* 12 */ " SimpleName " ,
/* 13 */ " NameOrRef "
} ;
const char * acpi_ut_get_argument_type_name ( u32 arg_type )
{
if ( arg_type > ARGP_MAX ) {
return ( " Unknown ARGP " ) ;
}
return ( acpi_gbl_argument_type [ arg_type ] ) ;
}
2011-02-14 16:00:21 +08:00
# endif
/*******************************************************************************
*
* FUNCTION : acpi_ut_valid_object_type
*
2012-07-12 09:40:10 +08:00
* PARAMETERS : type - Object type to be validated
2011-02-14 16:00:21 +08:00
*
* RETURN : TRUE if valid object type , FALSE otherwise
*
* DESCRIPTION : Validate an object type
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
u8 acpi_ut_valid_object_type ( acpi_object_type type )
{
if ( type > ACPI_TYPE_LOCAL_MAX ) {
/* Note: Assumes all TYPEs are contiguous (external/local) */
return ( FALSE ) ;
}
return ( TRUE ) ;
}