boundary_value_analysis
This analysis looks for comparisons of a register to an immediate in order to bound the possible values of that register.
For example, in the following jump table code, AL is bounded as less than or equal to 11 due to the comparison. This boundary value can be used by the jumptable propagation to determine a max size.
cmp AL,11 ja jumptable_default lea RDI,QWORD PTR [RIP+.L_jumptable] movzx EAX,AL movsxd RAX,DWORD PTR [RDI+RAX*4] add RAX,RDI jmp RAX
- flags_and_jump_pair(EA_flags:address, EA_jmp:address, CC:condition_code)
A pair of instructions that sets the flags register and then conditionally jump.
Empty on architectures where a flags register is not used.
Recursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- compare_and_jump_immediate(EA_cmp:address, EA_jmp:address, CC:condition_code, Reg:register, Immediate:number)
A pair of instructions that compares a register to an immediate and then conditionally jumps.
Uses:
arch.cmp_operation,arch.cmp_zero_operation,arch.conditional,arch.jump,cmp_immediate_to_reg,instruction,instruction_get_op,op_regdirect_contains_reg,reg_map,register_accessRecursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- compare_and_jump_register(EA_cmp:address, EA_jmp:address, CC:condition_code, Reg1:register, Reg2:register)
A pair of instructions that compares a register to another register and then conditionally jumps.
Uses:
arch.conditional,arch.jumpUsed by:
moved_label_candidate,symbolic_operand_attribute,symbolic_operand_candidate,symbolic_operand_pointRecursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- compare_and_jump_indirect(EA_cmp:address, EA_jmp:address, CC:condition_code, IndirectOp:operand_code, Immediate:number)
A pair of instructions that compares a memory location to an immediate and then conditionally jumps.
Uses:
arch.cmp_operation,instruction,instruction_get_op,op_immediate,op_indirectRecursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- limit_type_map(CC:condition_code, BranchLT:limit_type, FallthroughLT:limit_type, BranchOffset:number, FallthroughOffset:number)
Map condition codes to limit types
Used by:
arm_jump_table_cmp_limit,value_reg_limit
- value_reg_limit(From:address, To:address, Reg:register, Value:number, LimitType:limit_type)
An instruction at EA limits the value of Reg at some MIN or MAX value.
From: the address that creates the limit To: the address at which the limit is active
Uses:
arch.memory_access,arch.move_reg_imm,direct_jump,instruction_get_op,limit_type_map,track_registerRecursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- compare_and_jump_indirect_op_valid(EA_cmp:address, EA_jmp:address, EA:address, IndirectOp:operand_code, Steps:number)
Detect where indirect operand used in a comparison is unmodified afterward.
Uses:
arch.memory_access,arch.store_immediate,instruction_get_op,op_indirect_mapped,reg_def_use.defRecursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
Two live registers are a constant offset from each other at the end of a block.
Uses:
limit_reg_opRecursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- cmp_defines(EA_jmp:address, EA_dst:address, Reg:register)
A register is compared as NE or EQ and used for a conditional jump.
Uses:
direct_jumpRecursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- no_value_reg_limit(EA_jmp:address)
Jumps where generating a value_reg_limit is not supported.
Recursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- step_limit_small(Limit:unsigned)
Used by:
last_value_reg_limit
- last_value_reg_limit(From:address, To:address, Reg:register, Value:number, LimitType:limit_type, Steps:unsigned)
Basic-block propagation of value_reg_limit
From: the address that creates the limit To: the address at which the limit is active
Recursive:
block_points,flags_and_jump_pair,block_next,jump_table_element_access,jump_table_candidate_refined,relative_jump_table_entry_candidate,value_reg,reg_def_use.live_var_used,arm_jump_table_cmp_limit,arm_jump_table_block_start,unresolved_block,last_value_reg_limit,__agg_single2,reg_def_use.ref_in_block,arm_jump_table_candidate_start,relocation_adjustment_total,data_in_code_propagate,data_in_code,contains_implausible_instr_seq,code_in_block,stack_def_use.live_var_def,reg_def_use.live_var_def,wis_prior,simple_data_access_pattern,no_value_reg_limit,arm_jump_table_candidate,reg_def_use.used,arm_jump_table_skip_first_entry,reg_def_use.live_var_at_block_end,invalid,litpool_symbolic_operand,straight_line_def_used,jump_table_target,after_end,code_in_block_candidate_refined,stack_base_reg_move,initialized_data_segment,indefinite_litpool_ref,may_fallthrough,block_implies_block,reg_def_use.return_block_end,wis_has_prior,data_block_candidate,wis_memo,litpool_boundaries,inter_procedural_edge,candidate_block_is_not_padding,invalid_jump_table_candidate,stack_def_use.live_var_at_block_end,indexed_pc_relative_load_relative,unresolved_interval_order,compare_and_jump_register,tls_relative_operand_mips,reg_def_use.return_val_used,next_end,adjusts_stack_in_block,got_relative_operand,segment_target_range,tls_get_addr,stack_def_use.last_def_in_block,basic_target,symbolic_expr_from_relocation,unlikely_have_symbolic_immediate,next_start,block_overlap,compare_and_jump_indirect,def_used_for_address,overlapping_instruction,wis_schedule,__agg_single3,compare_and_jump_indirect_op_valid,cinf_ldr_add_pc,block_heuristic,stack_def_use.live_var_at_prior_used,symbol_minus_symbol_litpool_access_pattern,arm_jump_table_data_block,block_total_points,split_load_point,no_return_call_propagated,__agg_subclause6,discarded_split_load,init_symbol_minus_symbol_candidate_arm,__agg_subclause4,function_inference.function_entry_initial,next_type,stack_def_use.block_last_def,__agg_single6,reg_has_got,data_block_limit,base_relative_operation,init_ldr_add_pc,block_limit,unresolved_interval,stack_def_use.ref_in_block,reg_used_for,must_fallthrough,value_reg_edge,self_contained_segment,hi_load_prop,block,reg_def_use.def_used,relative_address,likely_fallthrough,composite_data_access,stack_def_use.defined_in_block,known_block,branch_to_calculated_pc_rel_addr,__agg_subclause7,no_return_call,split_load_operand,block_points_proportional,reg_has_base_image,relocation_adjustment,overlap_with_litpool,plt_block,instruction_memory_access_size,const_value_reg_used,__agg_single10,plt_entry,split_load_conflict,common_tail,correlated_live_reg,first_block_in_byte_interval,stack_def_use.def_used,reg_def_use.block_last_def,arm_jump_table_data_block_limit,possible_target_from,reg_reg_arithmetic_operation_defs,wis_schedule_iter,possible_target,stack_def_use.used_in_block,jump_table_prelude,padding_block_candidate,reg_def_use.ambiguous_last_def_in_block,block_candidate_boundaries,no_return_block,candidate_block_is_padding,indexed_pc_relative_load,block_boundaries,jump_table_candidate,discarded_block,reg_def_use.used_in_block,reg_def_use.flow_def,data_segment,transition_block_limit,inferred_main_dispatch,relative_address_start,padding_block_limit,data_access,local_dynamic_tls_candidate,negative_block_heuristic,gp_relative_operand,jump_table_signed,split_load_total_points,cmp_defines,start_function,no_return_call_refined,next_block_in_byte_interval,reg_def_use.live_var_at_prior_used,resolved_reaches,unresolved_block_overlap,arch.extend_load,block_instruction_next,inferred_main_in_reg,contains_plausible_instr_seq,value_reg_limit,tls_desc_call,base_relative_jump,straight_line_last_def,impossible_block,arm_jump_table_block_instruction,split_load_candidate,adrp_used,call_tls_get_addr_mips,cmp_reg_to_reg,split_load_for_symbolization,__agg_subclause2,incomplete_block,reg_def_use.defined_in_block,base_relative_operand,arch.reg_relative_load,stack_def_use.live_var_used_in_block,nop_in_padding_candidate,code_in_block_candidate,is_padding,value_reg_unsupported,reg_def_use.ambiguous_block_last_def,arch.simple_data_load,block_last_instruction,reg_def_use.last_def_in_block,call_tls_get_addr,litpool_ref,litpool_confidence,split_load,jump_table_start,block_candidate_dependency_edge,jump_table_max,compare_and_jump_immediate,stack_def_use.live_var_used,__agg_subclause3
- limit_reg_op(EA:address, DstReg:register, SrcReg:register, Offset:number)
Move or arithmetic operation on a limited register