1*4882a593Smuzhiyun /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */ 2*4882a593Smuzhiyun /****************************************************************************** 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Name: acstruct.h - Internal structs 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * Copyright (C) 2000 - 2020, Intel Corp. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun *****************************************************************************/ 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #ifndef __ACSTRUCT_H__ 11*4882a593Smuzhiyun #define __ACSTRUCT_H__ 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun /* acpisrc:struct_defs -- for acpisrc conversion */ 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun /***************************************************************************** 16*4882a593Smuzhiyun * 17*4882a593Smuzhiyun * Tree walking typedefs and structs 18*4882a593Smuzhiyun * 19*4882a593Smuzhiyun ****************************************************************************/ 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun /* 22*4882a593Smuzhiyun * Walk state - current state of a parse tree walk. Used for both a leisurely 23*4882a593Smuzhiyun * stroll through the tree (for whatever reason), and for control method 24*4882a593Smuzhiyun * execution. 25*4882a593Smuzhiyun */ 26*4882a593Smuzhiyun #define ACPI_NEXT_OP_DOWNWARD 1 27*4882a593Smuzhiyun #define ACPI_NEXT_OP_UPWARD 2 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun /* 30*4882a593Smuzhiyun * Groups of definitions for walk_type used for different implementations of 31*4882a593Smuzhiyun * walkers (never simultaneously) - flags for interpreter: 32*4882a593Smuzhiyun */ 33*4882a593Smuzhiyun #define ACPI_WALK_NON_METHOD 0 34*4882a593Smuzhiyun #define ACPI_WALK_METHOD 0x01 35*4882a593Smuzhiyun #define ACPI_WALK_METHOD_RESTART 0x02 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun struct acpi_walk_state { 38*4882a593Smuzhiyun struct acpi_walk_state *next; /* Next walk_state in list */ 39*4882a593Smuzhiyun u8 descriptor_type; /* To differentiate various internal objs */ 40*4882a593Smuzhiyun u8 walk_type; 41*4882a593Smuzhiyun u16 opcode; /* Current AML opcode */ 42*4882a593Smuzhiyun u8 next_op_info; /* Info about next_op */ 43*4882a593Smuzhiyun u8 num_operands; /* Stack pointer for Operands[] array */ 44*4882a593Smuzhiyun u8 operand_index; /* Index into operand stack, to be used by acpi_ds_obj_stack_push */ 45*4882a593Smuzhiyun acpi_owner_id owner_id; /* Owner of objects created during the walk */ 46*4882a593Smuzhiyun u8 last_predicate; /* Result of last predicate */ 47*4882a593Smuzhiyun u8 current_result; 48*4882a593Smuzhiyun u8 return_used; 49*4882a593Smuzhiyun u8 scope_depth; 50*4882a593Smuzhiyun u8 pass_number; /* Parse pass during table load */ 51*4882a593Smuzhiyun u8 namespace_override; /* Override existing objects */ 52*4882a593Smuzhiyun u8 result_size; /* Total elements for the result stack */ 53*4882a593Smuzhiyun u8 result_count; /* Current number of occupied elements of result stack */ 54*4882a593Smuzhiyun u8 *aml; 55*4882a593Smuzhiyun u32 arg_types; 56*4882a593Smuzhiyun u32 method_breakpoint; /* For single stepping */ 57*4882a593Smuzhiyun u32 user_breakpoint; /* User AML breakpoint */ 58*4882a593Smuzhiyun u32 parse_flags; 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun struct acpi_parse_state parser_state; /* Current state of parser */ 61*4882a593Smuzhiyun u32 prev_arg_types; 62*4882a593Smuzhiyun u32 arg_count; /* push for fixed or var args */ 63*4882a593Smuzhiyun u16 method_nesting_depth; 64*4882a593Smuzhiyun u8 method_is_nested; 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun struct acpi_namespace_node arguments[ACPI_METHOD_NUM_ARGS]; /* Control method arguments */ 67*4882a593Smuzhiyun struct acpi_namespace_node local_variables[ACPI_METHOD_NUM_LOCALS]; /* Control method locals */ 68*4882a593Smuzhiyun union acpi_operand_object *operands[ACPI_OBJ_NUM_OPERANDS + 1]; /* Operands passed to the interpreter (+1 for NULL terminator) */ 69*4882a593Smuzhiyun union acpi_operand_object **params; 70*4882a593Smuzhiyun 71*4882a593Smuzhiyun u8 *aml_last_while; 72*4882a593Smuzhiyun union acpi_operand_object **caller_return_desc; 73*4882a593Smuzhiyun union acpi_generic_state *control_state; /* List of control states (nested IFs) */ 74*4882a593Smuzhiyun struct acpi_namespace_node *deferred_node; /* Used when executing deferred opcodes */ 75*4882a593Smuzhiyun union acpi_operand_object *implicit_return_obj; 76*4882a593Smuzhiyun struct acpi_namespace_node *method_call_node; /* Called method Node */ 77*4882a593Smuzhiyun union acpi_parse_object *method_call_op; /* method_call Op if running a method */ 78*4882a593Smuzhiyun union acpi_operand_object *method_desc; /* Method descriptor if running a method */ 79*4882a593Smuzhiyun struct acpi_namespace_node *method_node; /* Method node if running a method */ 80*4882a593Smuzhiyun char *method_pathname; /* Full pathname of running method */ 81*4882a593Smuzhiyun union acpi_parse_object *op; /* Current parser op */ 82*4882a593Smuzhiyun const struct acpi_opcode_info *op_info; /* Info on current opcode */ 83*4882a593Smuzhiyun union acpi_parse_object *origin; /* Start of walk [Obsolete] */ 84*4882a593Smuzhiyun union acpi_operand_object *result_obj; 85*4882a593Smuzhiyun union acpi_generic_state *results; /* Stack of accumulated results */ 86*4882a593Smuzhiyun union acpi_operand_object *return_desc; /* Return object, if any */ 87*4882a593Smuzhiyun union acpi_generic_state *scope_info; /* Stack of nested scopes */ 88*4882a593Smuzhiyun union acpi_parse_object *prev_op; /* Last op that was processed */ 89*4882a593Smuzhiyun union acpi_parse_object *next_op; /* next op to be processed */ 90*4882a593Smuzhiyun struct acpi_thread_state *thread; 91*4882a593Smuzhiyun acpi_parse_downwards descending_callback; 92*4882a593Smuzhiyun acpi_parse_upwards ascending_callback; 93*4882a593Smuzhiyun }; 94*4882a593Smuzhiyun 95*4882a593Smuzhiyun /* Info used by acpi_ns_initialize_objects and acpi_ds_initialize_objects */ 96*4882a593Smuzhiyun 97*4882a593Smuzhiyun struct acpi_init_walk_info { 98*4882a593Smuzhiyun u32 table_index; 99*4882a593Smuzhiyun u32 object_count; 100*4882a593Smuzhiyun u32 method_count; 101*4882a593Smuzhiyun u32 serial_method_count; 102*4882a593Smuzhiyun u32 non_serial_method_count; 103*4882a593Smuzhiyun u32 serialized_method_count; 104*4882a593Smuzhiyun u32 device_count; 105*4882a593Smuzhiyun u32 op_region_count; 106*4882a593Smuzhiyun u32 field_count; 107*4882a593Smuzhiyun u32 buffer_count; 108*4882a593Smuzhiyun u32 package_count; 109*4882a593Smuzhiyun u32 op_region_init; 110*4882a593Smuzhiyun u32 field_init; 111*4882a593Smuzhiyun u32 buffer_init; 112*4882a593Smuzhiyun u32 package_init; 113*4882a593Smuzhiyun acpi_owner_id owner_id; 114*4882a593Smuzhiyun }; 115*4882a593Smuzhiyun 116*4882a593Smuzhiyun struct acpi_get_devices_info { 117*4882a593Smuzhiyun acpi_walk_callback user_function; 118*4882a593Smuzhiyun void *context; 119*4882a593Smuzhiyun const char *hid; 120*4882a593Smuzhiyun }; 121*4882a593Smuzhiyun 122*4882a593Smuzhiyun union acpi_aml_operands { 123*4882a593Smuzhiyun union acpi_operand_object *operands[7]; 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun struct { 126*4882a593Smuzhiyun struct acpi_object_integer *type; 127*4882a593Smuzhiyun struct acpi_object_integer *code; 128*4882a593Smuzhiyun struct acpi_object_integer *argument; 129*4882a593Smuzhiyun 130*4882a593Smuzhiyun } fatal; 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun struct { 133*4882a593Smuzhiyun union acpi_operand_object *source; 134*4882a593Smuzhiyun struct acpi_object_integer *index; 135*4882a593Smuzhiyun union acpi_operand_object *target; 136*4882a593Smuzhiyun 137*4882a593Smuzhiyun } index; 138*4882a593Smuzhiyun 139*4882a593Smuzhiyun struct { 140*4882a593Smuzhiyun union acpi_operand_object *source; 141*4882a593Smuzhiyun struct acpi_object_integer *index; 142*4882a593Smuzhiyun struct acpi_object_integer *length; 143*4882a593Smuzhiyun union acpi_operand_object *target; 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun } mid; 146*4882a593Smuzhiyun }; 147*4882a593Smuzhiyun 148*4882a593Smuzhiyun /* 149*4882a593Smuzhiyun * Structure used to pass object evaluation information and parameters. 150*4882a593Smuzhiyun * Purpose is to reduce CPU stack use. 151*4882a593Smuzhiyun */ 152*4882a593Smuzhiyun struct acpi_evaluate_info { 153*4882a593Smuzhiyun /* The first 3 elements are passed by the caller to acpi_ns_evaluate */ 154*4882a593Smuzhiyun 155*4882a593Smuzhiyun struct acpi_namespace_node *prefix_node; /* Input: starting node */ 156*4882a593Smuzhiyun const char *relative_pathname; /* Input: path relative to prefix_node */ 157*4882a593Smuzhiyun union acpi_operand_object **parameters; /* Input: argument list */ 158*4882a593Smuzhiyun 159*4882a593Smuzhiyun struct acpi_namespace_node *node; /* Resolved node (prefix_node:relative_pathname) */ 160*4882a593Smuzhiyun union acpi_operand_object *obj_desc; /* Object attached to the resolved node */ 161*4882a593Smuzhiyun char *full_pathname; /* Full pathname of the resolved node */ 162*4882a593Smuzhiyun 163*4882a593Smuzhiyun const union acpi_predefined_info *predefined; /* Used if Node is a predefined name */ 164*4882a593Smuzhiyun union acpi_operand_object *return_object; /* Object returned from the evaluation */ 165*4882a593Smuzhiyun union acpi_operand_object *parent_package; /* Used if return object is a Package */ 166*4882a593Smuzhiyun 167*4882a593Smuzhiyun u32 return_flags; /* Used for return value analysis */ 168*4882a593Smuzhiyun u32 return_btype; /* Bitmapped type of the returned object */ 169*4882a593Smuzhiyun u16 param_count; /* Count of the input argument list */ 170*4882a593Smuzhiyun u16 node_flags; /* Same as Node->Flags */ 171*4882a593Smuzhiyun u8 pass_number; /* Parser pass number */ 172*4882a593Smuzhiyun u8 return_object_type; /* Object type of the returned object */ 173*4882a593Smuzhiyun u8 flags; /* General flags */ 174*4882a593Smuzhiyun }; 175*4882a593Smuzhiyun 176*4882a593Smuzhiyun /* Values for Flags above */ 177*4882a593Smuzhiyun 178*4882a593Smuzhiyun #define ACPI_IGNORE_RETURN_VALUE 1 179*4882a593Smuzhiyun 180*4882a593Smuzhiyun /* Defines for return_flags field above */ 181*4882a593Smuzhiyun 182*4882a593Smuzhiyun #define ACPI_OBJECT_REPAIRED 1 183*4882a593Smuzhiyun #define ACPI_OBJECT_WRAPPED 2 184*4882a593Smuzhiyun 185*4882a593Smuzhiyun /* Info used by acpi_ns_initialize_devices */ 186*4882a593Smuzhiyun 187*4882a593Smuzhiyun struct acpi_device_walk_info { 188*4882a593Smuzhiyun struct acpi_table_desc *table_desc; 189*4882a593Smuzhiyun struct acpi_evaluate_info *evaluate_info; 190*4882a593Smuzhiyun u32 device_count; 191*4882a593Smuzhiyun u32 num_STA; 192*4882a593Smuzhiyun u32 num_INI; 193*4882a593Smuzhiyun }; 194*4882a593Smuzhiyun 195*4882a593Smuzhiyun /* Info used by Acpi acpi_db_display_fields */ 196*4882a593Smuzhiyun 197*4882a593Smuzhiyun struct acpi_region_walk_info { 198*4882a593Smuzhiyun u32 debug_level; 199*4882a593Smuzhiyun u32 count; 200*4882a593Smuzhiyun acpi_owner_id owner_id; 201*4882a593Smuzhiyun u8 display_type; 202*4882a593Smuzhiyun u32 address_space_id; 203*4882a593Smuzhiyun }; 204*4882a593Smuzhiyun 205*4882a593Smuzhiyun /* TBD: [Restructure] Merge with struct above */ 206*4882a593Smuzhiyun 207*4882a593Smuzhiyun struct acpi_walk_info { 208*4882a593Smuzhiyun u32 debug_level; 209*4882a593Smuzhiyun u32 count; 210*4882a593Smuzhiyun acpi_owner_id owner_id; 211*4882a593Smuzhiyun u8 display_type; 212*4882a593Smuzhiyun }; 213*4882a593Smuzhiyun 214*4882a593Smuzhiyun /* Display Types */ 215*4882a593Smuzhiyun 216*4882a593Smuzhiyun #define ACPI_DISPLAY_SUMMARY (u8) 0 217*4882a593Smuzhiyun #define ACPI_DISPLAY_OBJECTS (u8) 1 218*4882a593Smuzhiyun #define ACPI_DISPLAY_MASK (u8) 1 219*4882a593Smuzhiyun 220*4882a593Smuzhiyun #define ACPI_DISPLAY_SHORT (u8) 2 221*4882a593Smuzhiyun 222*4882a593Smuzhiyun #endif 223