binary/elf/symbolization
ELF-specific rules and relations for symbolization
- elf_relocation_size(ISA:symbol, Type:symbol, Size:unsigned)
Table maps ELF relocation types to a size in bits.
- reg_has_got(EA:address, Reg:register)
Value of register ‘Reg’ at address ‘EA’ is a GOT-relative base reference.
Uses:
got_section,loaded_sectionUsed by:
symbol_minus_symbol,symbolic_expr,symbolic_operand_attributeRecursive:
arm_jump_table_cmp_limit,value_reg_unsupported,value_reg,candidate_block_is_not_padding,gp_relative_operand,split_load_total_points,stack_def_use.def_used,indexed_pc_relative_load,branch_to_calculated_pc_rel_addr,code_in_block,jump_table_element_access,compare_and_jump_register,jump_table_candidate,invalid,block_candidate_boundaries,data_in_code_propagate,relocation_adjustment_total,arch.simple_data_load,local_dynamic_tls_candidate,block_limit,block_instruction_next,reg_def_use.used,wis_memo,stack_def_use.live_var_used_in_block,wis_has_prior,arm_jump_table_skip_first_entry,wis_schedule,flags_and_jump_pair,litpool_symbolic_operand,segment_target_range,inferred_main_in_reg,code_in_block_candidate_refined,unresolved_interval,code_in_block_candidate,reg_def_use.return_val_used,start_function,correlated_live_reg,indexed_pc_relative_load_relative,arm_jump_table_block_start,arch.reg_relative_load,arm_jump_table_data_block,next_block_in_byte_interval,impossible_block,reg_def_use.ambiguous_last_def_in_block,reg_def_use.live_var_at_prior_used,data_block_candidate,invalid_jump_table_candidate,compare_and_jump_indirect,reg_def_use.flow_def,arm_jump_table_data_block_limit,stack_base_reg_move,__agg_single3,base_relative_jump,arm_jump_table_block_instruction,__agg_subclause2,no_value_reg_limit,overlap_with_litpool,split_load_candidate,__agg_subclause4,padding_block_candidate,inferred_main_dispatch,relocation_adjustment,tls_get_addr,after_end,stack_def_use.defined_in_block,reg_def_use.used_in_block,stack_def_use.last_def_in_block,candidate_block_is_padding,plt_entry,jump_table_max,reg_def_use.live_var_at_block_end,initialized_data_segment,tls_relative_operand_mips,relative_address,litpool_ref,arm_jump_table_candidate_start,must_fallthrough,may_fallthrough,contains_implausible_instr_seq,__agg_subclause6,no_return_call_refined,block_points_proportional,no_return_block,cinf_ldr_add_pc,relative_address_start,adjusts_stack_in_block,resolved_reaches,block_total_points,next_end,possible_target_from,block_candidate_dependency_edge,block,self_contained_segment,block_next,reg_def_use.live_var_def,jump_table_signed,reg_has_got,no_return_call_propagated,wis_prior,split_load_conflict,jump_table_start,wis_schedule_iter,reg_def_use.ambiguous_block_last_def,jump_table_prelude,first_block_in_byte_interval,arch.extend_load,base_relative_operation,indefinite_litpool_ref,compare_and_jump_immediate,unresolved_block_overlap,split_load,stack_def_use.used_in_block,reg_reg_arithmetic_operation_defs,padding_block_limit,reg_def_use.def_used,tls_desc_call,litpool_boundaries,discarded_block,stack_def_use.live_var_def,base_relative_operand,data_in_code,plt_block,reg_used_for,overlapping_instruction,reg_has_base_image,cmp_defines,nop_in_padding_candidate,compare_and_jump_indirect_op_valid,data_block_limit,__agg_subclause7,block_implies_block,const_value_reg_used,reg_def_use.return_block_end,next_type,__agg_single10,adrp_used,symbol_minus_symbol_litpool_access_pattern,contains_plausible_instr_seq,got_relative_operand,jump_table_candidate_refined,stack_def_use.live_var_at_prior_used,possible_target,instruction_memory_access_size,block_points,basic_target,split_load_operand,incomplete_block,transition_block_limit,data_access,litpool_confidence,block_overlap,arm_jump_table_candidate,reg_def_use.block_last_def,reg_def_use.last_def_in_block,is_padding,simple_data_access_pattern,reg_def_use.live_var_used,straight_line_last_def,__agg_single2,inter_procedural_edge,init_symbol_minus_symbol_candidate_arm,function_inference.function_entry_initial,block_heuristic,hi_load_prop,unresolved_interval_order,symbolic_expr_from_relocation,discarded_split_load,likely_fallthrough,block_boundaries,call_tls_get_addr_mips,stack_def_use.block_last_def,__agg_single6,stack_def_use.live_var_at_block_end,split_load_point,cmp_reg_to_reg,unlikely_have_symbolic_immediate,reg_def_use.defined_in_block,jump_table_target,no_return_call,split_load_for_symbolization,call_tls_get_addr,__agg_subclause3,next_start,stack_def_use.ref_in_block,straight_line_def_used,def_used_for_address,init_ldr_add_pc,last_value_reg_limit,value_reg_edge,data_segment,common_tail,reg_def_use.ref_in_block,known_block,negative_block_heuristic,relative_jump_table_entry_candidate,stack_def_use.live_var_used,unresolved_block,block_last_instruction,value_reg_limit,composite_data_access
- got_reference_pointer(EA:address)
Address ‘EA’ is used as a GOT-relative base reference. ‘EA’ is the beginning of either the .got or .got.plt section.
- got_relative_operand(EA:address, Index:operand_index, Dest:address)
Operand instruction at ‘EA’ at index ‘Index’ is a GOT-relative reference to an address ‘Dest’.
Uses:
arch.reg_reg_arithmetic_operation,got_reference_pointer,instruction_displacement_offset,instruction_get_op,op_immediate_and_reg,op_indirect_mapped,relocation,symbolUsed by:
moved_label_candidate,moved_label_class,symbolic_operand_attribute,symbolic_operand_candidate,tls_global_dynamicRecursive:
arm_jump_table_cmp_limit,value_reg_unsupported,value_reg,candidate_block_is_not_padding,gp_relative_operand,split_load_total_points,stack_def_use.def_used,indexed_pc_relative_load,branch_to_calculated_pc_rel_addr,code_in_block,jump_table_element_access,compare_and_jump_register,jump_table_candidate,invalid,block_candidate_boundaries,data_in_code_propagate,relocation_adjustment_total,arch.simple_data_load,local_dynamic_tls_candidate,block_limit,block_instruction_next,reg_def_use.used,wis_memo,stack_def_use.live_var_used_in_block,wis_has_prior,arm_jump_table_skip_first_entry,wis_schedule,flags_and_jump_pair,litpool_symbolic_operand,segment_target_range,inferred_main_in_reg,code_in_block_candidate_refined,unresolved_interval,code_in_block_candidate,reg_def_use.return_val_used,start_function,correlated_live_reg,indexed_pc_relative_load_relative,arm_jump_table_block_start,arch.reg_relative_load,arm_jump_table_data_block,next_block_in_byte_interval,impossible_block,reg_def_use.ambiguous_last_def_in_block,reg_def_use.live_var_at_prior_used,data_block_candidate,invalid_jump_table_candidate,compare_and_jump_indirect,reg_def_use.flow_def,arm_jump_table_data_block_limit,stack_base_reg_move,__agg_single3,base_relative_jump,arm_jump_table_block_instruction,__agg_subclause2,no_value_reg_limit,overlap_with_litpool,split_load_candidate,__agg_subclause4,padding_block_candidate,inferred_main_dispatch,relocation_adjustment,tls_get_addr,after_end,stack_def_use.defined_in_block,reg_def_use.used_in_block,stack_def_use.last_def_in_block,candidate_block_is_padding,plt_entry,jump_table_max,reg_def_use.live_var_at_block_end,initialized_data_segment,tls_relative_operand_mips,relative_address,litpool_ref,arm_jump_table_candidate_start,must_fallthrough,may_fallthrough,contains_implausible_instr_seq,__agg_subclause6,no_return_call_refined,block_points_proportional,no_return_block,cinf_ldr_add_pc,relative_address_start,adjusts_stack_in_block,resolved_reaches,block_total_points,next_end,possible_target_from,block_candidate_dependency_edge,block,self_contained_segment,block_next,reg_def_use.live_var_def,jump_table_signed,reg_has_got,no_return_call_propagated,wis_prior,split_load_conflict,jump_table_start,wis_schedule_iter,reg_def_use.ambiguous_block_last_def,jump_table_prelude,first_block_in_byte_interval,arch.extend_load,base_relative_operation,indefinite_litpool_ref,compare_and_jump_immediate,unresolved_block_overlap,split_load,stack_def_use.used_in_block,reg_reg_arithmetic_operation_defs,padding_block_limit,reg_def_use.def_used,tls_desc_call,litpool_boundaries,discarded_block,stack_def_use.live_var_def,base_relative_operand,data_in_code,plt_block,reg_used_for,overlapping_instruction,reg_has_base_image,cmp_defines,nop_in_padding_candidate,compare_and_jump_indirect_op_valid,data_block_limit,__agg_subclause7,block_implies_block,const_value_reg_used,reg_def_use.return_block_end,next_type,__agg_single10,adrp_used,symbol_minus_symbol_litpool_access_pattern,contains_plausible_instr_seq,got_relative_operand,jump_table_candidate_refined,stack_def_use.live_var_at_prior_used,possible_target,instruction_memory_access_size,block_points,basic_target,split_load_operand,incomplete_block,transition_block_limit,data_access,litpool_confidence,block_overlap,arm_jump_table_candidate,reg_def_use.block_last_def,reg_def_use.last_def_in_block,is_padding,simple_data_access_pattern,reg_def_use.live_var_used,straight_line_last_def,__agg_single2,inter_procedural_edge,init_symbol_minus_symbol_candidate_arm,function_inference.function_entry_initial,block_heuristic,hi_load_prop,unresolved_interval_order,symbolic_expr_from_relocation,discarded_split_load,likely_fallthrough,block_boundaries,call_tls_get_addr_mips,stack_def_use.block_last_def,__agg_single6,stack_def_use.live_var_at_block_end,split_load_point,cmp_reg_to_reg,unlikely_have_symbolic_immediate,reg_def_use.defined_in_block,jump_table_target,no_return_call,split_load_for_symbolization,call_tls_get_addr,__agg_subclause3,next_start,stack_def_use.ref_in_block,straight_line_def_used,def_used_for_address,init_ldr_add_pc,last_value_reg_limit,value_reg_edge,data_segment,common_tail,reg_def_use.ref_in_block,known_block,negative_block_heuristic,relative_jump_table_entry_candidate,stack_def_use.live_var_used,unresolved_block,block_last_instruction,value_reg_limit,composite_data_access
- start_function(ea:address)
Uses:
binary_format,entry_point,function_symbolUsed by:
inferred_special_symbolRecursive:
arm_jump_table_cmp_limit,value_reg_unsupported,value_reg,candidate_block_is_not_padding,gp_relative_operand,split_load_total_points,stack_def_use.def_used,indexed_pc_relative_load,branch_to_calculated_pc_rel_addr,code_in_block,jump_table_element_access,compare_and_jump_register,jump_table_candidate,invalid,block_candidate_boundaries,data_in_code_propagate,relocation_adjustment_total,arch.simple_data_load,local_dynamic_tls_candidate,block_limit,block_instruction_next,reg_def_use.used,wis_memo,stack_def_use.live_var_used_in_block,wis_has_prior,arm_jump_table_skip_first_entry,wis_schedule,flags_and_jump_pair,litpool_symbolic_operand,segment_target_range,inferred_main_in_reg,code_in_block_candidate_refined,unresolved_interval,code_in_block_candidate,reg_def_use.return_val_used,start_function,correlated_live_reg,indexed_pc_relative_load_relative,arm_jump_table_block_start,arch.reg_relative_load,arm_jump_table_data_block,next_block_in_byte_interval,impossible_block,reg_def_use.ambiguous_last_def_in_block,reg_def_use.live_var_at_prior_used,data_block_candidate,invalid_jump_table_candidate,compare_and_jump_indirect,reg_def_use.flow_def,arm_jump_table_data_block_limit,stack_base_reg_move,__agg_single3,base_relative_jump,arm_jump_table_block_instruction,__agg_subclause2,no_value_reg_limit,overlap_with_litpool,split_load_candidate,__agg_subclause4,padding_block_candidate,inferred_main_dispatch,relocation_adjustment,tls_get_addr,after_end,stack_def_use.defined_in_block,reg_def_use.used_in_block,stack_def_use.last_def_in_block,candidate_block_is_padding,plt_entry,jump_table_max,reg_def_use.live_var_at_block_end,initialized_data_segment,tls_relative_operand_mips,relative_address,litpool_ref,arm_jump_table_candidate_start,must_fallthrough,may_fallthrough,contains_implausible_instr_seq,__agg_subclause6,no_return_call_refined,block_points_proportional,no_return_block,cinf_ldr_add_pc,relative_address_start,adjusts_stack_in_block,resolved_reaches,block_total_points,next_end,possible_target_from,block_candidate_dependency_edge,block,self_contained_segment,block_next,reg_def_use.live_var_def,jump_table_signed,reg_has_got,no_return_call_propagated,wis_prior,split_load_conflict,jump_table_start,wis_schedule_iter,reg_def_use.ambiguous_block_last_def,jump_table_prelude,first_block_in_byte_interval,arch.extend_load,base_relative_operation,indefinite_litpool_ref,compare_and_jump_immediate,unresolved_block_overlap,split_load,stack_def_use.used_in_block,reg_reg_arithmetic_operation_defs,padding_block_limit,reg_def_use.def_used,tls_desc_call,litpool_boundaries,discarded_block,stack_def_use.live_var_def,base_relative_operand,data_in_code,plt_block,reg_used_for,overlapping_instruction,reg_has_base_image,cmp_defines,nop_in_padding_candidate,compare_and_jump_indirect_op_valid,data_block_limit,__agg_subclause7,block_implies_block,const_value_reg_used,reg_def_use.return_block_end,next_type,__agg_single10,adrp_used,symbol_minus_symbol_litpool_access_pattern,contains_plausible_instr_seq,got_relative_operand,jump_table_candidate_refined,stack_def_use.live_var_at_prior_used,possible_target,instruction_memory_access_size,block_points,basic_target,split_load_operand,incomplete_block,transition_block_limit,data_access,litpool_confidence,block_overlap,arm_jump_table_candidate,reg_def_use.block_last_def,reg_def_use.last_def_in_block,is_padding,simple_data_access_pattern,reg_def_use.live_var_used,straight_line_last_def,__agg_single2,inter_procedural_edge,init_symbol_minus_symbol_candidate_arm,function_inference.function_entry_initial,block_heuristic,hi_load_prop,unresolved_interval_order,symbolic_expr_from_relocation,discarded_split_load,likely_fallthrough,block_boundaries,call_tls_get_addr_mips,stack_def_use.block_last_def,__agg_single6,stack_def_use.live_var_at_block_end,split_load_point,cmp_reg_to_reg,unlikely_have_symbolic_immediate,reg_def_use.defined_in_block,jump_table_target,no_return_call,split_load_for_symbolization,call_tls_get_addr,__agg_subclause3,next_start,stack_def_use.ref_in_block,straight_line_def_used,def_used_for_address,init_ldr_add_pc,last_value_reg_limit,value_reg_edge,data_segment,common_tail,reg_def_use.ref_in_block,known_block,negative_block_heuristic,relative_jump_table_entry_candidate,stack_def_use.live_var_used,unresolved_block,block_last_instruction,value_reg_limit,composite_data_access
- do_infer_main_function()
Decide whether the main function should be inferred.
WARNING: Predicate not present in compiled Datalog program (Dead Code)
- inferred_main_dispatch(EA:address)
Locate where main() is dispatched (i.e., where __libc_start_main is called.)
Uses:
binary_format,binary_type,function_symbolRecursive:
arm_jump_table_cmp_limit,value_reg_unsupported,value_reg,candidate_block_is_not_padding,gp_relative_operand,split_load_total_points,stack_def_use.def_used,indexed_pc_relative_load,branch_to_calculated_pc_rel_addr,code_in_block,jump_table_element_access,compare_and_jump_register,jump_table_candidate,invalid,block_candidate_boundaries,data_in_code_propagate,relocation_adjustment_total,arch.simple_data_load,local_dynamic_tls_candidate,block_limit,block_instruction_next,reg_def_use.used,wis_memo,stack_def_use.live_var_used_in_block,wis_has_prior,arm_jump_table_skip_first_entry,wis_schedule,flags_and_jump_pair,litpool_symbolic_operand,segment_target_range,inferred_main_in_reg,code_in_block_candidate_refined,unresolved_interval,code_in_block_candidate,reg_def_use.return_val_used,start_function,correlated_live_reg,indexed_pc_relative_load_relative,arm_jump_table_block_start,arch.reg_relative_load,arm_jump_table_data_block,next_block_in_byte_interval,impossible_block,reg_def_use.ambiguous_last_def_in_block,reg_def_use.live_var_at_prior_used,data_block_candidate,invalid_jump_table_candidate,compare_and_jump_indirect,reg_def_use.flow_def,arm_jump_table_data_block_limit,stack_base_reg_move,__agg_single3,base_relative_jump,arm_jump_table_block_instruction,__agg_subclause2,no_value_reg_limit,overlap_with_litpool,split_load_candidate,__agg_subclause4,padding_block_candidate,inferred_main_dispatch,relocation_adjustment,tls_get_addr,after_end,stack_def_use.defined_in_block,reg_def_use.used_in_block,stack_def_use.last_def_in_block,candidate_block_is_padding,plt_entry,jump_table_max,reg_def_use.live_var_at_block_end,initialized_data_segment,tls_relative_operand_mips,relative_address,litpool_ref,arm_jump_table_candidate_start,must_fallthrough,may_fallthrough,contains_implausible_instr_seq,__agg_subclause6,no_return_call_refined,block_points_proportional,no_return_block,cinf_ldr_add_pc,relative_address_start,adjusts_stack_in_block,resolved_reaches,block_total_points,next_end,possible_target_from,block_candidate_dependency_edge,block,self_contained_segment,block_next,reg_def_use.live_var_def,jump_table_signed,reg_has_got,no_return_call_propagated,wis_prior,split_load_conflict,jump_table_start,wis_schedule_iter,reg_def_use.ambiguous_block_last_def,jump_table_prelude,first_block_in_byte_interval,arch.extend_load,base_relative_operation,indefinite_litpool_ref,compare_and_jump_immediate,unresolved_block_overlap,split_load,stack_def_use.used_in_block,reg_reg_arithmetic_operation_defs,padding_block_limit,reg_def_use.def_used,tls_desc_call,litpool_boundaries,discarded_block,stack_def_use.live_var_def,base_relative_operand,data_in_code,plt_block,reg_used_for,overlapping_instruction,reg_has_base_image,cmp_defines,nop_in_padding_candidate,compare_and_jump_indirect_op_valid,data_block_limit,__agg_subclause7,block_implies_block,const_value_reg_used,reg_def_use.return_block_end,next_type,__agg_single10,adrp_used,symbol_minus_symbol_litpool_access_pattern,contains_plausible_instr_seq,got_relative_operand,jump_table_candidate_refined,stack_def_use.live_var_at_prior_used,possible_target,instruction_memory_access_size,block_points,basic_target,split_load_operand,incomplete_block,transition_block_limit,data_access,litpool_confidence,block_overlap,arm_jump_table_candidate,reg_def_use.block_last_def,reg_def_use.last_def_in_block,is_padding,simple_data_access_pattern,reg_def_use.live_var_used,straight_line_last_def,__agg_single2,inter_procedural_edge,init_symbol_minus_symbol_candidate_arm,function_inference.function_entry_initial,block_heuristic,hi_load_prop,unresolved_interval_order,symbolic_expr_from_relocation,discarded_split_load,likely_fallthrough,block_boundaries,call_tls_get_addr_mips,stack_def_use.block_last_def,__agg_single6,stack_def_use.live_var_at_block_end,split_load_point,cmp_reg_to_reg,unlikely_have_symbolic_immediate,reg_def_use.defined_in_block,jump_table_target,no_return_call,split_load_for_symbolization,call_tls_get_addr,__agg_subclause3,next_start,stack_def_use.ref_in_block,straight_line_def_used,def_used_for_address,init_ldr_add_pc,last_value_reg_limit,value_reg_edge,data_segment,common_tail,reg_def_use.ref_in_block,known_block,negative_block_heuristic,relative_jump_table_entry_candidate,stack_def_use.live_var_used,unresolved_block,block_last_instruction,value_reg_limit,composite_data_access
- inferred_main_in_reg(EA:address, Reg:register)
The location and register where the address of main is loaded.
Uses:
arch.integer_reg_param,instruction,instruction_get_src_op,next,op_indirect_contains_reg,op_regdirect_contains_regUsed by:
inferred_main_functionRecursive:
arm_jump_table_cmp_limit,value_reg_unsupported,value_reg,candidate_block_is_not_padding,gp_relative_operand,split_load_total_points,stack_def_use.def_used,indexed_pc_relative_load,branch_to_calculated_pc_rel_addr,code_in_block,jump_table_element_access,compare_and_jump_register,jump_table_candidate,invalid,block_candidate_boundaries,data_in_code_propagate,relocation_adjustment_total,arch.simple_data_load,local_dynamic_tls_candidate,block_limit,block_instruction_next,reg_def_use.used,wis_memo,stack_def_use.live_var_used_in_block,wis_has_prior,arm_jump_table_skip_first_entry,wis_schedule,flags_and_jump_pair,litpool_symbolic_operand,segment_target_range,inferred_main_in_reg,code_in_block_candidate_refined,unresolved_interval,code_in_block_candidate,reg_def_use.return_val_used,start_function,correlated_live_reg,indexed_pc_relative_load_relative,arm_jump_table_block_start,arch.reg_relative_load,arm_jump_table_data_block,next_block_in_byte_interval,impossible_block,reg_def_use.ambiguous_last_def_in_block,reg_def_use.live_var_at_prior_used,data_block_candidate,invalid_jump_table_candidate,compare_and_jump_indirect,reg_def_use.flow_def,arm_jump_table_data_block_limit,stack_base_reg_move,__agg_single3,base_relative_jump,arm_jump_table_block_instruction,__agg_subclause2,no_value_reg_limit,overlap_with_litpool,split_load_candidate,__agg_subclause4,padding_block_candidate,inferred_main_dispatch,relocation_adjustment,tls_get_addr,after_end,stack_def_use.defined_in_block,reg_def_use.used_in_block,stack_def_use.last_def_in_block,candidate_block_is_padding,plt_entry,jump_table_max,reg_def_use.live_var_at_block_end,initialized_data_segment,tls_relative_operand_mips,relative_address,litpool_ref,arm_jump_table_candidate_start,must_fallthrough,may_fallthrough,contains_implausible_instr_seq,__agg_subclause6,no_return_call_refined,block_points_proportional,no_return_block,cinf_ldr_add_pc,relative_address_start,adjusts_stack_in_block,resolved_reaches,block_total_points,next_end,possible_target_from,block_candidate_dependency_edge,block,self_contained_segment,block_next,reg_def_use.live_var_def,jump_table_signed,reg_has_got,no_return_call_propagated,wis_prior,split_load_conflict,jump_table_start,wis_schedule_iter,reg_def_use.ambiguous_block_last_def,jump_table_prelude,first_block_in_byte_interval,arch.extend_load,base_relative_operation,indefinite_litpool_ref,compare_and_jump_immediate,unresolved_block_overlap,split_load,stack_def_use.used_in_block,reg_reg_arithmetic_operation_defs,padding_block_limit,reg_def_use.def_used,tls_desc_call,litpool_boundaries,discarded_block,stack_def_use.live_var_def,base_relative_operand,data_in_code,plt_block,reg_used_for,overlapping_instruction,reg_has_base_image,cmp_defines,nop_in_padding_candidate,compare_and_jump_indirect_op_valid,data_block_limit,__agg_subclause7,block_implies_block,const_value_reg_used,reg_def_use.return_block_end,next_type,__agg_single10,adrp_used,symbol_minus_symbol_litpool_access_pattern,contains_plausible_instr_seq,got_relative_operand,jump_table_candidate_refined,stack_def_use.live_var_at_prior_used,possible_target,instruction_memory_access_size,block_points,basic_target,split_load_operand,incomplete_block,transition_block_limit,data_access,litpool_confidence,block_overlap,arm_jump_table_candidate,reg_def_use.block_last_def,reg_def_use.last_def_in_block,is_padding,simple_data_access_pattern,reg_def_use.live_var_used,straight_line_last_def,__agg_single2,inter_procedural_edge,init_symbol_minus_symbol_candidate_arm,function_inference.function_entry_initial,block_heuristic,hi_load_prop,unresolved_interval_order,symbolic_expr_from_relocation,discarded_split_load,likely_fallthrough,block_boundaries,call_tls_get_addr_mips,stack_def_use.block_last_def,__agg_single6,stack_def_use.live_var_at_block_end,split_load_point,cmp_reg_to_reg,unlikely_have_symbolic_immediate,reg_def_use.defined_in_block,jump_table_target,no_return_call,split_load_for_symbolization,call_tls_get_addr,__agg_subclause3,next_start,stack_def_use.ref_in_block,straight_line_def_used,def_used_for_address,init_ldr_add_pc,last_value_reg_limit,value_reg_edge,data_segment,common_tail,reg_def_use.ref_in_block,known_block,negative_block_heuristic,relative_jump_table_entry_candidate,stack_def_use.live_var_used,unresolved_block,block_last_instruction,value_reg_limit,composite_data_access
- inferred_main_function(Main_location:address)
Infer the location of the main function.
Uses:
address_in_data,code_in_block,inferred_main_in_reg,instruction_get_op,op_indirect_contains_reg,reg_def_use.def_used,value_regRecursive:
refined_block,data_limit_after_access,moved_pc_relative_candidate,symbolic_expr,symbolic_operand,symbolic_operand_point,data_object,+disconnected6,data_limit,after_address_in_data,discarded_jump_table_entry,moved_data_label,best_func_symbol,inferred_symbol_mips,relative_jump_table_entry,string_candidate_refined,discarded_data_object,+disconnected1,address_array_aux,next_data_limit,preferred_data_access,label_conflict,symbolic_operand_attribute,main_function,block_needs_splitting_at,symbolic_expr_attribute,data_access_limit,boundary_sym_expr,symbolic_expr_symbol_minus_symbol,labeled_data_candidate,string_candidate,data_object_conflict,moved_label_candidate,labeled_ea,data_object_point,jump_table,function_inference.function_entry,+disconnected4,inferred_special_symbol,value_reg_address_before,code_in_split_block,+disconnected2,resolved_transfer,moved_displacement_candidate,symbolic_data,code_pointer_in_data,best_symexpr_symbol,next_address_in_data,symbol_minus_symbol_candidate,symbol_score,inferred_symbol,data_object_candidate,block_needs_merging,symbol_minus_symbol_from_relocation,data_object_total_points,inferred_main_function,symbol_minus_symbol,code_in_refined_block,moved_label,got_reference,split_block,address_array
- reloc_type_relpc(Type:symbol)
Type of relocation relevant to pc-relative attribute
Used by:
relocation_adjustment
- reloc_type_with_name(Type:symbol)
Type of relocation possibly with non-empty Symbol name
Used by:
symbolic_expr_from_relocation
- reloc_type_nameless(Type:symbol)
Type of relocation possibly with empty Symbol name
Used by:
symbolic_expr_from_relocation
- copy_relocated_symbol(EA:address, Name:symbol)
Collect all the symbols whose address, size and type are the same as the symbol with
COPYrelocation.Uses:
relocation,symbolRecursive:
copy_relocated_symbol
- best_ifunc_symbol(EA:address, SymbolName:symbol)
Best GNU_IFUNC symbol for plt entries. Uses
ifunc_symbol_scoreto deterministically select a single ifunc symbol for each EA.Uses:
ifunc_symbol_score,relocation,symbolUsed by:
plt_entry
- ifunc_symbol_score(EA:address, SymbolName:symbol, Score:unsigned)
Provide a score to GNU_IFUNC symbols based on scope, visibility, and their table index.
Uses:
defined_symbol,ifunc_scope_score,symbol_visibility_scoreUsed by:
best_ifunc_symbol
- ifunc_scope_score(Scope:symbol, Score:unsigned)
Auxiliary predicate to define
ifunc_symbol_scorePrefer symbols with LOCAL over GLOBAL, and with GLOBAl over anything else (WEAK).Uses:
symbolUsed by:
ifunc_symbol_score