2005-04-16 15:20:36 -07:00
/******************************************************************************
*
* Name : acnamesp . h - Namespace subcomponent prototypes and defines
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
2015-02-05 15:20:45 +08:00
* Copyright ( C ) 2000 - 2015 , Intel Corp .
2005-04-16 15:20:36 -07:00
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions , and the following disclaimer ,
* without modification .
* 2. Redistributions in binary form must reproduce at minimum a disclaimer
* substantially similar to the " NO WARRANTY " disclaimer below
* ( " Disclaimer " ) and any redistribution must be conditioned upon
* including a substantially similar Disclaimer requirement for further
* binary redistribution .
* 3. Neither the names of the above - listed copyright holders nor the names
* of any contributors may be used to endorse or promote products derived
* from this software without specific prior written permission .
*
* Alternatively , this software may be distributed under the terms of the
* GNU General Public License ( " GPL " ) version 2 as published by the Free
* Software Foundation .
*
* NO WARRANTY
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
* DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS INTERRUPTION )
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT ,
* STRICT LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES .
*/
# ifndef __ACNAMESP_H__
# define __ACNAMESP_H__
/* To search the entire name space, pass this as search_base */
# define ACPI_NS_ALL ((acpi_handle)0)
/*
* Elements of acpi_ns_properties are bit significant
* and should be one - to - one with values of acpi_object_type
*/
# define ACPI_NS_NORMAL 0
2005-08-05 00:44:28 -04:00
# define ACPI_NS_NEWSCOPE 1 /* a definition of this type opens a name scope */
# define ACPI_NS_LOCAL 2 /* suppress search of enclosing scopes */
2005-04-16 15:20:36 -07:00
/* Flags for acpi_ns_lookup, acpi_ns_search_and_enter */
# define ACPI_NS_NO_UPSEARCH 0
# define ACPI_NS_SEARCH_PARENT 0x01
# define ACPI_NS_DONT_OPEN_SCOPE 0x02
# define ACPI_NS_NO_PEER_SEARCH 0x04
# define ACPI_NS_ERROR_IF_FOUND 0x08
2006-10-03 00:00:00 -04:00
# define ACPI_NS_PREFIX_IS_SCOPE 0x10
2006-05-12 17:12:00 -04:00
# define ACPI_NS_EXTERNAL 0x20
2007-02-02 19:48:21 +03:00
# define ACPI_NS_TEMPORARY 0x40
2015-07-01 14:44:17 +08:00
# define ACPI_NS_OVERRIDE_IF_FOUND 0x80
2005-04-16 15:20:36 -07:00
2007-02-02 19:48:21 +03:00
/* Flags for acpi_ns_walk_namespace */
# define ACPI_NS_WALK_NO_UNLOCK 0
# define ACPI_NS_WALK_UNLOCK 0x01
# define ACPI_NS_WALK_TEMP_NODES 0x02
2005-04-16 15:20:36 -07:00
2009-07-24 10:56:43 +08:00
/* Object is not a package element */
# define ACPI_NOT_PACKAGE_ELEMENT ACPI_UINT32_MAX
/* Always emit warning message, not dependent on node flags */
# define ACPI_WARN_ALWAYS 0
2005-04-18 22:49:35 -04:00
/*
* nsinit - Namespace initialization
*/
2005-08-05 00:44:28 -04:00
acpi_status acpi_ns_initialize_objects ( void ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
acpi_status acpi_ns_initialize_devices ( void ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
/*
* nsload - Namespace loading
*/
2005-08-05 00:44:28 -04:00
acpi_status acpi_ns_load_namespace ( void ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2008-06-10 13:42:13 +08:00
acpi_ns_load_table ( u32 table_index , struct acpi_namespace_node * node ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
/*
* nswalk - walk the namespace
*/
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_walk_namespace ( acpi_object_type type ,
acpi_handle start_object ,
u32 max_depth ,
2007-02-02 19:48:21 +03:00
u32 flags ,
2013-08-08 15:30:05 +08:00
acpi_walk_callback descending_callback ,
acpi_walk_callback ascending_callback ,
2005-08-05 00:44:28 -04:00
void * context , void * * return_value ) ;
2009-05-21 10:27:51 +08:00
struct acpi_namespace_node * acpi_ns_get_next_node ( struct acpi_namespace_node
* parent ,
struct acpi_namespace_node
2005-08-05 00:44:28 -04:00
* child ) ;
2005-04-16 15:20:36 -07:00
2009-05-21 10:27:51 +08:00
struct acpi_namespace_node * acpi_ns_get_next_node_typed ( acpi_object_type type ,
struct
acpi_namespace_node
* parent ,
struct
acpi_namespace_node
* child ) ;
2005-04-18 22:49:35 -04:00
/*
* nsparse - table parsing
*/
2005-04-16 15:20:36 -07:00
acpi_status
2008-06-10 13:42:13 +08:00
acpi_ns_parse_table ( u32 table_index , struct acpi_namespace_node * start_node ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2008-06-10 13:42:13 +08:00
acpi_ns_one_complete_parse ( u32 pass_number ,
u32 table_index ,
2008-04-10 19:06:39 +04:00
struct acpi_namespace_node * start_node ) ;
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nsaccess - Top - level namespace access
2005-04-16 15:20:36 -07:00
*/
2005-08-05 00:44:28 -04:00
acpi_status acpi_ns_root_initialize ( void ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_lookup ( union acpi_generic_state * scope_info ,
char * name ,
acpi_object_type type ,
acpi_interpreter_mode interpreter_mode ,
u32 flags ,
struct acpi_walk_state * walk_state ,
struct acpi_namespace_node * * ret_node ) ;
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nsalloc - Named object allocation / deallocation
2005-04-16 15:20:36 -07:00
*/
2005-08-05 00:44:28 -04:00
struct acpi_namespace_node * acpi_ns_create_node ( u32 name ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
void acpi_ns_delete_node ( struct acpi_namespace_node * node ) ;
2005-04-16 15:20:36 -07:00
2009-06-29 13:43:27 +08:00
void acpi_ns_remove_node ( struct acpi_namespace_node * node ) ;
2005-04-18 22:49:35 -04:00
void
2005-08-05 00:44:28 -04:00
acpi_ns_delete_namespace_subtree ( struct acpi_namespace_node * parent_handle ) ;
2005-04-18 22:49:35 -04:00
2005-08-05 00:44:28 -04:00
void acpi_ns_delete_namespace_by_owner ( acpi_owner_id owner_id ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
void acpi_ns_detach_object ( struct acpi_namespace_node * node ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
void acpi_ns_delete_children ( struct acpi_namespace_node * parent ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
int acpi_ns_compare_names ( char * name1 , char * name2 ) ;
2005-04-16 15:20:36 -07:00
2013-03-08 09:23:16 +00:00
/*
* nsconvert - Dynamic object conversion routines
*/
acpi_status
acpi_ns_convert_to_integer ( union acpi_operand_object * original_object ,
union acpi_operand_object * * return_object ) ;
acpi_status
acpi_ns_convert_to_string ( union acpi_operand_object * original_object ,
union acpi_operand_object * * return_object ) ;
acpi_status
acpi_ns_convert_to_buffer ( union acpi_operand_object * original_object ,
union acpi_operand_object * * return_object ) ;
2013-03-08 09:23:24 +00:00
acpi_status
acpi_ns_convert_to_unicode ( union acpi_operand_object * original_object ,
union acpi_operand_object * * return_object ) ;
2013-03-08 09:23:32 +00:00
acpi_status
acpi_ns_convert_to_resource ( union acpi_operand_object * original_object ,
union acpi_operand_object * * return_object ) ;
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nsdump - Namespace dump / print utilities
2005-04-16 15:20:36 -07:00
*/
2005-04-18 22:49:35 -04:00
# ifdef ACPI_FUTURE_USAGE
2005-08-05 00:44:28 -04:00
void acpi_ns_dump_tables ( acpi_handle search_base , u32 max_depth ) ;
# endif /* ACPI_FUTURE_USAGE */
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
void acpi_ns_dump_entry ( acpi_handle handle , u32 debug_level ) ;
2005-04-16 15:20:36 -07:00
void
2005-08-05 00:44:28 -04:00
acpi_ns_dump_pathname ( acpi_handle handle , char * msg , u32 level , u32 component ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
void acpi_ns_print_pathname ( u32 num_segments , char * pathname ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_dump_one_object ( acpi_handle obj_handle ,
u32 level , void * context , void * * return_value ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
# ifdef ACPI_FUTURE_USAGE
2005-04-16 15:20:36 -07:00
void
2005-08-05 00:44:28 -04:00
acpi_ns_dump_objects ( acpi_object_type type ,
u8 display_type ,
u32 max_depth ,
acpi_owner_id owner_id , acpi_handle start_handle ) ;
2013-09-23 09:52:19 +08:00
void
acpi_ns_dump_object_paths ( acpi_object_type type ,
u8 display_type ,
u32 max_depth ,
acpi_owner_id owner_id , acpi_handle start_handle ) ;
2005-08-05 00:44:28 -04:00
# endif /* ACPI_FUTURE_USAGE */
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nseval - Namespace evaluation functions
2005-04-16 15:20:36 -07:00
*/
2006-05-26 16:36:00 -04:00
acpi_status acpi_ns_evaluate ( struct acpi_evaluate_info * info ) ;
2005-04-16 15:20:36 -07:00
2009-08-13 14:03:15 +08:00
void acpi_ns_exec_module_code_list ( void ) ;
2008-09-28 15:26:17 +08:00
/*
2013-05-30 10:00:01 +08:00
* nsarguments - Argument count / type checking for predefined / reserved names
2008-09-28 15:26:17 +08:00
*/
2013-05-30 10:00:01 +08:00
void
acpi_ns_check_argument_count ( char * pathname ,
struct acpi_namespace_node * node ,
u32 user_param_count ,
const union acpi_predefined_info * info ) ;
2008-09-28 15:26:17 +08:00
void
2013-05-30 10:00:01 +08:00
acpi_ns_check_acpi_compliance ( char * pathname ,
2008-09-28 15:26:17 +08:00
struct acpi_namespace_node * node ,
2013-05-30 10:00:01 +08:00
const union acpi_predefined_info * predefined ) ;
void acpi_ns_check_argument_types ( struct acpi_evaluate_info * info ) ;
/*
* nspredef - Return value checking for predefined / reserved names
*/
acpi_status
acpi_ns_check_return_value ( struct acpi_namespace_node * node ,
struct acpi_evaluate_info * info ,
u32 user_param_count ,
acpi_status return_status ,
union acpi_operand_object * * return_object ) ;
2008-09-28 15:26:17 +08:00
2013-01-11 13:08:51 +01:00
acpi_status
2013-05-30 10:00:01 +08:00
acpi_ns_check_object_type ( struct acpi_evaluate_info * info ,
2013-01-11 13:08:51 +01:00
union acpi_operand_object * * return_object_ptr ,
u32 expected_btypes , u32 package_index ) ;
/*
* nsprepkg - Validation of predefined name packages
*/
acpi_status
2013-05-30 10:00:01 +08:00
acpi_ns_check_package ( struct acpi_evaluate_info * info ,
2013-01-11 13:08:51 +01:00
union acpi_operand_object * * return_object_ptr ) ;
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nsnames - Name and Scope manipulation
2005-04-16 15:20:36 -07:00
*/
2005-08-05 00:44:28 -04:00
u32 acpi_ns_opens_scope ( acpi_object_type type ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
char * acpi_ns_get_external_pathname ( struct acpi_namespace_node * node ) ;
2005-04-16 15:20:36 -07:00
2015-07-23 12:52:39 +08:00
u32
acpi_ns_build_normalized_path ( struct acpi_namespace_node * node ,
char * full_path , u32 path_size , u8 no_trailing ) ;
char * acpi_ns_get_normalized_pathname ( struct acpi_namespace_node * node ,
u8 no_trailing ) ;
2005-08-05 00:44:28 -04:00
char * acpi_ns_name_of_current_scope ( struct acpi_walk_state * walk_state ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_handle_to_pathname ( acpi_handle target_handle ,
2015-07-23 12:52:39 +08:00
struct acpi_buffer * buffer , u8 no_trailing ) ;
2005-04-16 15:20:36 -07:00
u8
2005-08-05 00:44:28 -04:00
acpi_ns_pattern_match ( struct acpi_namespace_node * obj_node , char * search_for ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2006-05-26 16:36:00 -04:00
acpi_ns_get_node ( struct acpi_namespace_node * prefix_node ,
2008-06-10 13:55:53 +08:00
const char * external_pathname ,
2006-05-26 16:36:00 -04:00
u32 flags , struct acpi_namespace_node * * out_node ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
acpi_size acpi_ns_get_pathname_length ( struct acpi_namespace_node * node ) ;
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nsobject - Object management for namespace nodes
2005-04-16 15:20:36 -07:00
*/
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_attach_object ( struct acpi_namespace_node * node ,
union acpi_operand_object * object , acpi_object_type type ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
union acpi_operand_object * acpi_ns_get_attached_object ( struct
acpi_namespace_node
* node ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
union acpi_operand_object * acpi_ns_get_secondary_object ( union
acpi_operand_object
* obj_desc ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_attach_data ( struct acpi_namespace_node * node ,
acpi_object_handler handler , void * data ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_detach_data ( struct acpi_namespace_node * node ,
acpi_object_handler handler ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_get_attached_data ( struct acpi_namespace_node * node ,
acpi_object_handler handler , void * * data ) ;
2005-04-16 15:20:36 -07:00
2009-07-24 10:56:43 +08:00
/*
2009-11-12 09:44:06 +08:00
* nsrepair - General return object repair for all
* predefined methods / objects
2009-07-24 10:56:43 +08:00
*/
acpi_status
2013-05-30 10:00:01 +08:00
acpi_ns_simple_repair ( struct acpi_evaluate_info * info ,
2009-07-24 10:56:43 +08:00
u32 expected_btypes ,
u32 package_index ,
union acpi_operand_object * * return_object_ptr ) ;
2009-07-24 11:03:09 +08:00
acpi_status
2013-05-30 10:00:01 +08:00
acpi_ns_wrap_with_package ( struct acpi_evaluate_info * info ,
2012-03-21 09:51:39 +08:00
union acpi_operand_object * original_object ,
union acpi_operand_object * * obj_desc_ptr ) ;
2009-07-24 11:03:09 +08:00
2010-01-21 09:28:32 +08:00
acpi_status
2013-05-30 10:00:01 +08:00
acpi_ns_repair_null_element ( struct acpi_evaluate_info * info ,
2010-01-21 09:28:32 +08:00
u32 expected_btypes ,
u32 package_index ,
union acpi_operand_object * * return_object_ptr ) ;
void
2013-05-30 10:00:01 +08:00
acpi_ns_remove_null_elements ( struct acpi_evaluate_info * info ,
2010-01-21 09:28:32 +08:00
u8 package_type ,
union acpi_operand_object * obj_desc ) ;
2009-11-12 09:44:06 +08:00
/*
* nsrepair2 - Return object repair for specific
* predefined methods / objects
*/
acpi_status
2013-05-30 10:00:01 +08:00
acpi_ns_complex_repairs ( struct acpi_evaluate_info * info ,
2009-11-12 09:44:06 +08:00
struct acpi_namespace_node * node ,
acpi_status validate_status ,
union acpi_operand_object * * return_object_ptr ) ;
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nssearch - Namespace searching and entry
2005-04-16 15:20:36 -07:00
*/
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_search_and_enter ( u32 entry_name ,
struct acpi_walk_state * walk_state ,
struct acpi_namespace_node * node ,
acpi_interpreter_mode interpreter_mode ,
acpi_object_type type ,
u32 flags , struct acpi_namespace_node * * ret_node ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2006-05-26 16:36:00 -04:00
acpi_ns_search_one_scope ( u32 entry_name ,
struct acpi_namespace_node * node ,
acpi_object_type type ,
struct acpi_namespace_node * * ret_node ) ;
2005-04-16 15:20:36 -07:00
void
2005-08-05 00:44:28 -04:00
acpi_ns_install_node ( struct acpi_walk_state * walk_state ,
struct acpi_namespace_node * parent_node ,
struct acpi_namespace_node * node , acpi_object_type type ) ;
2005-04-16 15:20:36 -07:00
/*
2005-04-18 22:49:35 -04:00
* nsutils - Utility functions
2005-04-16 15:20:36 -07:00
*/
2005-08-05 00:44:28 -04:00
acpi_object_type acpi_ns_get_type ( struct acpi_namespace_node * node ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
u32 acpi_ns_local ( acpi_object_type type ) ;
2005-04-16 15:20:36 -07:00
2008-06-10 13:55:53 +08:00
void
acpi_ns_print_node_pathname ( struct acpi_namespace_node * node , const char * msg ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
acpi_status acpi_ns_build_internal_name ( struct acpi_namestring_info * info ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
void acpi_ns_get_internal_name_length ( struct acpi_namestring_info * info ) ;
2005-04-16 15:20:36 -07:00
2008-06-10 13:55:53 +08:00
acpi_status
acpi_ns_internalize_name ( const char * dotted_name , char * * converted_name ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_ns_externalize_name ( u32 internal_name_length ,
2008-06-10 13:55:53 +08:00
const char * internal_name ,
2005-08-05 00:44:28 -04:00
u32 * converted_name_length , char * * converted_name ) ;
2005-04-16 15:20:36 -07:00
2009-12-11 14:57:00 +08:00
struct acpi_namespace_node * acpi_ns_validate_handle ( acpi_handle handle ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
void acpi_ns_terminate ( void ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
# endif /* __ACNAMESP_H__ */