Lines Matching defs:cfg_hooks
25 struct cfg_hooks struct
28 const char *name;
31 int (*verify_flow_info) (void);
32 void (*dump_bb) (basic_block, FILE *, int, int);
37 basic_block (*create_basic_block) (void *head, void *end, basic_block after);
43 edge (*redirect_edge_and_branch) (edge e, basic_block b);
48 basic_block (*redirect_edge_and_branch_force) (edge, basic_block);
52 bool (*can_remove_branch_p) (const_edge);
55 void (*delete_basic_block) (basic_block);
59 basic_block (*split_block) (basic_block b, void * i);
62 bool (*move_block_after) (basic_block b, basic_block a);
65 bool (*can_merge_blocks_p) (basic_block a, basic_block b);
68 void (*merge_blocks) (basic_block a, basic_block b);
71 void (*predict_edge) (edge e, enum br_predictor predictor, int probability);
75 bool (*predicted_by_p) (const_basic_block bb, enum br_predictor predictor);
78 bool (*can_duplicate_block_p) (const_basic_block a);
81 basic_block (*duplicate_block) (basic_block a);
85 basic_block (*split_edge) (edge);
86 void (*make_forwarder_block) (edge);
89 void (*tidy_fallthru_edge) (edge);
92 basic_block (*force_nonfallthru) (edge);
96 bool (*block_ends_with_call_p) (basic_block);
100 bool (*block_ends_with_condjump_p) (const_basic_block);
109 int (*flow_call_edges_add) (sbitmap);
113 void (*execute_on_growing_pred) (edge);
117 void (*execute_on_shrinking_pred) (edge);
121 bool (*cfg_hook_duplicate_loop_to_header_edge) (struct loop *, edge,
128 void (*lv_add_condition_to_bb) (basic_block, basic_block, basic_block,
131 void (*lv_adjust_loop_header_phi) (basic_block, basic_block,
136 void (*extract_cond_bb_edges) (basic_block, edge *, edge *);
141 void (*flush_pending_stmts) (edge);