use_def_analysis
This modules computes def-uses chains for a subset of the registers (defined in track_register). and only if those chains are related eventually to an access to memory.
-‘def’ computes definitions of registers at each of the locations.
- -‘def_used_for_address’ compute the set of live uses backwards at each of the locations.
However, it only computes uses starting at accesses to memory.
-‘def_used’ intersects the two previous facts to obtain def-use chains.
The traversal of def_used_for_address is kept intra-procedural (not following call edges).
- local_next(ea:address, ea_next:address)
WARNING: Predicate not present in compiled Datalog program (Dead Code)
- block_instruction_next(Block:address, Before:address, After:address)
next() for each instruction within a block.
Uses:
nextRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- inter_procedural_edge(Src:address, Dest:address)
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- block_next(Block:address, BlockEnd:address, NextBlock:address)
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- call_uses_reg(Call:address, Reg:register)
‘Call’ implicitly uses ‘Reg’, such as register parameters.
WARNING: Predicate not present in compiled Datalog program (Dead Code)
- flow_def(EA:address, Var:T, EA_next:address, Value:number)
A <T> is implicitly defined by being compared to a constant and then jumping this definition only takes place in between the jump and the target that implies equality
Uses:
arch.conditional,arch.jump,cmp_immediate_to_reg,direct_jump,next,track_registerRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- ea_propagates_def(EA:address, Var:T)
A Var <T> can propagate through the instruction at EA.
Intended to be extended by child components to modify behavior of AdvancedDefUsed.
WARNING: Predicate not present in compiled Datalog program (Dead Code)
- block_propagates_def(Block:address, Var:T)
A Var <T> can propagate through Block.
WARNING: Predicate not present in compiled Datalog program (Dead Code)
- defined_in_block(Block:address, Var:T)
A Var <T> is defined in the Block
Uses:
reg_def_use.def,stack_def_use.defRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- used_in_block(Block:address, EA_used:address, Var:T, Index:operand_index)
A Var <T> is used in the Block
Uses:
stack_def_use.usedRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- block_last_def(EA:address, EA_def:address, Var:T)
The last address prior to EA where Var was defined within the block
Multiple are possible in conditional cases.
Uses:
arch.conditional,arch.conditional,reg_def_use.def,reg_def_use.def,stack_def_use.defRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- ambiguous_block_last_def(EA:address, Var:T)
Indicates at EA, Var has multiple possible last definitions in the block due to conditional def(s).
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- last_def_in_block(Block:address, EA_def:address, Var:T)
The last definition(s) of <T> in a given block.
Multiple are possible in conditional cases.
Uses:
arch.conditional,arch.conditional,reg_def_use.def,reg_def_use.def,stack_def_use.defRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- ambiguous_last_def_in_block(Block:address, Var:T)
Indicates at the end of Block, Var has multiple possible last definitions in the block due to conditional def(s).
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- ref_in_block(Block:address, Var:T)
A <T> is referenced in a block
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- live_var_def(Block:address, VarIdentity:T, LiveVar:T, EA_def:address)
A <T> is defined in a block, and is still live at the end of the block.
This can potentially be paired with a live_var_used if there is a path between the Blocks.
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- live_var_used(Block:address, LiveVar:T, UsedVar:T, EA_used:address, Index:operand_index, Moves:unsigned)
A <T> is used in a block, but a live definition for that use is not found within the block.
We consider a <T> to be live only if it is live for interblock edges. Intrablock cases are handled directly by the def_used relation.
To find the definition for this use, live_var_at_block_end will have to propagate backward from the block.
The
Movesfield, used only by stack var tracking, tracks the number of basic blocks that perform a stack variable transformation (where a stack variable descriptor is adjusted due to a change in the stack pointer). This prevents infinite loops.Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- live_var_at_block_end(Block:address, BlockUsed:address, Var:T)
The <T> is live at the end of Block, and will be used in BlockUsed.
Propagates backward from usages to search for defs.
This is faster than propagating forward from defs, since a used value should always be defined in well-behaved code. In addition, we know to stop propagating once the definition is found.
The alternative strategy of propagating forward from defs means that it must propagate indefinitely, in case it is used multiple times. Further, side-effect definitions are often unused.
To further optimize this strategy, if another use is encountered, we don’t propagate any further. Later, the relation live_var_at_prior_used() propagates defs forward through adjacent uses.
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- live_var_at_prior_used(EA_used:address, BlockUsed:address, Var:T)
The <T> is live at EA_used and at the beginning of BlockUsed, and holds the same value from the same definition. The <T> is used in BlockUsed.
Forms an edge between two used() that depend on the same def.
Recursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- return_val_used(EA_call:address, Callee:address, Reg:register, EA_used:address, Index_used:operand_index)
A value returned from a function is used.
Uses:
arch.return_reg,direct_callRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- return_block_end(Callee:address, CalleeEnd:address, Block:address, BlockEnd:address)
A value is returned from a called procedure Callee, from the last Block with the last instruction at BlockEnd.
Uses:
arch.return,direct_call,fde_addressesRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- def_used(EA_def:address, Var:register, EA_used:address, Index_used:operand_index)
A <T> is defined in ‘EA_def’ and used in ‘EA_used’ in the operand with index ‘Index_used’
Used by:
base_addr_load,base_addr_offset_operand_point,boundary_sym_expr,def_register_is_not_base_address,dest_enlarged_data_section,inferred_main_function,local_exec_tls_candidate,missed_jump_table,moved_immediate_candidate,moved_label_candidate,moved_label_class,moved_pc_relative_candidate,resolved_transfer,resolved_transfer_to_symbol,symbol_minus_symbol,symbolic_operand_attribute,symbolic_operand_candidate,symbolic_operand_point,tls_pointer_reg_at,tls_relative_operand,value_reg_address_before,value_reg_at_operand,value_reg_at_operand_loop,base_addr_load,moved_label_candidate,moved_label_classRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- adjusts_stack_in_block(Block:address, EA:address, BaseReg:register, Offset:number)
An offset is added to a stack pointer register at EA.
Uses:
arch.frame_pointer,arch.reg_arithmetic_operation,arch.stack_pointerRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- stack_base_reg_move(Block:address, EA:address, Src:register, Dst:register)
A stack base register is moved to another potential stack base register.
Uses:
arch.frame_pointer,arch.move_reg_reg,arch.stack_pointerRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- def_used(EA_def:address, VarDef:stack_var, EA_used:address, VarUsed:stack_var, Index_used:operand_index)
A stack is defined in ‘EA_def’ and used in ‘EA_used’ in the operand with index ‘Index_used’
Used by:
base_addr_load,base_addr_offset_operand_point,boundary_sym_expr,def_register_is_not_base_address,dest_enlarged_data_section,inferred_main_function,local_exec_tls_candidate,missed_jump_table,moved_immediate_candidate,moved_label_candidate,moved_label_class,moved_pc_relative_candidate,resolved_transfer,resolved_transfer_to_symbol,symbol_minus_symbol,symbolic_operand_attribute,symbolic_operand_candidate,symbolic_operand_point,tls_pointer_reg_at,tls_relative_operand,value_reg_address_before,value_reg_at_operand,value_reg_at_operand_loop,base_addr_load,moved_label_candidate,moved_label_classRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- live_var_used_in_block(Block:address, EA:address, LiveVar:stack_var, UsedVar:stack_var, EA_used:address, Index:operand_index, Moves:unsigned)
Propagate live uses backwards within a block on a per-instruction basis.
Uses:
arch.stack_pointer,next,reg_def_use.def,stack_def_use.def,stack_def_use.moves_limitRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- moves_limit(Moves:unsigned)
Specify the number of moves of the stack register (the stack pointer or the frame pointer) that are tracked in the def-use stack analysis. This parameters is used to ensure rapid convergence
Used by:
stack_def_use.live_var_used_in_block
- reg_used_for(EA:address, Reg:register, Type:symbol)
The register ‘Reg’ used as an address at address ‘EA’.
Uses:
instruction_get_op,op_indirect_contains_reg,reg_call,reg_jumpRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end
- def_used_for_address(EA_def:address, Reg:register, Type:symbol)
The register ‘Reg’ as defined at address ‘EA_def’ is later used either as an address
or to compute an address.
Uses:
arch.adr_dest,arch.memory_access,arch.pc_relative_addrUsed by:
moved_label_candidate,symbolic_operand_attribute,symbolic_operand_candidate,symbolic_operand_pointRecursive:
block_candidate_boundaries,jump_table_start,candidate_block_is_not_padding,reg_def_use.used_in_block,tls_get_addr,block,inter_procedural_edge,next_end,arch.extend_load,value_reg_unsupported,block_implies_block,last_value_reg_limit,init_symbol_minus_symbol_candidate_arm,block_points_proportional,wis_memo,indefinite_litpool_ref,cmp_defines,arm_jump_table_data_block,reg_def_use.return_block_end,data_access,__agg_subclause6,resolved_reaches,split_load_candidate,possible_target,arm_jump_table_block_instruction,incomplete_block,__agg_subclause7,must_fallthrough,indexed_pc_relative_load,stack_def_use.live_var_at_block_end,overlapping_instruction,gp_relative_operand,invalid,arm_jump_table_data_block_limit,arm_jump_table_cmp_limit,inferred_main_in_reg,reg_def_use.flow_def,arm_jump_table_block_start,wis_schedule,invalid_jump_table_candidate,straight_line_def_used,next_start,wis_has_prior,known_block,jump_table_target,flags_and_jump_pair,block_limit,block_candidate_dependency_edge,jump_table_candidate,split_load_for_symbolization,reg_def_use.def_used,block_next,no_return_call_refined,reg_reg_arithmetic_operation_defs,block_last_instruction,next_block_in_byte_interval,reg_def_use.ambiguous_last_def_in_block,arm_jump_table_skip_first_entry,straight_line_last_def,compare_and_jump_indirect,litpool_ref,relocation_adjustment_total,__agg_subclause3,data_in_code,may_fallthrough,reg_used_for,adrp_used,impossible_block,start_function,wis_prior,reg_def_use.defined_in_block,def_used_for_address,contains_implausible_instr_seq,reg_def_use.block_last_def,reg_def_use.last_def_in_block,stack_def_use.live_var_at_prior_used,data_block_limit,compare_and_jump_indirect_op_valid,simple_data_access_pattern,stack_def_use.live_var_def,tls_relative_operand_mips,segment_target_range,unresolved_block_overlap,__agg_single3,split_load_conflict,nop_in_padding_candidate,plt_block,code_in_block_candidate_refined,data_in_code_propagate,stack_def_use.live_var_used_in_block,block_total_points,reg_has_base_image,arm_jump_table_candidate,initialized_data_segment,possible_target_from,padding_block_limit,after_end,arm_jump_table_candidate_start,code_in_block,stack_base_reg_move,compare_and_jump_immediate,adjusts_stack_in_block,reg_def_use.ref_in_block,overlap_with_litpool,relocation_adjustment,split_load_total_points,reg_def_use.ambiguous_block_last_def,composite_data_access,litpool_boundaries,jump_table_candidate_refined,const_value_reg_used,relative_address_start,inferred_main_dispatch,call_tls_get_addr_mips,no_return_block,value_reg_edge,candidate_block_is_padding,__agg_single2,no_return_call,__agg_subclause4,compare_and_jump_register,jump_table_signed,reg_def_use.live_var_def,block_heuristic,no_return_call_propagated,arch.reg_relative_load,base_relative_operand,got_relative_operand,block_points,call_tls_get_addr,block_boundaries,split_load_point,is_padding,block_overlap,function_inference.function_entry_initial,next_type,common_tail,padding_block_candidate,stack_def_use.last_def_in_block,litpool_symbolic_operand,data_segment,stack_def_use.block_last_def,instruction_memory_access_size,litpool_confidence,init_ldr_add_pc,plt_entry,hi_load_prop,stack_def_use.defined_in_block,basic_target,__agg_subclause2,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,unresolved_interval,unresolved_interval_order,split_load,symbol_minus_symbol_litpool_access_pattern,negative_block_heuristic,jump_table_element_access,first_block_in_byte_interval,self_contained_segment,cinf_ldr_add_pc,jump_table_prelude,wis_schedule_iter,transition_block_limit,tls_desc_call,jump_table_max,correlated_live_reg,branch_to_calculated_pc_rel_addr,__agg_single10,no_value_reg_limit,data_block_candidate,__agg_single6,block_instruction_next,split_load_operand,stack_def_use.live_var_used,base_relative_operation,discarded_block,contains_plausible_instr_seq,code_in_block_candidate,reg_def_use.return_val_used,arch.simple_data_load,value_reg,stack_def_use.used_in_block,indexed_pc_relative_load_relative,stack_def_use.def_used,relative_address,cmp_reg_to_reg,discarded_split_load,reg_has_got,reg_def_use.live_var_at_prior_used,value_reg_limit,local_dynamic_tls_candidate,stack_def_use.ref_in_block,reg_def_use.live_var_used,relative_jump_table_entry_candidate,reg_def_use.used,likely_fallthrough,unresolved_block,base_relative_jump,reg_def_use.live_var_at_block_end