GCC Middle and Back End API Reference
|
Public Member Functions | |
void | ssa_propagate (void) |
Private Member Functions | |
enum ssa_prop_result | visit_stmt (gimple *, edge *, tree *) final override |
enum ssa_prop_result | visit_phi (gphi *) final override |
void | simulate_stmt (gimple *stmt) |
void | simulate_block (basic_block) |
|
privateinherited |
Simulate the execution of BLOCK. Evaluate the statement associated with each variable reference inside the block.
References add_control_edge(), BB_VISITED, cfun, dump_file, dump_flags, EXIT_BLOCK_PTR_FOR_FN, basic_block_def::flags, FOR_EACH_EDGE, gsi_end_p(), gsi_next(), gsi_start_bb(), gsi_start_phis(), gsi_stmt(), basic_block_def::index, NULL, ssa_propagation_engine::simulate_stmt(), basic_block_def::succs, and TDF_DETAILS.
Referenced by ssa_propagation_engine::ssa_propagate().
|
privateinherited |
Simulate the execution of STMT and update the work lists accordingly.
References add_control_edge(), add_ssa_edge(), as_a(), bitmap_clear_bit(), dump_file, dump_flags, FOR_EACH_EDGE, FOR_EACH_SSA_USE_OPERAND, gimple_bb(), gimple_nop_p(), gimple_phi_result(), gimple_uid(), NULL, NULL_TREE, PHI_ARG_DEF_FROM_EDGE, prop_set_simulate_again(), prop_simulate_again_p(), ssa_edge_worklist, SSA_NAME_DEF_STMT, SSA_NAME_IS_DEFAULT_DEF, SSA_OP_USE, SSA_PROP_INTERESTING, SSA_PROP_NOT_INTERESTING, SSA_PROP_VARYING, stmt_ends_bb_p(), basic_block_def::succs, TDF_DETAILS, TREE_CODE, USE_FROM_PTR, ssa_propagation_engine::visit_phi(), and ssa_propagation_engine::visit_stmt().
Referenced by ssa_propagation_engine::simulate_block(), and ssa_propagation_engine::ssa_propagate().
|
inherited |
Entry point to the propagation engine. The VISIT_STMT virtual function is called for every statement visited and the VISIT_PHI virtual function is called for every PHI node visited.
References add_control_edge(), BASIC_BLOCK_FOR_FN, bb_to_cfg_order, bitmap_clear_bit(), bitmap_empty_p(), bitmap_first_set_bit(), cfg_blocks, cfg_order_to_bb, cfun, curr_order, dump_file, dump_flags, ENTRY_BLOCK_PTR_FOR_FN, FOR_EACH_EDGE, gimple_bb(), basic_block_def::index, NULL, print_gimple_stmt(), ssa_propagation_engine::simulate_block(), ssa_propagation_engine::simulate_stmt(), ssa_edge_worklist, ssa_prop_fini(), ssa_prop_init(), TDF_DETAILS, and uid_to_stmt.
Referenced by do_ssa_ccp(), execute_copy_prop(), and tree_lower_complex().
|
finaloverrideprivatevirtual |
Evaluate a PHI node against the complex lattice defined above.
Implements ssa_propagation_engine.
References complex_lattice_values, find_lattice_value(), gcc_assert, gimple_phi_arg_def(), gimple_phi_num_args(), gimple_phi_result(), i, SSA_NAME_OCCURS_IN_ABNORMAL_PHI, SSA_NAME_VERSION, SSA_PROP_INTERESTING, SSA_PROP_NOT_INTERESTING, SSA_PROP_VARYING, TREE_CODE, TREE_TYPE, UNINITIALIZED, and VARYING.
|
finaloverrideprivatevirtual |
Evaluate statement STMT against the complex lattice defined above.
Implements ssa_propagation_engine.
References complex_lattice_values, find_lattice_value(), find_lattice_value_parts(), gcc_assert, gimple_assign_rhs1(), gimple_assign_rhs2(), gimple_expr_code(), gimple_get_lhs(), ONLY_REAL, SSA_NAME_OCCURS_IN_ABNORMAL_PHI, SSA_NAME_VERSION, SSA_PROP_INTERESTING, SSA_PROP_NOT_INTERESTING, SSA_PROP_VARYING, TREE_CODE, TREE_TYPE, UNINITIALIZED, and VARYING.