1 /* Support routines for Splitting Paths to loop backedges
2 Copyright (C) 2015-2017 Free Software Foundation, Inc.
3 Contributed by Ajit Kumar Agarwal <ajitkum@xilinx.com>.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3, or (at your option)
12 GCC is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING3. If not see
19 <http://www.gnu.org/licenses/>. */
23 #include "coretypes.h"
27 #include "tree-pass.h"
31 #include "gimple-iterator.h"
35 #include "gimple-ssa.h"
36 #include "tree-phinodes.h"
37 #include "ssa-iterators.h"
39 /* Given LATCH, the latch block in a loop, see if the shape of the
40 path reaching LATCH is suitable for being split by duplication.
41 If so, return the block that will be duplicated into its predecessor
42 paths. Else return NULL. */
45 find_block_to_duplicate_for_splitting_paths (basic_block latch
)
47 /* We should have simple latches at this point. So the latch should
48 have a single successor. This implies the predecessor of the latch
49 likely has the loop exit. And it's that predecessor we're most
50 interested in. To keep things simple, we're going to require that
51 the latch have a single predecessor too. */
52 if (single_succ_p (latch
) && single_pred_p (latch
))
54 basic_block bb
= get_immediate_dominator (CDI_DOMINATORS
, latch
);
55 gcc_assert (single_pred_edge (latch
)->src
== bb
);
57 /* If BB has been marked as not to be duplicated, then honor that
62 gimple
*last
= gsi_stmt (gsi_last_nondebug_bb (bb
));
63 /* The immediate dominator of the latch must end in a conditional. */
64 if (!last
|| gimple_code (last
) != GIMPLE_COND
)
67 /* We're hoping that BB is a join point for an IF-THEN-ELSE diamond
68 region. Verify that it is.
70 First, verify that BB has two predecessors (each arm of the
71 IF-THEN-ELSE) and two successors (the latch and exit). */
72 if (EDGE_COUNT (bb
->preds
) == 2 && EDGE_COUNT (bb
->succs
) == 2)
74 /* Now verify that BB's immediate dominator ends in a
75 conditional as well. */
76 basic_block bb_idom
= get_immediate_dominator (CDI_DOMINATORS
, bb
);
77 gimple
*last
= gsi_stmt (gsi_last_nondebug_bb (bb_idom
));
78 if (!last
|| gimple_code (last
) != GIMPLE_COND
)
81 /* And that BB's immediate dominator's successors are the
82 predecessors of BB or BB itself. */
83 if (!(EDGE_PRED (bb
, 0)->src
== bb_idom
84 || find_edge (bb_idom
, EDGE_PRED (bb
, 0)->src
))
85 || !(EDGE_PRED (bb
, 1)->src
== bb_idom
86 || find_edge (bb_idom
, EDGE_PRED (bb
, 1)->src
)))
89 /* And that the predecessors of BB each have a single successor
90 or are BB's immediate domiator itself. */
91 if (!(EDGE_PRED (bb
, 0)->src
== bb_idom
92 || single_succ_p (EDGE_PRED (bb
, 0)->src
))
93 || !(EDGE_PRED (bb
, 1)->src
== bb_idom
94 || single_succ_p (EDGE_PRED (bb
, 1)->src
)))
97 /* So at this point we have a simple diamond for an IF-THEN-ELSE
98 construct starting at BB_IDOM, with a join point at BB. BB
99 pass control outside the loop or to the loop latch.
101 We're going to want to create two duplicates of BB, one for
102 each successor of BB_IDOM. */
109 /* Return the number of non-debug statements in a block. */
111 count_stmts_in_block (basic_block bb
)
113 gimple_stmt_iterator gsi
;
114 unsigned int num_stmts
= 0;
116 for (gsi
= gsi_start_bb (bb
); !gsi_end_p (gsi
); gsi_next (&gsi
))
118 gimple
*stmt
= gsi_stmt (gsi
);
119 if (!is_gimple_debug (stmt
))
125 /* Return TRUE if CODE represents a tree code that is not likely to
126 be easily if-convertable because it likely expands into multiple
127 insns, FALSE otherwise. */
129 poor_ifcvt_candidate_code (enum tree_code code
)
131 return (code
== MIN_EXPR
135 || code
== CALL_EXPR
);
138 /* Return TRUE if BB is a reasonable block to duplicate by examining
139 its size, false otherwise. BB will always be a loop latch block.
143 We do not want to spoil if-conversion if at all possible.
145 Most of the benefit seems to be from eliminating the unconditional
146 jump rather than CSE/DCE opportunities. So favor duplicating
147 small latches. A latch with just a conditional branch is ideal.
149 CSE/DCE opportunties crop up when statements from the predecessors
150 feed statements in the latch and allow statements in the latch to
154 is_feasible_trace (basic_block bb
)
156 basic_block pred1
= EDGE_PRED (bb
, 0)->src
;
157 basic_block pred2
= EDGE_PRED (bb
, 1)->src
;
158 int num_stmts_in_join
= count_stmts_in_block (bb
);
159 int num_stmts_in_pred1
160 = EDGE_COUNT (pred1
->succs
) == 1 ? count_stmts_in_block (pred1
) : 0;
161 int num_stmts_in_pred2
162 = EDGE_COUNT (pred2
->succs
) == 1 ? count_stmts_in_block (pred2
) : 0;
164 /* This is meant to catch cases that are likely opportunities for
165 if-conversion. Essentially we look for the case where
166 BB's predecessors are both single statement blocks where
167 the output of that statement feed the same PHI in BB. */
168 if (num_stmts_in_pred1
== 1 && num_stmts_in_pred2
== 1)
170 gimple
*stmt1
= last_and_only_stmt (pred1
);
171 gimple
*stmt2
= last_and_only_stmt (pred2
);
174 && gimple_code (stmt1
) == GIMPLE_ASSIGN
175 && gimple_code (stmt2
) == GIMPLE_ASSIGN
)
177 enum tree_code code1
= gimple_assign_rhs_code (stmt1
);
178 enum tree_code code2
= gimple_assign_rhs_code (stmt2
);
180 if (!poor_ifcvt_candidate_code (code1
)
181 && !poor_ifcvt_candidate_code (code2
))
183 tree lhs1
= gimple_assign_lhs (stmt1
);
184 tree lhs2
= gimple_assign_lhs (stmt2
);
185 gimple_stmt_iterator gsi
;
186 for (gsi
= gsi_start_phis (bb
); !gsi_end_p (gsi
); gsi_next (&gsi
))
188 gimple
*phi
= gsi_stmt (gsi
);
189 if ((gimple_phi_arg_def (phi
, 0) == lhs1
190 && gimple_phi_arg_def (phi
, 1) == lhs2
)
191 || (gimple_phi_arg_def (phi
, 1) == lhs1
192 && gimple_phi_arg_def (phi
, 0) == lhs2
))
194 if (dump_file
&& (dump_flags
& TDF_DETAILS
))
196 "Block %d appears to be a join point for "
197 "if-convertable diamond.\n",
206 /* If the joiner has no PHIs with useful uses there is zero chance
207 of CSE/DCE/jump-threading possibilities exposed by duplicating it. */
208 bool found_useful_phi
= false;
209 for (gphi_iterator si
= gsi_start_phis (bb
); ! gsi_end_p (si
);
212 gphi
*phi
= si
.phi ();
214 imm_use_iterator iter
;
215 FOR_EACH_IMM_USE_FAST (use_p
, iter
, gimple_phi_result (phi
))
217 gimple
*stmt
= USE_STMT (use_p
);
218 if (is_gimple_debug (stmt
))
220 /* If there's a use in the joiner this might be a CSE/DCE
222 if (gimple_bb (stmt
) == bb
)
224 found_useful_phi
= true;
227 /* If the use is on a loop header PHI and on one path the
228 value is unchanged this might expose a jump threading
230 if (gimple_code (stmt
) == GIMPLE_PHI
231 && gimple_bb (stmt
) == bb
->loop_father
->header
232 /* But for memory the PHI alone isn't good enough. */
233 && ! virtual_operand_p (gimple_phi_result (stmt
)))
235 bool found_unchanged_path
= false;
236 for (unsigned i
= 0; i
< gimple_phi_num_args (phi
); ++i
)
237 if (gimple_phi_arg_def (phi
, i
) == gimple_phi_result (stmt
))
239 found_unchanged_path
= true;
242 /* If we found an unchanged path this can only be a threading
243 opportunity if we have uses of the loop header PHI result
244 in a stmt dominating the merge block. Otherwise the
245 splitting may prevent if-conversion. */
246 if (found_unchanged_path
)
248 use_operand_p use2_p
;
249 imm_use_iterator iter2
;
250 FOR_EACH_IMM_USE_FAST (use2_p
, iter2
, gimple_phi_result (stmt
))
252 if (is_gimple_debug (USE_STMT (use2_p
)))
254 basic_block use_bb
= gimple_bb (USE_STMT (use2_p
));
256 && dominated_by_p (CDI_DOMINATORS
, bb
, use_bb
))
258 found_useful_phi
= true;
263 if (found_useful_phi
)
267 if (found_useful_phi
)
270 /* There is one exception namely a controlling condition we can propagate
271 an equivalence from to the joiner. */
272 bool found_cprop_opportunity
= false;
273 basic_block dom
= get_immediate_dominator (CDI_DOMINATORS
, bb
);
274 gcond
*cond
= as_a
<gcond
*> (last_stmt (dom
));
275 if (gimple_cond_code (cond
) == EQ_EXPR
276 || gimple_cond_code (cond
) == NE_EXPR
)
277 for (unsigned i
= 0; i
< 2; ++i
)
279 tree op
= gimple_op (cond
, i
);
280 if (TREE_CODE (op
) == SSA_NAME
)
283 imm_use_iterator iter
;
284 FOR_EACH_IMM_USE_FAST (use_p
, iter
, op
)
286 if (is_gimple_debug (USE_STMT (use_p
)))
288 if (gimple_bb (USE_STMT (use_p
)) == bb
)
290 found_cprop_opportunity
= true;
295 if (found_cprop_opportunity
)
299 if (! found_useful_phi
&& ! found_cprop_opportunity
)
301 if (dump_file
&& (dump_flags
& TDF_DETAILS
))
303 "Block %d is a join that does not expose CSE/DCE/jump-thread "
304 "opportunities when duplicated.\n",
309 /* We may want something here which looks at dataflow and tries
310 to guess if duplication of BB is likely to result in simplification
311 of instructions in BB in either the original or the duplicate. */
313 /* Upper Hard limit on the number statements to copy. */
314 if (num_stmts_in_join
315 >= PARAM_VALUE (PARAM_MAX_JUMP_THREAD_DUPLICATION_STMTS
))
321 /* If the immediate dominator of the latch of the loop is
322 block with conditional branch, then the loop latch is
323 duplicated to its predecessors path preserving the SSA
326 CFG before transformation.
346 Block 8 is the latch. We're going to make copies of block 6 (9 & 10)
347 and wire things up so they look like this:
370 Blocks 9 and 10 will get merged into blocks 4 & 5 respectively which
371 enables CSE, DCE and other optimizations to occur on a larger block
377 bool changed
= false;
380 loop_optimizer_init (LOOPS_NORMAL
| LOOPS_HAVE_RECORDED_EXITS
);
381 initialize_original_copy_tables ();
382 calculate_dominance_info (CDI_DOMINATORS
);
384 FOR_EACH_LOOP (loop
, LI_FROM_INNERMOST
)
386 /* Only split paths if we are optimizing this loop for speed. */
387 if (!optimize_loop_for_speed_p (loop
))
390 /* See if there is a block that we can duplicate to split the
391 path to the loop latch. */
393 = find_block_to_duplicate_for_splitting_paths (loop
->latch
);
395 /* BB is the merge point for an IF-THEN-ELSE we want to transform.
397 Essentially we want to create a duplicate of bb and redirect the
398 first predecessor of BB to the duplicate (leaving the second
399 predecessor as is. This will split the path leading to the latch
400 re-using BB to avoid useless copying. */
401 if (bb
&& is_feasible_trace (bb
))
403 if (dump_file
&& (dump_flags
& TDF_DETAILS
))
405 "Duplicating join block %d into predecessor paths\n",
407 basic_block pred0
= EDGE_PRED (bb
, 0)->src
;
408 if (EDGE_COUNT (pred0
->succs
) != 1)
409 pred0
= EDGE_PRED (bb
, 1)->src
;
410 transform_duplicate (pred0
, bb
);
413 /* If BB has an outgoing edge marked as IRREDUCIBLE, then
414 duplicating BB may result in an irreducible region turning
417 Long term we might want to hook this into the block
418 duplication code, but as we've seen with similar changes
419 for edge removal, that can be somewhat risky. */
420 if (EDGE_SUCC (bb
, 0)->flags
& EDGE_IRREDUCIBLE_LOOP
421 || EDGE_SUCC (bb
, 1)->flags
& EDGE_IRREDUCIBLE_LOOP
)
423 if (dump_file
&& (dump_flags
& TDF_DETAILS
))
425 "Join block %d has EDGE_IRREDUCIBLE_LOOP set. "
426 "Scheduling loop fixups.\n",
428 loops_state_set (LOOPS_NEED_FIXUP
);
433 loop_optimizer_finalize ();
434 free_original_copy_tables ();
438 /* Main entry point for splitting paths. Returns TODO_cleanup_cfg if any
439 paths where split, otherwise return zero. */
442 execute_split_paths ()
444 /* If we don't have at least 2 real blocks and backedges in the
445 CFG, then there's no point in trying to perform path splitting. */
446 if (n_basic_blocks_for_fn (cfun
) <= NUM_FIXED_BLOCKS
+ 1
447 || !mark_dfs_back_edges ())
450 bool changed
= split_paths();
452 free_dominance_info (CDI_DOMINATORS
);
454 return changed
? TODO_cleanup_cfg
: 0;
460 return flag_split_paths
;
465 const pass_data pass_data_split_paths
=
467 GIMPLE_PASS
, /* type */
468 "split-paths", /* name */
469 OPTGROUP_NONE
, /* optinfo_flags */
470 TV_SPLIT_PATHS
, /* tv_id */
471 PROP_ssa
, /* properties_required */
472 0, /* properties_provided */
473 0, /* properties_destroyed */
474 0, /* todo_flags_start */
475 TODO_update_ssa
, /* todo_flags_finish */
478 class pass_split_paths
: public gimple_opt_pass
481 pass_split_paths (gcc::context
*ctxt
)
482 : gimple_opt_pass (pass_data_split_paths
, ctxt
)
484 /* opt_pass methods: */
485 opt_pass
* clone () { return new pass_split_paths (m_ctxt
); }
486 virtual bool gate (function
*) { return gate_split_paths (); }
487 virtual unsigned int execute (function
*) { return execute_split_paths (); }
489 }; // class pass_split_paths
494 make_pass_split_paths (gcc::context
*ctxt
)
496 return new pass_split_paths (ctxt
);