1*4882a593Smuzhiyun /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */ 2*4882a593Smuzhiyun /****************************************************************************** 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Name: acglobal.h - Declarations for global variables 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * Copyright (C) 2000 - 2020, Intel Corp. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun *****************************************************************************/ 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #ifndef __ACGLOBAL_H__ 11*4882a593Smuzhiyun #define __ACGLOBAL_H__ 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun /***************************************************************************** 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * Globals related to the incoming ACPI tables 16*4882a593Smuzhiyun * 17*4882a593Smuzhiyun ****************************************************************************/ 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun /* Master list of all ACPI tables that were found in the RSDT/XSDT */ 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_table_list, acpi_gbl_root_table_list); 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun /* DSDT information. Used to check for DSDT corruption */ 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_table_header *, acpi_gbl_DSDT); 26*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_table_header, acpi_gbl_original_dsdt_header); 27*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u32, acpi_gbl_dsdt_index, ACPI_INVALID_TABLE_INDEX); 28*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u32, acpi_gbl_facs_index, ACPI_INVALID_TABLE_INDEX); 29*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u32, acpi_gbl_xfacs_index, ACPI_INVALID_TABLE_INDEX); 30*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u32, acpi_gbl_fadt_index, ACPI_INVALID_TABLE_INDEX); 31*4882a593Smuzhiyun 32*4882a593Smuzhiyun #if (!ACPI_REDUCED_HARDWARE) 33*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_table_facs *, acpi_gbl_FACS); 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun #endif /* !ACPI_REDUCED_HARDWARE */ 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun /* These addresses are calculated from the FADT Event Block addresses */ 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_generic_address, acpi_gbl_xpm1a_status); 40*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_generic_address, acpi_gbl_xpm1a_enable); 41*4882a593Smuzhiyun 42*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_generic_address, acpi_gbl_xpm1b_status); 43*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_generic_address, acpi_gbl_xpm1b_enable); 44*4882a593Smuzhiyun 45*4882a593Smuzhiyun #ifdef ACPI_GPE_USE_LOGICAL_ADDRESSES 46*4882a593Smuzhiyun ACPI_GLOBAL(unsigned long, acpi_gbl_xgpe0_block_logical_address); 47*4882a593Smuzhiyun ACPI_GLOBAL(unsigned long, acpi_gbl_xgpe1_block_logical_address); 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun #endif /* ACPI_GPE_USE_LOGICAL_ADDRESSES */ 50*4882a593Smuzhiyun 51*4882a593Smuzhiyun /* 52*4882a593Smuzhiyun * Handle both ACPI 1.0 and ACPI 2.0+ Integer widths. The integer width is 53*4882a593Smuzhiyun * determined by the revision of the DSDT: If the DSDT revision is less than 54*4882a593Smuzhiyun * 2, use only the lower 32 bits of the internal 64-bit Integer. 55*4882a593Smuzhiyun */ 56*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_integer_bit_width); 57*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_integer_byte_width); 58*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_integer_nybble_width); 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun /***************************************************************************** 61*4882a593Smuzhiyun * 62*4882a593Smuzhiyun * Mutual exclusion within the ACPICA subsystem 63*4882a593Smuzhiyun * 64*4882a593Smuzhiyun ****************************************************************************/ 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun /* 67*4882a593Smuzhiyun * Predefined mutex objects. This array contains the 68*4882a593Smuzhiyun * actual OS mutex handles, indexed by the local ACPI_MUTEX_HANDLEs. 69*4882a593Smuzhiyun * (The table maps local handles to the real OS handles) 70*4882a593Smuzhiyun */ 71*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_mutex_info, acpi_gbl_mutex_info[ACPI_NUM_MUTEX]); 72*4882a593Smuzhiyun 73*4882a593Smuzhiyun /* 74*4882a593Smuzhiyun * Global lock mutex is an actual AML mutex object 75*4882a593Smuzhiyun * Global lock semaphore works in conjunction with the actual global lock 76*4882a593Smuzhiyun * Global lock spinlock is used for "pending" handshake 77*4882a593Smuzhiyun */ 78*4882a593Smuzhiyun ACPI_GLOBAL(union acpi_operand_object *, acpi_gbl_global_lock_mutex); 79*4882a593Smuzhiyun ACPI_GLOBAL(acpi_semaphore, acpi_gbl_global_lock_semaphore); 80*4882a593Smuzhiyun ACPI_GLOBAL(acpi_spinlock, acpi_gbl_global_lock_pending_lock); 81*4882a593Smuzhiyun ACPI_GLOBAL(u16, acpi_gbl_global_lock_handle); 82*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_global_lock_acquired); 83*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_global_lock_present); 84*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_global_lock_pending); 85*4882a593Smuzhiyun 86*4882a593Smuzhiyun /* 87*4882a593Smuzhiyun * Spinlocks are used for interfaces that can be possibly called at 88*4882a593Smuzhiyun * interrupt level 89*4882a593Smuzhiyun */ 90*4882a593Smuzhiyun ACPI_GLOBAL(acpi_spinlock, acpi_gbl_gpe_lock); /* For GPE data structs and registers */ 91*4882a593Smuzhiyun ACPI_GLOBAL(acpi_raw_spinlock, acpi_gbl_hardware_lock); /* For ACPI H/W except GPE registers */ 92*4882a593Smuzhiyun ACPI_GLOBAL(acpi_spinlock, acpi_gbl_reference_count_lock); 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun /* Mutex for _OSI support */ 95*4882a593Smuzhiyun 96*4882a593Smuzhiyun ACPI_GLOBAL(acpi_mutex, acpi_gbl_osi_mutex); 97*4882a593Smuzhiyun 98*4882a593Smuzhiyun /* Reader/Writer lock is used for namespace walk and dynamic table unload */ 99*4882a593Smuzhiyun 100*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_rw_lock, acpi_gbl_namespace_rw_lock); 101*4882a593Smuzhiyun 102*4882a593Smuzhiyun /***************************************************************************** 103*4882a593Smuzhiyun * 104*4882a593Smuzhiyun * Miscellaneous globals 105*4882a593Smuzhiyun * 106*4882a593Smuzhiyun ****************************************************************************/ 107*4882a593Smuzhiyun 108*4882a593Smuzhiyun /* Object caches */ 109*4882a593Smuzhiyun 110*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_namespace_cache); 111*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_state_cache); 112*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_ps_node_cache); 113*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_ps_node_ext_cache); 114*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_operand_cache); 115*4882a593Smuzhiyun 116*4882a593Smuzhiyun /* System */ 117*4882a593Smuzhiyun 118*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u32, acpi_gbl_startup_flags, 0); 119*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_shutdown, TRUE); 120*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_early_initialization, TRUE); 121*4882a593Smuzhiyun 122*4882a593Smuzhiyun /* Global handlers */ 123*4882a593Smuzhiyun 124*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_global_notify_handler, acpi_gbl_global_notify[2]); 125*4882a593Smuzhiyun ACPI_GLOBAL(acpi_exception_handler, acpi_gbl_exception_handler); 126*4882a593Smuzhiyun ACPI_GLOBAL(acpi_init_handler, acpi_gbl_init_handler); 127*4882a593Smuzhiyun ACPI_GLOBAL(acpi_table_handler, acpi_gbl_table_handler); 128*4882a593Smuzhiyun ACPI_GLOBAL(void *, acpi_gbl_table_handler_context); 129*4882a593Smuzhiyun ACPI_GLOBAL(acpi_interface_handler, acpi_gbl_interface_handler); 130*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_sci_handler_info *, acpi_gbl_sci_handler_list); 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun /* Owner ID support */ 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_owner_id_mask[ACPI_NUM_OWNERID_MASKS]); 135*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_last_owner_id_index); 136*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_next_owner_id_offset); 137*4882a593Smuzhiyun 138*4882a593Smuzhiyun /* Initialization sequencing */ 139*4882a593Smuzhiyun 140*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_namespace_initialized, FALSE); 141*4882a593Smuzhiyun 142*4882a593Smuzhiyun /* Miscellaneous */ 143*4882a593Smuzhiyun 144*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_original_mode); 145*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_ns_lookup_count); 146*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_ps_find_count); 147*4882a593Smuzhiyun ACPI_GLOBAL(u16, acpi_gbl_pm1_enable_register_save); 148*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_debugger_configuration); 149*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_step_to_next_call); 150*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_acpi_hardware_present); 151*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_events_initialized); 152*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_interface_info *, acpi_gbl_supported_interfaces); 153*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_address_range *, 154*4882a593Smuzhiyun acpi_gbl_address_range_list[ACPI_ADDRESS_RANGE_MAX]); 155*4882a593Smuzhiyun 156*4882a593Smuzhiyun /* Other miscellaneous, declared and initialized in utglobal */ 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun extern const char *acpi_gbl_sleep_state_names[ACPI_S_STATE_COUNT]; 159*4882a593Smuzhiyun extern const char *acpi_gbl_lowest_dstate_names[ACPI_NUM_sx_w_METHODS]; 160*4882a593Smuzhiyun extern const char *acpi_gbl_highest_dstate_names[ACPI_NUM_sx_d_METHODS]; 161*4882a593Smuzhiyun extern const char *acpi_gbl_region_types[ACPI_NUM_PREDEFINED_REGIONS]; 162*4882a593Smuzhiyun extern const char acpi_gbl_lower_hex_digits[]; 163*4882a593Smuzhiyun extern const char acpi_gbl_upper_hex_digits[]; 164*4882a593Smuzhiyun extern const struct acpi_opcode_info acpi_gbl_aml_op_info[AML_NUM_OPCODES]; 165*4882a593Smuzhiyun 166*4882a593Smuzhiyun /* Lists for tracking memory allocations (debug only) */ 167*4882a593Smuzhiyun 168*4882a593Smuzhiyun #ifdef ACPI_DBG_TRACK_ALLOCATIONS 169*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_memory_list *, acpi_gbl_global_list); 170*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_memory_list *, acpi_gbl_ns_node_list); 171*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_display_final_mem_stats); 172*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_disable_mem_tracking); 173*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_verbose_leak_dump); 174*4882a593Smuzhiyun #endif 175*4882a593Smuzhiyun 176*4882a593Smuzhiyun /***************************************************************************** 177*4882a593Smuzhiyun * 178*4882a593Smuzhiyun * ACPI Namespace 179*4882a593Smuzhiyun * 180*4882a593Smuzhiyun ****************************************************************************/ 181*4882a593Smuzhiyun 182*4882a593Smuzhiyun #define NUM_PREDEFINED_NAMES 10 183*4882a593Smuzhiyun 184*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_namespace_node, acpi_gbl_root_node_struct); 185*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_namespace_node *, acpi_gbl_root_node); 186*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_namespace_node *, acpi_gbl_fadt_gpe_device); 187*4882a593Smuzhiyun 188*4882a593Smuzhiyun extern const u8 acpi_gbl_ns_properties[ACPI_NUM_NS_TYPES]; 189*4882a593Smuzhiyun extern const struct acpi_predefined_names 190*4882a593Smuzhiyun acpi_gbl_pre_defined_names[NUM_PREDEFINED_NAMES]; 191*4882a593Smuzhiyun 192*4882a593Smuzhiyun #ifdef ACPI_DEBUG_OUTPUT 193*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_current_node_count); 194*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_current_node_size); 195*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_max_concurrent_node_count); 196*4882a593Smuzhiyun ACPI_GLOBAL(acpi_size *, acpi_gbl_entry_stack_pointer); 197*4882a593Smuzhiyun ACPI_GLOBAL(acpi_size *, acpi_gbl_lowest_stack_pointer); 198*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_deepest_nesting); 199*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u32, acpi_gbl_nesting_level, 0); 200*4882a593Smuzhiyun #endif 201*4882a593Smuzhiyun 202*4882a593Smuzhiyun /***************************************************************************** 203*4882a593Smuzhiyun * 204*4882a593Smuzhiyun * Interpreter/Parser globals 205*4882a593Smuzhiyun * 206*4882a593Smuzhiyun ****************************************************************************/ 207*4882a593Smuzhiyun 208*4882a593Smuzhiyun /* Control method single step flag */ 209*4882a593Smuzhiyun 210*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_cm_single_step); 211*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_thread_state *, acpi_gbl_current_walk_list); 212*4882a593Smuzhiyun ACPI_INIT_GLOBAL(union acpi_parse_object, *acpi_gbl_current_scope, NULL); 213*4882a593Smuzhiyun 214*4882a593Smuzhiyun /* ASL/ASL+ converter */ 215*4882a593Smuzhiyun 216*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_capture_comments, FALSE); 217*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_last_list_head, NULL); 218*4882a593Smuzhiyun 219*4882a593Smuzhiyun /***************************************************************************** 220*4882a593Smuzhiyun * 221*4882a593Smuzhiyun * Hardware globals 222*4882a593Smuzhiyun * 223*4882a593Smuzhiyun ****************************************************************************/ 224*4882a593Smuzhiyun 225*4882a593Smuzhiyun extern struct acpi_bit_register_info 226*4882a593Smuzhiyun acpi_gbl_bit_register_info[ACPI_NUM_BITREG]; 227*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_sleep_type_a); 228*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_sleep_type_b); 229*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_sleep_type_a_s0); 230*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_sleep_type_b_s0); 231*4882a593Smuzhiyun 232*4882a593Smuzhiyun /***************************************************************************** 233*4882a593Smuzhiyun * 234*4882a593Smuzhiyun * Event and GPE globals 235*4882a593Smuzhiyun * 236*4882a593Smuzhiyun ****************************************************************************/ 237*4882a593Smuzhiyun 238*4882a593Smuzhiyun #if (!ACPI_REDUCED_HARDWARE) 239*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_all_gpes_initialized); 240*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_gpe_xrupt_info *, acpi_gbl_gpe_xrupt_list_head); 241*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_gpe_block_info *, 242*4882a593Smuzhiyun acpi_gbl_gpe_fadt_blocks[ACPI_MAX_GPE_BLOCKS]); 243*4882a593Smuzhiyun ACPI_GLOBAL(acpi_gbl_event_handler, acpi_gbl_global_event_handler); 244*4882a593Smuzhiyun ACPI_GLOBAL(void *, acpi_gbl_global_event_handler_context); 245*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_fixed_event_handler, 246*4882a593Smuzhiyun acpi_gbl_fixed_event_handlers[ACPI_NUM_FIXED_EVENTS]); 247*4882a593Smuzhiyun extern struct acpi_fixed_event_info 248*4882a593Smuzhiyun acpi_gbl_fixed_event_info[ACPI_NUM_FIXED_EVENTS]; 249*4882a593Smuzhiyun #endif /* !ACPI_REDUCED_HARDWARE */ 250*4882a593Smuzhiyun 251*4882a593Smuzhiyun /***************************************************************************** 252*4882a593Smuzhiyun * 253*4882a593Smuzhiyun * Debug support 254*4882a593Smuzhiyun * 255*4882a593Smuzhiyun ****************************************************************************/ 256*4882a593Smuzhiyun 257*4882a593Smuzhiyun /* Event counters */ 258*4882a593Smuzhiyun 259*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_method_count); 260*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gpe_count); 261*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_sci_count); 262*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_fixed_event_count[ACPI_NUM_FIXED_EVENTS]); 263*4882a593Smuzhiyun 264*4882a593Smuzhiyun /* Dynamic control method tracing mechanism */ 265*4882a593Smuzhiyun 266*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_original_dbg_level); 267*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_original_dbg_layer); 268*4882a593Smuzhiyun 269*4882a593Smuzhiyun /***************************************************************************** 270*4882a593Smuzhiyun * 271*4882a593Smuzhiyun * Debugger and Disassembler 272*4882a593Smuzhiyun * 273*4882a593Smuzhiyun ****************************************************************************/ 274*4882a593Smuzhiyun 275*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_db_output_flags, ACPI_DB_CONSOLE_OUTPUT); 276*4882a593Smuzhiyun 277*4882a593Smuzhiyun #ifdef ACPI_DISASSEMBLER 278*4882a593Smuzhiyun 279*4882a593Smuzhiyun /* Do not disassemble buffers to resource descriptors */ 280*4882a593Smuzhiyun 281*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_no_resource_disassembly, FALSE); 282*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_ignore_noop_operator, FALSE); 283*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_cstyle_disassembly, TRUE); 284*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_force_aml_disassembly, FALSE); 285*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_dm_opt_verbose, TRUE); 286*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_dm_emit_external_opcodes, FALSE); 287*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_do_disassembler_optimizations, TRUE); 288*4882a593Smuzhiyun ACPI_INIT_GLOBAL(ACPI_PARSE_OBJECT_LIST, *acpi_gbl_temp_list_head, NULL); 289*4882a593Smuzhiyun 290*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_dm_opt_disasm); 291*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_dm_opt_listing); 292*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_num_external_methods); 293*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_resolved_external_methods); 294*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_external_list *, acpi_gbl_external_list); 295*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_external_file *, acpi_gbl_external_file_list); 296*4882a593Smuzhiyun #endif 297*4882a593Smuzhiyun 298*4882a593Smuzhiyun #ifdef ACPI_DEBUGGER 299*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_abort_method, FALSE); 300*4882a593Smuzhiyun ACPI_INIT_GLOBAL(acpi_thread_id, acpi_gbl_db_thread_id, ACPI_INVALID_THREAD_ID); 301*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u32, acpi_gbl_next_cmd_num, 1); 302*4882a593Smuzhiyun 303*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_db_opt_no_ini_methods); 304*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_db_opt_no_region_support); 305*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_db_output_to_file); 306*4882a593Smuzhiyun ACPI_GLOBAL(char *, acpi_gbl_db_buffer); 307*4882a593Smuzhiyun ACPI_GLOBAL(char *, acpi_gbl_db_filename); 308*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_db_debug_level); 309*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_db_console_debug_level); 310*4882a593Smuzhiyun ACPI_GLOBAL(struct acpi_namespace_node *, acpi_gbl_db_scope_node); 311*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_db_terminate_loop); 312*4882a593Smuzhiyun ACPI_GLOBAL(u8, acpi_gbl_db_threads_terminated); 313*4882a593Smuzhiyun ACPI_GLOBAL(char *, acpi_gbl_db_args[ACPI_DEBUGGER_MAX_ARGS]); 314*4882a593Smuzhiyun ACPI_GLOBAL(acpi_object_type, acpi_gbl_db_arg_types[ACPI_DEBUGGER_MAX_ARGS]); 315*4882a593Smuzhiyun 316*4882a593Smuzhiyun /* These buffers should all be the same size */ 317*4882a593Smuzhiyun 318*4882a593Smuzhiyun ACPI_GLOBAL(char, acpi_gbl_db_parsed_buf[ACPI_DB_LINE_BUFFER_SIZE]); 319*4882a593Smuzhiyun ACPI_GLOBAL(char, acpi_gbl_db_scope_buf[ACPI_DB_LINE_BUFFER_SIZE]); 320*4882a593Smuzhiyun ACPI_GLOBAL(char, acpi_gbl_db_debug_filename[ACPI_DB_LINE_BUFFER_SIZE]); 321*4882a593Smuzhiyun 322*4882a593Smuzhiyun /* Statistics globals */ 323*4882a593Smuzhiyun 324*4882a593Smuzhiyun ACPI_GLOBAL(u16, acpi_gbl_obj_type_count[ACPI_TOTAL_TYPES]); 325*4882a593Smuzhiyun ACPI_GLOBAL(u16, acpi_gbl_node_type_count[ACPI_TOTAL_TYPES]); 326*4882a593Smuzhiyun ACPI_GLOBAL(u16, acpi_gbl_obj_type_count_misc); 327*4882a593Smuzhiyun ACPI_GLOBAL(u16, acpi_gbl_node_type_count_misc); 328*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_num_nodes); 329*4882a593Smuzhiyun ACPI_GLOBAL(u32, acpi_gbl_num_objects); 330*4882a593Smuzhiyun #endif /* ACPI_DEBUGGER */ 331*4882a593Smuzhiyun 332*4882a593Smuzhiyun #if defined (ACPI_DISASSEMBLER) || defined (ACPI_ASL_COMPILER) 333*4882a593Smuzhiyun ACPI_GLOBAL(const char, *acpi_gbl_pld_panel_list[]); 334*4882a593Smuzhiyun ACPI_GLOBAL(const char, *acpi_gbl_pld_vertical_position_list[]); 335*4882a593Smuzhiyun ACPI_GLOBAL(const char, *acpi_gbl_pld_horizontal_position_list[]); 336*4882a593Smuzhiyun ACPI_GLOBAL(const char, *acpi_gbl_pld_shape_list[]); 337*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_disasm_flag, FALSE); 338*4882a593Smuzhiyun #endif 339*4882a593Smuzhiyun 340*4882a593Smuzhiyun /***************************************************************************** 341*4882a593Smuzhiyun * 342*4882a593Smuzhiyun * ACPICA application-specific globals 343*4882a593Smuzhiyun * 344*4882a593Smuzhiyun ****************************************************************************/ 345*4882a593Smuzhiyun 346*4882a593Smuzhiyun /* ASL-to-ASL+ conversion utility (implemented within the iASL compiler) */ 347*4882a593Smuzhiyun 348*4882a593Smuzhiyun #ifdef ACPI_ASL_COMPILER 349*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_current_inline_comment, NULL); 350*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_current_end_node_comment, NULL); 351*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_current_open_brace_comment, NULL); 352*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_current_close_brace_comment, NULL); 353*4882a593Smuzhiyun 354*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_root_filename, NULL); 355*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_current_filename, NULL); 356*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_current_parent_filename, NULL); 357*4882a593Smuzhiyun ACPI_INIT_GLOBAL(char *, acpi_gbl_current_include_filename, NULL); 358*4882a593Smuzhiyun 359*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_def_blk_comment_list_head, 360*4882a593Smuzhiyun NULL); 361*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_def_blk_comment_list_tail, 362*4882a593Smuzhiyun NULL); 363*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_reg_comment_list_head, 364*4882a593Smuzhiyun NULL); 365*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_reg_comment_list_tail, 366*4882a593Smuzhiyun NULL); 367*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_inc_comment_list_head, 368*4882a593Smuzhiyun NULL); 369*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_inc_comment_list_tail, 370*4882a593Smuzhiyun NULL); 371*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_end_blk_comment_list_head, 372*4882a593Smuzhiyun NULL); 373*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_node, *acpi_gbl_end_blk_comment_list_tail, 374*4882a593Smuzhiyun NULL); 375*4882a593Smuzhiyun 376*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_comment_addr_node, 377*4882a593Smuzhiyun *acpi_gbl_comment_addr_list_head, NULL); 378*4882a593Smuzhiyun ACPI_INIT_GLOBAL(struct acpi_file_node, *acpi_gbl_file_tree_root, NULL); 379*4882a593Smuzhiyun 380*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_reg_comment_cache); 381*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_comment_addr_cache); 382*4882a593Smuzhiyun ACPI_GLOBAL(acpi_cache_t *, acpi_gbl_file_cache); 383*4882a593Smuzhiyun 384*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_debug_asl_conversion, FALSE); 385*4882a593Smuzhiyun ACPI_INIT_GLOBAL(ACPI_FILE, acpi_gbl_conv_debug_file, NULL); 386*4882a593Smuzhiyun ACPI_GLOBAL(char, acpi_gbl_table_sig[4]); 387*4882a593Smuzhiyun #endif 388*4882a593Smuzhiyun 389*4882a593Smuzhiyun #ifdef ACPI_APPLICATION 390*4882a593Smuzhiyun ACPI_INIT_GLOBAL(ACPI_FILE, acpi_gbl_debug_file, NULL); 391*4882a593Smuzhiyun ACPI_INIT_GLOBAL(ACPI_FILE, acpi_gbl_output_file, NULL); 392*4882a593Smuzhiyun ACPI_INIT_GLOBAL(u8, acpi_gbl_debug_timeout, FALSE); 393*4882a593Smuzhiyun 394*4882a593Smuzhiyun /* Print buffer */ 395*4882a593Smuzhiyun 396*4882a593Smuzhiyun ACPI_GLOBAL(acpi_spinlock, acpi_gbl_print_lock); /* For print buffer */ 397*4882a593Smuzhiyun ACPI_GLOBAL(char, acpi_gbl_print_buffer[1024]); 398*4882a593Smuzhiyun #endif /* ACPI_APPLICATION */ 399*4882a593Smuzhiyun 400*4882a593Smuzhiyun #endif /* __ACGLOBAL_H__ */ 401