1*4882a593Smuzhiyun /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */ 2*4882a593Smuzhiyun /****************************************************************************** 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Name: acutils.h -- prototypes for the common (subsystem-wide) procedures 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * Copyright (C) 2000 - 2020, Intel Corp. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun *****************************************************************************/ 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #ifndef _ACUTILS_H 11*4882a593Smuzhiyun #define _ACUTILS_H 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun extern const u8 acpi_gbl_resource_aml_sizes[]; 14*4882a593Smuzhiyun extern const u8 acpi_gbl_resource_aml_serial_bus_sizes[]; 15*4882a593Smuzhiyun 16*4882a593Smuzhiyun /* Strings used by the disassembler and debugger resource dump routines */ 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun #if defined(ACPI_DEBUG_OUTPUT) || defined (ACPI_DISASSEMBLER) || defined (ACPI_DEBUGGER) 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun extern const char *acpi_gbl_bm_decode[]; 21*4882a593Smuzhiyun extern const char *acpi_gbl_config_decode[]; 22*4882a593Smuzhiyun extern const char *acpi_gbl_consume_decode[]; 23*4882a593Smuzhiyun extern const char *acpi_gbl_dec_decode[]; 24*4882a593Smuzhiyun extern const char *acpi_gbl_he_decode[]; 25*4882a593Smuzhiyun extern const char *acpi_gbl_io_decode[]; 26*4882a593Smuzhiyun extern const char *acpi_gbl_ll_decode[]; 27*4882a593Smuzhiyun extern const char *acpi_gbl_max_decode[]; 28*4882a593Smuzhiyun extern const char *acpi_gbl_mem_decode[]; 29*4882a593Smuzhiyun extern const char *acpi_gbl_min_decode[]; 30*4882a593Smuzhiyun extern const char *acpi_gbl_mtp_decode[]; 31*4882a593Smuzhiyun extern const char *acpi_gbl_rng_decode[]; 32*4882a593Smuzhiyun extern const char *acpi_gbl_rw_decode[]; 33*4882a593Smuzhiyun extern const char *acpi_gbl_shr_decode[]; 34*4882a593Smuzhiyun extern const char *acpi_gbl_siz_decode[]; 35*4882a593Smuzhiyun extern const char *acpi_gbl_trs_decode[]; 36*4882a593Smuzhiyun extern const char *acpi_gbl_ttp_decode[]; 37*4882a593Smuzhiyun extern const char *acpi_gbl_typ_decode[]; 38*4882a593Smuzhiyun extern const char *acpi_gbl_ppc_decode[]; 39*4882a593Smuzhiyun extern const char *acpi_gbl_ior_decode[]; 40*4882a593Smuzhiyun extern const char *acpi_gbl_dts_decode[]; 41*4882a593Smuzhiyun extern const char *acpi_gbl_ct_decode[]; 42*4882a593Smuzhiyun extern const char *acpi_gbl_sbt_decode[]; 43*4882a593Smuzhiyun extern const char *acpi_gbl_am_decode[]; 44*4882a593Smuzhiyun extern const char *acpi_gbl_sm_decode[]; 45*4882a593Smuzhiyun extern const char *acpi_gbl_wm_decode[]; 46*4882a593Smuzhiyun extern const char *acpi_gbl_cph_decode[]; 47*4882a593Smuzhiyun extern const char *acpi_gbl_cpo_decode[]; 48*4882a593Smuzhiyun extern const char *acpi_gbl_dp_decode[]; 49*4882a593Smuzhiyun extern const char *acpi_gbl_ed_decode[]; 50*4882a593Smuzhiyun extern const char *acpi_gbl_bpb_decode[]; 51*4882a593Smuzhiyun extern const char *acpi_gbl_sb_decode[]; 52*4882a593Smuzhiyun extern const char *acpi_gbl_fc_decode[]; 53*4882a593Smuzhiyun extern const char *acpi_gbl_pt_decode[]; 54*4882a593Smuzhiyun extern const char *acpi_gbl_ptyp_decode[]; 55*4882a593Smuzhiyun #endif 56*4882a593Smuzhiyun 57*4882a593Smuzhiyun /* 58*4882a593Smuzhiyun * For the iASL compiler case, the output is redirected to stderr so that 59*4882a593Smuzhiyun * any of the various ACPI errors and warnings do not appear in the output 60*4882a593Smuzhiyun * files, for either the compiler or disassembler portions of the tool. 61*4882a593Smuzhiyun */ 62*4882a593Smuzhiyun #ifdef ACPI_ASL_COMPILER 63*4882a593Smuzhiyun 64*4882a593Smuzhiyun #include <stdio.h> 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun #define ACPI_MSG_REDIRECT_BEGIN \ 67*4882a593Smuzhiyun FILE *output_file = acpi_gbl_output_file; \ 68*4882a593Smuzhiyun acpi_os_redirect_output (stderr); 69*4882a593Smuzhiyun 70*4882a593Smuzhiyun #define ACPI_MSG_REDIRECT_END \ 71*4882a593Smuzhiyun acpi_os_redirect_output (output_file); 72*4882a593Smuzhiyun 73*4882a593Smuzhiyun #else 74*4882a593Smuzhiyun /* 75*4882a593Smuzhiyun * non-iASL case - no redirection, nothing to do 76*4882a593Smuzhiyun */ 77*4882a593Smuzhiyun #define ACPI_MSG_REDIRECT_BEGIN 78*4882a593Smuzhiyun #define ACPI_MSG_REDIRECT_END 79*4882a593Smuzhiyun #endif 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun /* 82*4882a593Smuzhiyun * Common error message prefixes 83*4882a593Smuzhiyun */ 84*4882a593Smuzhiyun #ifndef ACPI_MSG_ERROR 85*4882a593Smuzhiyun #define ACPI_MSG_ERROR "ACPI Error: " 86*4882a593Smuzhiyun #endif 87*4882a593Smuzhiyun #ifndef ACPI_MSG_WARNING 88*4882a593Smuzhiyun #define ACPI_MSG_WARNING "ACPI Warning: " 89*4882a593Smuzhiyun #endif 90*4882a593Smuzhiyun #ifndef ACPI_MSG_INFO 91*4882a593Smuzhiyun #define ACPI_MSG_INFO "ACPI: " 92*4882a593Smuzhiyun #endif 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun #ifndef ACPI_MSG_BIOS_ERROR 95*4882a593Smuzhiyun #define ACPI_MSG_BIOS_ERROR "Firmware Error (ACPI): " 96*4882a593Smuzhiyun #endif 97*4882a593Smuzhiyun #ifndef ACPI_MSG_BIOS_WARNING 98*4882a593Smuzhiyun #define ACPI_MSG_BIOS_WARNING "Firmware Warning (ACPI): " 99*4882a593Smuzhiyun #endif 100*4882a593Smuzhiyun 101*4882a593Smuzhiyun /* 102*4882a593Smuzhiyun * Common message suffix 103*4882a593Smuzhiyun */ 104*4882a593Smuzhiyun #define ACPI_MSG_SUFFIX \ 105*4882a593Smuzhiyun acpi_os_printf (" (%8.8X/%s-%u)\n", ACPI_CA_VERSION, module_name, line_number) 106*4882a593Smuzhiyun 107*4882a593Smuzhiyun /* Flags to indicate implicit or explicit string-to-integer conversion */ 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun #define ACPI_IMPLICIT_CONVERSION TRUE 110*4882a593Smuzhiyun #define ACPI_NO_IMPLICIT_CONVERSION FALSE 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun /* Types for Resource descriptor entries */ 113*4882a593Smuzhiyun 114*4882a593Smuzhiyun #define ACPI_INVALID_RESOURCE 0 115*4882a593Smuzhiyun #define ACPI_FIXED_LENGTH 1 116*4882a593Smuzhiyun #define ACPI_VARIABLE_LENGTH 2 117*4882a593Smuzhiyun #define ACPI_SMALL_VARIABLE_LENGTH 3 118*4882a593Smuzhiyun 119*4882a593Smuzhiyun typedef 120*4882a593Smuzhiyun acpi_status (*acpi_walk_aml_callback) (u8 *aml, 121*4882a593Smuzhiyun u32 length, 122*4882a593Smuzhiyun u32 offset, 123*4882a593Smuzhiyun u8 resource_index, void **context); 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun typedef 126*4882a593Smuzhiyun acpi_status (*acpi_pkg_callback) (u8 object_type, 127*4882a593Smuzhiyun union acpi_operand_object * source_object, 128*4882a593Smuzhiyun union acpi_generic_state * state, 129*4882a593Smuzhiyun void *context); 130*4882a593Smuzhiyun 131*4882a593Smuzhiyun struct acpi_pkg_info { 132*4882a593Smuzhiyun u8 *free_space; 133*4882a593Smuzhiyun acpi_size length; 134*4882a593Smuzhiyun u32 object_space; 135*4882a593Smuzhiyun u32 num_packages; 136*4882a593Smuzhiyun }; 137*4882a593Smuzhiyun 138*4882a593Smuzhiyun /* Object reference counts */ 139*4882a593Smuzhiyun 140*4882a593Smuzhiyun #define REF_INCREMENT (u16) 0 141*4882a593Smuzhiyun #define REF_DECREMENT (u16) 1 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun /* acpi_ut_dump_buffer */ 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun #define DB_BYTE_DISPLAY 0x01 146*4882a593Smuzhiyun #define DB_WORD_DISPLAY 0x02 147*4882a593Smuzhiyun #define DB_DWORD_DISPLAY 0x04 148*4882a593Smuzhiyun #define DB_QWORD_DISPLAY 0x08 149*4882a593Smuzhiyun #define DB_DISPLAY_DATA_ONLY 0x10 150*4882a593Smuzhiyun 151*4882a593Smuzhiyun /* 152*4882a593Smuzhiyun * utascii - ASCII utilities 153*4882a593Smuzhiyun */ 154*4882a593Smuzhiyun u8 acpi_ut_valid_nameseg(char *signature); 155*4882a593Smuzhiyun 156*4882a593Smuzhiyun u8 acpi_ut_valid_name_char(char character, u32 position); 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun void acpi_ut_check_and_repair_ascii(u8 *name, char *repaired_name, u32 count); 159*4882a593Smuzhiyun 160*4882a593Smuzhiyun /* 161*4882a593Smuzhiyun * utnonansi - Non-ANSI C library functions 162*4882a593Smuzhiyun */ 163*4882a593Smuzhiyun void acpi_ut_strupr(char *src_string); 164*4882a593Smuzhiyun 165*4882a593Smuzhiyun void acpi_ut_strlwr(char *src_string); 166*4882a593Smuzhiyun 167*4882a593Smuzhiyun int acpi_ut_stricmp(char *string1, char *string2); 168*4882a593Smuzhiyun 169*4882a593Smuzhiyun /* 170*4882a593Smuzhiyun * utstrsuppt - string-to-integer conversion support functions 171*4882a593Smuzhiyun */ 172*4882a593Smuzhiyun acpi_status acpi_ut_convert_octal_string(char *string, u64 *return_value); 173*4882a593Smuzhiyun 174*4882a593Smuzhiyun acpi_status acpi_ut_convert_decimal_string(char *string, u64 *return_value_ptr); 175*4882a593Smuzhiyun 176*4882a593Smuzhiyun acpi_status acpi_ut_convert_hex_string(char *string, u64 *return_value_ptr); 177*4882a593Smuzhiyun 178*4882a593Smuzhiyun char acpi_ut_remove_whitespace(char **string); 179*4882a593Smuzhiyun 180*4882a593Smuzhiyun char acpi_ut_remove_leading_zeros(char **string); 181*4882a593Smuzhiyun 182*4882a593Smuzhiyun u8 acpi_ut_detect_hex_prefix(char **string); 183*4882a593Smuzhiyun 184*4882a593Smuzhiyun void acpi_ut_remove_hex_prefix(char **string); 185*4882a593Smuzhiyun 186*4882a593Smuzhiyun u8 acpi_ut_detect_octal_prefix(char **string); 187*4882a593Smuzhiyun 188*4882a593Smuzhiyun /* 189*4882a593Smuzhiyun * utstrtoul64 - string-to-integer conversion functions 190*4882a593Smuzhiyun */ 191*4882a593Smuzhiyun acpi_status acpi_ut_strtoul64(char *string, u64 *ret_integer); 192*4882a593Smuzhiyun 193*4882a593Smuzhiyun u64 acpi_ut_explicit_strtoul64(char *string); 194*4882a593Smuzhiyun 195*4882a593Smuzhiyun u64 acpi_ut_implicit_strtoul64(char *string); 196*4882a593Smuzhiyun 197*4882a593Smuzhiyun /* 198*4882a593Smuzhiyun * utglobal - Global data structures and procedures 199*4882a593Smuzhiyun */ 200*4882a593Smuzhiyun acpi_status acpi_ut_init_globals(void); 201*4882a593Smuzhiyun 202*4882a593Smuzhiyun const char *acpi_ut_get_mutex_name(u32 mutex_id); 203*4882a593Smuzhiyun 204*4882a593Smuzhiyun #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER) 205*4882a593Smuzhiyun 206*4882a593Smuzhiyun const char *acpi_ut_get_notify_name(u32 notify_value, acpi_object_type type); 207*4882a593Smuzhiyun #endif 208*4882a593Smuzhiyun 209*4882a593Smuzhiyun const char *acpi_ut_get_type_name(acpi_object_type type); 210*4882a593Smuzhiyun 211*4882a593Smuzhiyun const char *acpi_ut_get_node_name(void *object); 212*4882a593Smuzhiyun 213*4882a593Smuzhiyun const char *acpi_ut_get_descriptor_name(void *object); 214*4882a593Smuzhiyun 215*4882a593Smuzhiyun const char *acpi_ut_get_reference_name(union acpi_operand_object *object); 216*4882a593Smuzhiyun 217*4882a593Smuzhiyun const char *acpi_ut_get_object_type_name(union acpi_operand_object *obj_desc); 218*4882a593Smuzhiyun 219*4882a593Smuzhiyun const char *acpi_ut_get_region_name(u8 space_id); 220*4882a593Smuzhiyun 221*4882a593Smuzhiyun const char *acpi_ut_get_event_name(u32 event_id); 222*4882a593Smuzhiyun 223*4882a593Smuzhiyun const char *acpi_ut_get_argument_type_name(u32 arg_type); 224*4882a593Smuzhiyun 225*4882a593Smuzhiyun char acpi_ut_hex_to_ascii_char(u64 integer, u32 position); 226*4882a593Smuzhiyun 227*4882a593Smuzhiyun acpi_status acpi_ut_ascii_to_hex_byte(char *two_ascii_chars, u8 *return_byte); 228*4882a593Smuzhiyun 229*4882a593Smuzhiyun u8 acpi_ut_ascii_char_to_hex(int hex_char); 230*4882a593Smuzhiyun 231*4882a593Smuzhiyun u8 acpi_ut_valid_object_type(acpi_object_type type); 232*4882a593Smuzhiyun 233*4882a593Smuzhiyun /* 234*4882a593Smuzhiyun * utinit - miscellaneous initialization and shutdown 235*4882a593Smuzhiyun */ 236*4882a593Smuzhiyun acpi_status acpi_ut_hardware_initialize(void); 237*4882a593Smuzhiyun 238*4882a593Smuzhiyun void acpi_ut_subsystem_shutdown(void); 239*4882a593Smuzhiyun 240*4882a593Smuzhiyun /* 241*4882a593Smuzhiyun * utcopy - Object construction and conversion interfaces 242*4882a593Smuzhiyun */ 243*4882a593Smuzhiyun acpi_status 244*4882a593Smuzhiyun acpi_ut_build_simple_object(union acpi_operand_object *obj, 245*4882a593Smuzhiyun union acpi_object *user_obj, 246*4882a593Smuzhiyun u8 *data_space, u32 *buffer_space_used); 247*4882a593Smuzhiyun 248*4882a593Smuzhiyun acpi_status 249*4882a593Smuzhiyun acpi_ut_build_package_object(union acpi_operand_object *obj, 250*4882a593Smuzhiyun u8 *buffer, u32 *space_used); 251*4882a593Smuzhiyun 252*4882a593Smuzhiyun acpi_status 253*4882a593Smuzhiyun acpi_ut_copy_iobject_to_eobject(union acpi_operand_object *obj, 254*4882a593Smuzhiyun struct acpi_buffer *ret_buffer); 255*4882a593Smuzhiyun 256*4882a593Smuzhiyun acpi_status 257*4882a593Smuzhiyun acpi_ut_copy_eobject_to_iobject(union acpi_object *obj, 258*4882a593Smuzhiyun union acpi_operand_object **internal_obj); 259*4882a593Smuzhiyun 260*4882a593Smuzhiyun acpi_status 261*4882a593Smuzhiyun acpi_ut_copy_isimple_to_isimple(union acpi_operand_object *source_obj, 262*4882a593Smuzhiyun union acpi_operand_object *dest_obj); 263*4882a593Smuzhiyun 264*4882a593Smuzhiyun acpi_status 265*4882a593Smuzhiyun acpi_ut_copy_iobject_to_iobject(union acpi_operand_object *source_desc, 266*4882a593Smuzhiyun union acpi_operand_object **dest_desc, 267*4882a593Smuzhiyun struct acpi_walk_state *walk_state); 268*4882a593Smuzhiyun 269*4882a593Smuzhiyun /* 270*4882a593Smuzhiyun * utcreate - Object creation 271*4882a593Smuzhiyun */ 272*4882a593Smuzhiyun acpi_status 273*4882a593Smuzhiyun acpi_ut_update_object_reference(union acpi_operand_object *object, u16 action); 274*4882a593Smuzhiyun 275*4882a593Smuzhiyun /* 276*4882a593Smuzhiyun * utdebug - Debug interfaces 277*4882a593Smuzhiyun */ 278*4882a593Smuzhiyun void acpi_ut_init_stack_ptr_trace(void); 279*4882a593Smuzhiyun 280*4882a593Smuzhiyun void acpi_ut_track_stack_ptr(void); 281*4882a593Smuzhiyun 282*4882a593Smuzhiyun void 283*4882a593Smuzhiyun acpi_ut_trace(u32 line_number, 284*4882a593Smuzhiyun const char *function_name, 285*4882a593Smuzhiyun const char *module_name, u32 component_id); 286*4882a593Smuzhiyun 287*4882a593Smuzhiyun void 288*4882a593Smuzhiyun acpi_ut_trace_ptr(u32 line_number, 289*4882a593Smuzhiyun const char *function_name, 290*4882a593Smuzhiyun const char *module_name, 291*4882a593Smuzhiyun u32 component_id, const void *pointer); 292*4882a593Smuzhiyun 293*4882a593Smuzhiyun void 294*4882a593Smuzhiyun acpi_ut_trace_u32(u32 line_number, 295*4882a593Smuzhiyun const char *function_name, 296*4882a593Smuzhiyun const char *module_name, u32 component_id, u32 integer); 297*4882a593Smuzhiyun 298*4882a593Smuzhiyun void 299*4882a593Smuzhiyun acpi_ut_trace_str(u32 line_number, 300*4882a593Smuzhiyun const char *function_name, 301*4882a593Smuzhiyun const char *module_name, 302*4882a593Smuzhiyun u32 component_id, const char *string); 303*4882a593Smuzhiyun 304*4882a593Smuzhiyun void 305*4882a593Smuzhiyun acpi_ut_exit(u32 line_number, 306*4882a593Smuzhiyun const char *function_name, 307*4882a593Smuzhiyun const char *module_name, u32 component_id); 308*4882a593Smuzhiyun 309*4882a593Smuzhiyun void 310*4882a593Smuzhiyun acpi_ut_status_exit(u32 line_number, 311*4882a593Smuzhiyun const char *function_name, 312*4882a593Smuzhiyun const char *module_name, 313*4882a593Smuzhiyun u32 component_id, acpi_status status); 314*4882a593Smuzhiyun 315*4882a593Smuzhiyun void 316*4882a593Smuzhiyun acpi_ut_value_exit(u32 line_number, 317*4882a593Smuzhiyun const char *function_name, 318*4882a593Smuzhiyun const char *module_name, u32 component_id, u64 value); 319*4882a593Smuzhiyun 320*4882a593Smuzhiyun void 321*4882a593Smuzhiyun acpi_ut_ptr_exit(u32 line_number, 322*4882a593Smuzhiyun const char *function_name, 323*4882a593Smuzhiyun const char *module_name, u32 component_id, u8 *ptr); 324*4882a593Smuzhiyun 325*4882a593Smuzhiyun void 326*4882a593Smuzhiyun acpi_ut_str_exit(u32 line_number, 327*4882a593Smuzhiyun const char *function_name, 328*4882a593Smuzhiyun const char *module_name, u32 component_id, const char *string); 329*4882a593Smuzhiyun 330*4882a593Smuzhiyun void 331*4882a593Smuzhiyun acpi_ut_debug_dump_buffer(u8 *buffer, u32 count, u32 display, u32 component_id); 332*4882a593Smuzhiyun 333*4882a593Smuzhiyun void acpi_ut_dump_buffer(u8 *buffer, u32 count, u32 display, u32 offset); 334*4882a593Smuzhiyun 335*4882a593Smuzhiyun #ifdef ACPI_APPLICATION 336*4882a593Smuzhiyun void 337*4882a593Smuzhiyun acpi_ut_dump_buffer_to_file(ACPI_FILE file, 338*4882a593Smuzhiyun u8 *buffer, 339*4882a593Smuzhiyun u32 count, u32 display, u32 base_offset); 340*4882a593Smuzhiyun #endif 341*4882a593Smuzhiyun 342*4882a593Smuzhiyun void acpi_ut_report_error(char *module_name, u32 line_number); 343*4882a593Smuzhiyun 344*4882a593Smuzhiyun void acpi_ut_report_info(char *module_name, u32 line_number); 345*4882a593Smuzhiyun 346*4882a593Smuzhiyun void acpi_ut_report_warning(char *module_name, u32 line_number); 347*4882a593Smuzhiyun 348*4882a593Smuzhiyun /* 349*4882a593Smuzhiyun * utdelete - Object deletion and reference counts 350*4882a593Smuzhiyun */ 351*4882a593Smuzhiyun void acpi_ut_add_reference(union acpi_operand_object *object); 352*4882a593Smuzhiyun 353*4882a593Smuzhiyun void acpi_ut_remove_reference(union acpi_operand_object *object); 354*4882a593Smuzhiyun 355*4882a593Smuzhiyun void acpi_ut_delete_internal_package_object(union acpi_operand_object *object); 356*4882a593Smuzhiyun 357*4882a593Smuzhiyun void acpi_ut_delete_internal_simple_object(union acpi_operand_object *object); 358*4882a593Smuzhiyun 359*4882a593Smuzhiyun void acpi_ut_delete_internal_object_list(union acpi_operand_object **obj_list); 360*4882a593Smuzhiyun 361*4882a593Smuzhiyun /* 362*4882a593Smuzhiyun * uteval - object evaluation 363*4882a593Smuzhiyun */ 364*4882a593Smuzhiyun acpi_status 365*4882a593Smuzhiyun acpi_ut_evaluate_object(struct acpi_namespace_node *prefix_node, 366*4882a593Smuzhiyun const char *path, 367*4882a593Smuzhiyun u32 expected_return_btypes, 368*4882a593Smuzhiyun union acpi_operand_object **return_desc); 369*4882a593Smuzhiyun 370*4882a593Smuzhiyun acpi_status 371*4882a593Smuzhiyun acpi_ut_evaluate_numeric_object(const char *object_name, 372*4882a593Smuzhiyun struct acpi_namespace_node *device_node, 373*4882a593Smuzhiyun u64 *value); 374*4882a593Smuzhiyun 375*4882a593Smuzhiyun acpi_status 376*4882a593Smuzhiyun acpi_ut_execute_STA(struct acpi_namespace_node *device_node, u32 *status_flags); 377*4882a593Smuzhiyun 378*4882a593Smuzhiyun acpi_status 379*4882a593Smuzhiyun acpi_ut_execute_power_methods(struct acpi_namespace_node *device_node, 380*4882a593Smuzhiyun const char **method_names, 381*4882a593Smuzhiyun u8 method_count, u8 *out_values); 382*4882a593Smuzhiyun 383*4882a593Smuzhiyun /* 384*4882a593Smuzhiyun * utids - device ID support 385*4882a593Smuzhiyun */ 386*4882a593Smuzhiyun acpi_status 387*4882a593Smuzhiyun acpi_ut_execute_HID(struct acpi_namespace_node *device_node, 388*4882a593Smuzhiyun struct acpi_pnp_device_id ** return_id); 389*4882a593Smuzhiyun 390*4882a593Smuzhiyun acpi_status 391*4882a593Smuzhiyun acpi_ut_execute_UID(struct acpi_namespace_node *device_node, 392*4882a593Smuzhiyun struct acpi_pnp_device_id ** return_id); 393*4882a593Smuzhiyun 394*4882a593Smuzhiyun acpi_status 395*4882a593Smuzhiyun acpi_ut_execute_CID(struct acpi_namespace_node *device_node, 396*4882a593Smuzhiyun struct acpi_pnp_device_id_list ** return_cid_list); 397*4882a593Smuzhiyun 398*4882a593Smuzhiyun acpi_status 399*4882a593Smuzhiyun acpi_ut_execute_CLS(struct acpi_namespace_node *device_node, 400*4882a593Smuzhiyun struct acpi_pnp_device_id **return_id); 401*4882a593Smuzhiyun 402*4882a593Smuzhiyun /* 403*4882a593Smuzhiyun * utlock - reader/writer locks 404*4882a593Smuzhiyun */ 405*4882a593Smuzhiyun acpi_status acpi_ut_create_rw_lock(struct acpi_rw_lock *lock); 406*4882a593Smuzhiyun 407*4882a593Smuzhiyun void acpi_ut_delete_rw_lock(struct acpi_rw_lock *lock); 408*4882a593Smuzhiyun 409*4882a593Smuzhiyun acpi_status acpi_ut_acquire_read_lock(struct acpi_rw_lock *lock); 410*4882a593Smuzhiyun 411*4882a593Smuzhiyun acpi_status acpi_ut_release_read_lock(struct acpi_rw_lock *lock); 412*4882a593Smuzhiyun 413*4882a593Smuzhiyun acpi_status acpi_ut_acquire_write_lock(struct acpi_rw_lock *lock); 414*4882a593Smuzhiyun 415*4882a593Smuzhiyun void acpi_ut_release_write_lock(struct acpi_rw_lock *lock); 416*4882a593Smuzhiyun 417*4882a593Smuzhiyun /* 418*4882a593Smuzhiyun * utobject - internal object create/delete/cache routines 419*4882a593Smuzhiyun */ 420*4882a593Smuzhiyun union acpi_operand_object *acpi_ut_create_internal_object_dbg(const char 421*4882a593Smuzhiyun *module_name, 422*4882a593Smuzhiyun u32 line_number, 423*4882a593Smuzhiyun u32 component_id, 424*4882a593Smuzhiyun acpi_object_type 425*4882a593Smuzhiyun type); 426*4882a593Smuzhiyun 427*4882a593Smuzhiyun void *acpi_ut_allocate_object_desc_dbg(const char *module_name, 428*4882a593Smuzhiyun u32 line_number, u32 component_id); 429*4882a593Smuzhiyun 430*4882a593Smuzhiyun #define acpi_ut_create_internal_object(t) acpi_ut_create_internal_object_dbg (_acpi_module_name,__LINE__,_COMPONENT,t) 431*4882a593Smuzhiyun #define acpi_ut_allocate_object_desc() acpi_ut_allocate_object_desc_dbg (_acpi_module_name,__LINE__,_COMPONENT) 432*4882a593Smuzhiyun 433*4882a593Smuzhiyun void acpi_ut_delete_object_desc(union acpi_operand_object *object); 434*4882a593Smuzhiyun 435*4882a593Smuzhiyun u8 acpi_ut_valid_internal_object(void *object); 436*4882a593Smuzhiyun 437*4882a593Smuzhiyun union acpi_operand_object *acpi_ut_create_package_object(u32 count); 438*4882a593Smuzhiyun 439*4882a593Smuzhiyun union acpi_operand_object *acpi_ut_create_integer_object(u64 value); 440*4882a593Smuzhiyun 441*4882a593Smuzhiyun union acpi_operand_object *acpi_ut_create_buffer_object(acpi_size buffer_size); 442*4882a593Smuzhiyun 443*4882a593Smuzhiyun union acpi_operand_object *acpi_ut_create_string_object(acpi_size string_size); 444*4882a593Smuzhiyun 445*4882a593Smuzhiyun acpi_status 446*4882a593Smuzhiyun acpi_ut_get_object_size(union acpi_operand_object *obj, acpi_size *obj_length); 447*4882a593Smuzhiyun 448*4882a593Smuzhiyun /* 449*4882a593Smuzhiyun * utosi - Support for the _OSI predefined control method 450*4882a593Smuzhiyun */ 451*4882a593Smuzhiyun acpi_status acpi_ut_initialize_interfaces(void); 452*4882a593Smuzhiyun 453*4882a593Smuzhiyun acpi_status acpi_ut_interface_terminate(void); 454*4882a593Smuzhiyun 455*4882a593Smuzhiyun acpi_status acpi_ut_install_interface(acpi_string interface_name); 456*4882a593Smuzhiyun 457*4882a593Smuzhiyun acpi_status acpi_ut_remove_interface(acpi_string interface_name); 458*4882a593Smuzhiyun 459*4882a593Smuzhiyun acpi_status acpi_ut_update_interfaces(u8 action); 460*4882a593Smuzhiyun 461*4882a593Smuzhiyun struct acpi_interface_info *acpi_ut_get_interface(acpi_string interface_name); 462*4882a593Smuzhiyun 463*4882a593Smuzhiyun acpi_status acpi_ut_osi_implementation(struct acpi_walk_state *walk_state); 464*4882a593Smuzhiyun 465*4882a593Smuzhiyun /* 466*4882a593Smuzhiyun * utpredef - support for predefined names 467*4882a593Smuzhiyun */ 468*4882a593Smuzhiyun const union acpi_predefined_info *acpi_ut_get_next_predefined_method(const union 469*4882a593Smuzhiyun acpi_predefined_info 470*4882a593Smuzhiyun *this_name); 471*4882a593Smuzhiyun 472*4882a593Smuzhiyun const union acpi_predefined_info *acpi_ut_match_predefined_method(char *name); 473*4882a593Smuzhiyun 474*4882a593Smuzhiyun void acpi_ut_get_expected_return_types(char *buffer, u32 expected_btypes); 475*4882a593Smuzhiyun 476*4882a593Smuzhiyun #if (defined ACPI_ASL_COMPILER || defined ACPI_HELP_APP) 477*4882a593Smuzhiyun const union acpi_predefined_info *acpi_ut_match_resource_name(char *name); 478*4882a593Smuzhiyun 479*4882a593Smuzhiyun void 480*4882a593Smuzhiyun acpi_ut_display_predefined_method(char *buffer, 481*4882a593Smuzhiyun const union acpi_predefined_info *this_name, 482*4882a593Smuzhiyun u8 multi_line); 483*4882a593Smuzhiyun 484*4882a593Smuzhiyun u32 acpi_ut_get_resource_bit_width(char *buffer, u16 types); 485*4882a593Smuzhiyun #endif 486*4882a593Smuzhiyun 487*4882a593Smuzhiyun /* 488*4882a593Smuzhiyun * utstate - Generic state creation/cache routines 489*4882a593Smuzhiyun */ 490*4882a593Smuzhiyun void 491*4882a593Smuzhiyun acpi_ut_push_generic_state(union acpi_generic_state **list_head, 492*4882a593Smuzhiyun union acpi_generic_state *state); 493*4882a593Smuzhiyun 494*4882a593Smuzhiyun union acpi_generic_state *acpi_ut_pop_generic_state(union acpi_generic_state 495*4882a593Smuzhiyun **list_head); 496*4882a593Smuzhiyun 497*4882a593Smuzhiyun union acpi_generic_state *acpi_ut_create_generic_state(void); 498*4882a593Smuzhiyun 499*4882a593Smuzhiyun struct acpi_thread_state *acpi_ut_create_thread_state(void); 500*4882a593Smuzhiyun 501*4882a593Smuzhiyun union acpi_generic_state *acpi_ut_create_update_state(union acpi_operand_object 502*4882a593Smuzhiyun *object, u16 action); 503*4882a593Smuzhiyun 504*4882a593Smuzhiyun union acpi_generic_state *acpi_ut_create_pkg_state(void *internal_object, 505*4882a593Smuzhiyun void *external_object, 506*4882a593Smuzhiyun u32 index); 507*4882a593Smuzhiyun 508*4882a593Smuzhiyun acpi_status 509*4882a593Smuzhiyun acpi_ut_create_update_state_and_push(union acpi_operand_object *object, 510*4882a593Smuzhiyun u16 action, 511*4882a593Smuzhiyun union acpi_generic_state **state_list); 512*4882a593Smuzhiyun 513*4882a593Smuzhiyun union acpi_generic_state *acpi_ut_create_control_state(void); 514*4882a593Smuzhiyun 515*4882a593Smuzhiyun void acpi_ut_delete_generic_state(union acpi_generic_state *state); 516*4882a593Smuzhiyun 517*4882a593Smuzhiyun /* 518*4882a593Smuzhiyun * utmath 519*4882a593Smuzhiyun */ 520*4882a593Smuzhiyun acpi_status 521*4882a593Smuzhiyun acpi_ut_divide(u64 in_dividend, 522*4882a593Smuzhiyun u64 in_divisor, u64 *out_quotient, u64 *out_remainder); 523*4882a593Smuzhiyun 524*4882a593Smuzhiyun acpi_status 525*4882a593Smuzhiyun acpi_ut_short_divide(u64 in_dividend, 526*4882a593Smuzhiyun u32 divisor, u64 *out_quotient, u32 *out_remainder); 527*4882a593Smuzhiyun 528*4882a593Smuzhiyun acpi_status 529*4882a593Smuzhiyun acpi_ut_short_multiply(u64 in_multiplicand, u32 multiplier, u64 *outproduct); 530*4882a593Smuzhiyun 531*4882a593Smuzhiyun acpi_status acpi_ut_short_shift_left(u64 operand, u32 count, u64 *out_result); 532*4882a593Smuzhiyun 533*4882a593Smuzhiyun acpi_status acpi_ut_short_shift_right(u64 operand, u32 count, u64 *out_result); 534*4882a593Smuzhiyun 535*4882a593Smuzhiyun /* 536*4882a593Smuzhiyun * utmisc 537*4882a593Smuzhiyun */ 538*4882a593Smuzhiyun const struct acpi_exception_info *acpi_ut_validate_exception(acpi_status 539*4882a593Smuzhiyun status); 540*4882a593Smuzhiyun 541*4882a593Smuzhiyun u8 acpi_ut_is_pci_root_bridge(char *id); 542*4882a593Smuzhiyun 543*4882a593Smuzhiyun #if (defined ACPI_ASL_COMPILER || defined ACPI_EXEC_APP || defined ACPI_NAMES_APP) 544*4882a593Smuzhiyun u8 acpi_ut_is_aml_table(struct acpi_table_header *table); 545*4882a593Smuzhiyun #endif 546*4882a593Smuzhiyun 547*4882a593Smuzhiyun acpi_status 548*4882a593Smuzhiyun acpi_ut_walk_package_tree(union acpi_operand_object *source_object, 549*4882a593Smuzhiyun void *target_object, 550*4882a593Smuzhiyun acpi_pkg_callback walk_callback, void *context); 551*4882a593Smuzhiyun 552*4882a593Smuzhiyun /* Values for Base above (16=Hex, 10=Decimal) */ 553*4882a593Smuzhiyun 554*4882a593Smuzhiyun #define ACPI_ANY_BASE 0 555*4882a593Smuzhiyun 556*4882a593Smuzhiyun u32 acpi_ut_dword_byte_swap(u32 value); 557*4882a593Smuzhiyun 558*4882a593Smuzhiyun void acpi_ut_set_integer_width(u8 revision); 559*4882a593Smuzhiyun 560*4882a593Smuzhiyun #ifdef ACPI_DEBUG_OUTPUT 561*4882a593Smuzhiyun void 562*4882a593Smuzhiyun acpi_ut_display_init_pathname(u8 type, 563*4882a593Smuzhiyun struct acpi_namespace_node *obj_handle, 564*4882a593Smuzhiyun const char *path); 565*4882a593Smuzhiyun #endif 566*4882a593Smuzhiyun 567*4882a593Smuzhiyun /* 568*4882a593Smuzhiyun * utownerid - Support for Table/Method Owner IDs 569*4882a593Smuzhiyun */ 570*4882a593Smuzhiyun acpi_status acpi_ut_allocate_owner_id(acpi_owner_id *owner_id); 571*4882a593Smuzhiyun 572*4882a593Smuzhiyun void acpi_ut_release_owner_id(acpi_owner_id *owner_id); 573*4882a593Smuzhiyun 574*4882a593Smuzhiyun /* 575*4882a593Smuzhiyun * utresrc 576*4882a593Smuzhiyun */ 577*4882a593Smuzhiyun acpi_status 578*4882a593Smuzhiyun acpi_ut_walk_aml_resources(struct acpi_walk_state *walk_state, 579*4882a593Smuzhiyun u8 *aml, 580*4882a593Smuzhiyun acpi_size aml_length, 581*4882a593Smuzhiyun acpi_walk_aml_callback user_function, 582*4882a593Smuzhiyun void **context); 583*4882a593Smuzhiyun 584*4882a593Smuzhiyun acpi_status 585*4882a593Smuzhiyun acpi_ut_validate_resource(struct acpi_walk_state *walk_state, 586*4882a593Smuzhiyun void *aml, u8 *return_index); 587*4882a593Smuzhiyun 588*4882a593Smuzhiyun u32 acpi_ut_get_descriptor_length(void *aml); 589*4882a593Smuzhiyun 590*4882a593Smuzhiyun u16 acpi_ut_get_resource_length(void *aml); 591*4882a593Smuzhiyun 592*4882a593Smuzhiyun u8 acpi_ut_get_resource_header_length(void *aml); 593*4882a593Smuzhiyun 594*4882a593Smuzhiyun u8 acpi_ut_get_resource_type(void *aml); 595*4882a593Smuzhiyun 596*4882a593Smuzhiyun acpi_status 597*4882a593Smuzhiyun acpi_ut_get_resource_end_tag(union acpi_operand_object *obj_desc, u8 **end_tag); 598*4882a593Smuzhiyun 599*4882a593Smuzhiyun /* 600*4882a593Smuzhiyun * utstring - String and character utilities 601*4882a593Smuzhiyun */ 602*4882a593Smuzhiyun void acpi_ut_print_string(char *string, u16 max_length); 603*4882a593Smuzhiyun 604*4882a593Smuzhiyun #if defined ACPI_ASL_COMPILER || defined ACPI_EXEC_APP 605*4882a593Smuzhiyun void ut_convert_backslashes(char *pathname); 606*4882a593Smuzhiyun #endif 607*4882a593Smuzhiyun 608*4882a593Smuzhiyun void acpi_ut_repair_name(char *name); 609*4882a593Smuzhiyun 610*4882a593Smuzhiyun #if defined (ACPI_DEBUGGER) || defined (ACPI_APPLICATION) || defined (ACPI_DEBUG_OUTPUT) 611*4882a593Smuzhiyun u8 acpi_ut_safe_strcpy(char *dest, acpi_size dest_size, char *source); 612*4882a593Smuzhiyun 613*4882a593Smuzhiyun void acpi_ut_safe_strncpy(char *dest, char *source, acpi_size dest_size); 614*4882a593Smuzhiyun 615*4882a593Smuzhiyun u8 acpi_ut_safe_strcat(char *dest, acpi_size dest_size, char *source); 616*4882a593Smuzhiyun 617*4882a593Smuzhiyun u8 618*4882a593Smuzhiyun acpi_ut_safe_strncat(char *dest, 619*4882a593Smuzhiyun acpi_size dest_size, 620*4882a593Smuzhiyun char *source, acpi_size max_transfer_length); 621*4882a593Smuzhiyun #endif 622*4882a593Smuzhiyun 623*4882a593Smuzhiyun /* 624*4882a593Smuzhiyun * utmutex - mutex support 625*4882a593Smuzhiyun */ 626*4882a593Smuzhiyun acpi_status acpi_ut_mutex_initialize(void); 627*4882a593Smuzhiyun 628*4882a593Smuzhiyun void acpi_ut_mutex_terminate(void); 629*4882a593Smuzhiyun 630*4882a593Smuzhiyun acpi_status acpi_ut_acquire_mutex(acpi_mutex_handle mutex_id); 631*4882a593Smuzhiyun 632*4882a593Smuzhiyun acpi_status acpi_ut_release_mutex(acpi_mutex_handle mutex_id); 633*4882a593Smuzhiyun 634*4882a593Smuzhiyun /* 635*4882a593Smuzhiyun * utalloc - memory allocation and object caching 636*4882a593Smuzhiyun */ 637*4882a593Smuzhiyun acpi_status acpi_ut_create_caches(void); 638*4882a593Smuzhiyun 639*4882a593Smuzhiyun acpi_status acpi_ut_delete_caches(void); 640*4882a593Smuzhiyun 641*4882a593Smuzhiyun acpi_status acpi_ut_validate_buffer(struct acpi_buffer *buffer); 642*4882a593Smuzhiyun 643*4882a593Smuzhiyun acpi_status 644*4882a593Smuzhiyun acpi_ut_initialize_buffer(struct acpi_buffer *buffer, 645*4882a593Smuzhiyun acpi_size required_length); 646*4882a593Smuzhiyun 647*4882a593Smuzhiyun #ifdef ACPI_DBG_TRACK_ALLOCATIONS 648*4882a593Smuzhiyun void *acpi_ut_allocate_and_track(acpi_size size, 649*4882a593Smuzhiyun u32 component, const char *module, u32 line); 650*4882a593Smuzhiyun 651*4882a593Smuzhiyun void *acpi_ut_allocate_zeroed_and_track(acpi_size size, 652*4882a593Smuzhiyun u32 component, 653*4882a593Smuzhiyun const char *module, u32 line); 654*4882a593Smuzhiyun 655*4882a593Smuzhiyun void 656*4882a593Smuzhiyun acpi_ut_free_and_track(void *address, 657*4882a593Smuzhiyun u32 component, const char *module, u32 line); 658*4882a593Smuzhiyun 659*4882a593Smuzhiyun void acpi_ut_dump_allocation_info(void); 660*4882a593Smuzhiyun 661*4882a593Smuzhiyun void acpi_ut_dump_allocations(u32 component, const char *module); 662*4882a593Smuzhiyun 663*4882a593Smuzhiyun acpi_status 664*4882a593Smuzhiyun acpi_ut_create_list(const char *list_name, 665*4882a593Smuzhiyun u16 object_size, struct acpi_memory_list **return_cache); 666*4882a593Smuzhiyun 667*4882a593Smuzhiyun #endif /* ACPI_DBG_TRACK_ALLOCATIONS */ 668*4882a593Smuzhiyun 669*4882a593Smuzhiyun /* 670*4882a593Smuzhiyun * utaddress - address range check 671*4882a593Smuzhiyun */ 672*4882a593Smuzhiyun acpi_status 673*4882a593Smuzhiyun acpi_ut_add_address_range(acpi_adr_space_type space_id, 674*4882a593Smuzhiyun acpi_physical_address address, 675*4882a593Smuzhiyun u32 length, struct acpi_namespace_node *region_node); 676*4882a593Smuzhiyun 677*4882a593Smuzhiyun void 678*4882a593Smuzhiyun acpi_ut_remove_address_range(acpi_adr_space_type space_id, 679*4882a593Smuzhiyun struct acpi_namespace_node *region_node); 680*4882a593Smuzhiyun 681*4882a593Smuzhiyun u32 682*4882a593Smuzhiyun acpi_ut_check_address_range(acpi_adr_space_type space_id, 683*4882a593Smuzhiyun acpi_physical_address address, u32 length, u8 warn); 684*4882a593Smuzhiyun 685*4882a593Smuzhiyun void acpi_ut_delete_address_lists(void); 686*4882a593Smuzhiyun 687*4882a593Smuzhiyun /* 688*4882a593Smuzhiyun * utxferror - various error/warning output functions 689*4882a593Smuzhiyun */ 690*4882a593Smuzhiyun ACPI_PRINTF_LIKE(5) 691*4882a593Smuzhiyun void ACPI_INTERNAL_VAR_XFACE 692*4882a593Smuzhiyun acpi_ut_predefined_warning(const char *module_name, 693*4882a593Smuzhiyun u32 line_number, 694*4882a593Smuzhiyun char *pathname, 695*4882a593Smuzhiyun u16 node_flags, const char *format, ...); 696*4882a593Smuzhiyun 697*4882a593Smuzhiyun ACPI_PRINTF_LIKE(5) 698*4882a593Smuzhiyun void ACPI_INTERNAL_VAR_XFACE 699*4882a593Smuzhiyun acpi_ut_predefined_info(const char *module_name, 700*4882a593Smuzhiyun u32 line_number, 701*4882a593Smuzhiyun char *pathname, 702*4882a593Smuzhiyun u16 node_flags, const char *format, ...); 703*4882a593Smuzhiyun 704*4882a593Smuzhiyun ACPI_PRINTF_LIKE(5) 705*4882a593Smuzhiyun void ACPI_INTERNAL_VAR_XFACE 706*4882a593Smuzhiyun acpi_ut_predefined_bios_error(const char *module_name, 707*4882a593Smuzhiyun u32 line_number, 708*4882a593Smuzhiyun char *pathname, 709*4882a593Smuzhiyun u16 node_flags, const char *format, ...); 710*4882a593Smuzhiyun 711*4882a593Smuzhiyun void 712*4882a593Smuzhiyun acpi_ut_prefixed_namespace_error(const char *module_name, 713*4882a593Smuzhiyun u32 line_number, 714*4882a593Smuzhiyun union acpi_generic_state *prefix_scope, 715*4882a593Smuzhiyun const char *internal_name, 716*4882a593Smuzhiyun acpi_status lookup_status); 717*4882a593Smuzhiyun 718*4882a593Smuzhiyun void 719*4882a593Smuzhiyun acpi_ut_method_error(const char *module_name, 720*4882a593Smuzhiyun u32 line_number, 721*4882a593Smuzhiyun const char *message, 722*4882a593Smuzhiyun struct acpi_namespace_node *node, 723*4882a593Smuzhiyun const char *path, acpi_status lookup_status); 724*4882a593Smuzhiyun 725*4882a593Smuzhiyun /* 726*4882a593Smuzhiyun * Utility functions for ACPI names and IDs 727*4882a593Smuzhiyun */ 728*4882a593Smuzhiyun const struct ah_predefined_name *acpi_ah_match_predefined_name(char *nameseg); 729*4882a593Smuzhiyun 730*4882a593Smuzhiyun const struct ah_device_id *acpi_ah_match_hardware_id(char *hid); 731*4882a593Smuzhiyun 732*4882a593Smuzhiyun const char *acpi_ah_match_uuid(u8 *data); 733*4882a593Smuzhiyun 734*4882a593Smuzhiyun /* 735*4882a593Smuzhiyun * utuuid -- UUID support functions 736*4882a593Smuzhiyun */ 737*4882a593Smuzhiyun #if (defined ACPI_ASL_COMPILER || defined ACPI_EXEC_APP || defined ACPI_HELP_APP) 738*4882a593Smuzhiyun void acpi_ut_convert_string_to_uuid(char *in_string, u8 *uuid_buffer); 739*4882a593Smuzhiyun #endif 740*4882a593Smuzhiyun 741*4882a593Smuzhiyun #endif /* _ACUTILS_H */ 742