diff options
author | Richard Biener <rguenther@suse.de> | 2019-11-25 07:51:38 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2019-11-25 07:51:38 +0000 |
commit | f10d2d85c90c9c649675c248cd5a99f66288f81f (patch) | |
tree | 284bcf852c57a2fa1c05c83c5138e1553cc14a03 /gcc/cfgloop.c | |
parent | 5a34952edb758109a3b919bc149136ee9277ee3a (diff) | |
download | gcc-f10d2d85c90c9c649675c248cd5a99f66288f81f.zip gcc-f10d2d85c90c9c649675c248cd5a99f66288f81f.tar.gz gcc-f10d2d85c90c9c649675c248cd5a99f66288f81f.tar.bz2 |
cfgloop.h (get_loop_exit_edges): Add extra parameter denoting loop body, defaulted to NULL.
2019-11-25 Richard Biener <rguenther@suse.de>
* cfgloop.h (get_loop_exit_edges): Add extra parameter denoting
loop body, defaulted to NULL.
(single_likely_exit): Add exit vector argument
* tree-ssa-loop-niter.h (loop_only_exit_p): Add loop body argument.
(number_of_iterations_exit): Likewise.
(number_of_iterations_exit_assumptions): Likewise.
* cfgloop.c (get_loop_exit_edges): Use passed in loop body
if not NULL.
* cfgloopanal.c (single_likely_exit): Use passed in exit vector.
* tree-ssa-loop-ivcanon.c (canonicalize_loop_induction_variables):
Compute exit vector around call to single_likely_exit.
* tree-ssa-loop-ivopts.c (tree_ssa_iv_optimize_loop): Pass down
loop body to loop_only_exit_p.
* tree-ssa-loop-niter.c (loop_only_exit_p): Get loop body from
caller.
(number_of_iterations_exit_assumptions): Get loop body from caller
if not NULL.
(number_of_iterations_exit): Pass through new loop body arg.
(infer_loop_bounds_from_undefined): Get loop body from caller.
(estimate_numbers_of_iterations): Compute loop body once.
From-SVN: r278667
Diffstat (limited to 'gcc/cfgloop.c')
-rw-r--r-- | gcc/cfgloop.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/gcc/cfgloop.c b/gcc/cfgloop.c index 308ed7d..c766471 100644 --- a/gcc/cfgloop.c +++ b/gcc/cfgloop.c @@ -1203,12 +1203,11 @@ release_recorded_exits (function *fn) /* Returns the list of the exit edges of a LOOP. */ vec<edge> -get_loop_exit_edges (const class loop *loop) +get_loop_exit_edges (const class loop *loop, basic_block *body) { vec<edge> edges = vNULL; edge e; unsigned i; - basic_block *body; edge_iterator ei; struct loop_exit *exit; @@ -1223,14 +1222,20 @@ get_loop_exit_edges (const class loop *loop) } else { - body = get_loop_body (loop); + bool body_from_caller = true; + if (!body) + { + body = get_loop_body (loop); + body_from_caller = false; + } for (i = 0; i < loop->num_nodes; i++) FOR_EACH_EDGE (e, ei, body[i]->succs) { if (!flow_bb_inside_loop_p (loop, e->dest)) edges.safe_push (e); } - free (body); + if (!body_from_caller) + free (body); } return edges; |