Lines Matching defs:cfg_hooks
58 struct cfg_hooks struct
61 const char *name;
64 int (*verify_flow_info) (void);
65 void (*dump_bb) (FILE *, basic_block, int, dump_flags_t);
66 void (*dump_bb_for_graph) (pretty_printer *, basic_block);
71 basic_block (*create_basic_block) (void *head, void *end, basic_block after);
77 edge (*redirect_edge_and_branch) (edge e, basic_block b);
82 basic_block (*redirect_edge_and_branch_force) (edge, basic_block);
86 bool (*can_remove_branch_p) (const_edge);
89 void (*delete_basic_block) (basic_block);
93 basic_block (*split_block) (basic_block b, void * i);
96 bool (*move_block_after) (basic_block b, basic_block a);
99 bool (*can_merge_blocks_p) (basic_block a, basic_block b);
102 void (*merge_blocks) (basic_block a, basic_block b);
105 void (*predict_edge) (edge e, enum br_predictor predictor, int probability);
109 bool (*predicted_by_p) (const_basic_block bb, enum br_predictor predictor);
112 bool (*can_duplicate_block_p) (const_basic_block a);
115 basic_block (*duplicate_block) (basic_block a);
119 basic_block (*split_edge) (edge);
120 void (*make_forwarder_block) (edge);
123 void (*tidy_fallthru_edge) (edge);
126 basic_block (*force_nonfallthru) (edge);
130 bool (*block_ends_with_call_p) (basic_block);
134 bool (*block_ends_with_condjump_p) (const_basic_block);
143 int (*flow_call_edges_add) (sbitmap);
147 void (*execute_on_growing_pred) (edge);
151 void (*execute_on_shrinking_pred) (edge);
155 bool (*cfg_hook_duplicate_loop_to_header_edge) (struct loop *, edge,
162 void (*lv_add_condition_to_bb) (basic_block, basic_block, basic_block,
165 void (*lv_adjust_loop_header_phi) (basic_block, basic_block,
170 void (*extract_cond_bb_edges) (basic_block, edge *, edge *);
175 void (*flush_pending_stmts) (edge);
178 bool (*empty_block_p) (basic_block);
182 basic_block (*split_block_before_cond_jump) (basic_block);
185 void (*account_profile_record) (basic_block, int, struct profile_record *);