Commit d506d6ca by Richard Biener Committed by Richard Biener

tree-ssa-structalias.c (solve_graph): When propagating to successors update the…

tree-ssa-structalias.c (solve_graph): When propagating to successors update the graphs succ edges and avoid duplicate...

2017-08-17  Richard Biener  <rguenther@suse.de>

	* tree-ssa-structalias.c (solve_graph): When propagating
	to successors update the graphs succ edges and avoid duplicate work.

From-SVN: r251146
parent b8d8d3ff
2017-08-17 Richard Biener <rguenther@suse.de>
* tree-ssa-structalias.c (solve_graph): When propagating
to successors update the graphs succ edges and avoid duplicate work.
2017-08-17 Maxim Ostapenko <m.ostapenko@samsung.com>
PR target/81861
......
......@@ -2765,20 +2765,35 @@ solve_graph (constraint_graph_t graph)
unsigned eff_escaped_id = find (escaped_id);
/* Propagate solution to all successors. */
unsigned to_remove = ~0U;
EXECUTE_IF_IN_NONNULL_BITMAP (graph->succs[i],
0, j, bi)
{
bitmap tmp;
bool flag;
if (to_remove != ~0U)
{
bitmap_clear_bit (graph->succs[i], to_remove);
to_remove = ~0U;
}
unsigned int to = find (j);
tmp = get_varinfo (to)->solution;
flag = false;
if (to != j)
{
/* Update the succ graph, avoiding duplicate
work. */
to_remove = j;
if (! bitmap_set_bit (graph->succs[i], to))
continue;
/* We eventually end up processing 'to' twice
as it is undefined whether bitmap iteration
iterates over bits set during iteration.
Play safe instead of doing tricks. */
}
/* Don't try to propagate to ourselves. */
if (to == i)
continue;
bitmap tmp = get_varinfo (to)->solution;
bool flag = false;
/* If we propagate from ESCAPED use ESCAPED as
placeholder. */
if (i == eff_escaped_id)
......@@ -2789,6 +2804,8 @@ solve_graph (constraint_graph_t graph)
if (flag)
bitmap_set_bit (changed, to);
}
if (to_remove != ~0U)
bitmap_clear_bit (graph->succs[i], to_remove);
}
}
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment