aboutsummaryrefslogtreecommitdiff
path: root/gcc/cfgloop.c
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2019-11-25 07:51:38 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2019-11-25 07:51:38 +0000
commitf10d2d85c90c9c649675c248cd5a99f66288f81f (patch)
tree284bcf852c57a2fa1c05c83c5138e1553cc14a03 /gcc/cfgloop.c
parent5a34952edb758109a3b919bc149136ee9277ee3a (diff)
downloadgcc-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.c13
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;