aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr46177-2.c18
-rw-r--r--gcc/tree-loop-distribution.c35
4 files changed, 36 insertions, 29 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f4c868a..de4d484 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2010-11-09 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/46177
+ * tree-loop-distribution.c (prop_phis): Remove.
+ (generate_builtin): Re-use the old loop exit edge to avoid
+ needing to update PHI nodes.
+
2010-11-09 Joern Rennecke <amylaar@spamcop.net>
* ix86_expand_split_stack_prologue (args_size): Change type to
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 4214d4e..70493d9 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2010-11-09 Richard Guenther <rguenther@suse.de>
+ PR tree-optimization/46177
+ * gcc.dg/pr46177-2.c: New testcase.
+
+2010-11-09 Richard Guenther <rguenther@suse.de>
+
PR testsuite/46312
* gcc.dg/vec-scal-opt.c: Move ...
* gcc.dg/vect/vect-scal-opt.c: ... here.
diff --git a/gcc/testsuite/gcc.dg/pr46177-2.c b/gcc/testsuite/gcc.dg/pr46177-2.c
new file mode 100644
index 0000000..91fd20e
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr46177-2.c
@@ -0,0 +1,18 @@
+/* { dg-do compile } */
+/* { dg-options "-O -fno-tree-copy-prop -ftree-loop-distribution" } */
+
+int A[30], B[30];
+
+void
+foo (int j)
+{
+ int i, k;
+ for (k = 0; k < 10; k++)
+ if (j)
+ {
+ for (; j < k; j++)
+ ;
+ for (i = 0; i < k; i++)
+ A[i] = B[i] = 0;
+ }
+}
diff --git a/gcc/tree-loop-distribution.c b/gcc/tree-loop-distribution.c
index bc3f54d..59585cd 100644
--- a/gcc/tree-loop-distribution.c
+++ b/gcc/tree-loop-distribution.c
@@ -311,31 +311,6 @@ generate_memset_zero (gimple stmt, tree op0, tree nb_iter,
return res;
}
-/* Propagate phis in BB b to their uses and remove them. */
-
-static void
-prop_phis (basic_block b)
-{
- gimple_stmt_iterator psi;
-
- for (psi = gsi_start_phis (b); !gsi_end_p (psi); )
- {
- gimple phi = gsi_stmt (psi);
- tree def = gimple_phi_result (phi);
-
- if (!is_gimple_reg (def))
- mark_virtual_phi_result_for_renaming (phi);
- else
- {
- tree use = gimple_phi_arg_def (phi, 0);
- gcc_assert (gimple_phi_num_args (phi) == 1);
- replace_uses_by (def, use);
- }
-
- remove_phi_node (&psi, true);
- }
-}
-
/* Tries to generate a builtin function for the instructions of LOOP
pointed to by the bits set in PARTITION. Returns true when the
operation succeeded. */
@@ -405,11 +380,13 @@ generate_builtin (struct loop *loop, bitmap partition, bool copy_p)
if (res && !copy_p)
{
unsigned nbbs = loop->num_nodes;
- basic_block src = loop_preheader_edge (loop)->src;
- basic_block dest = single_exit (loop)->dest;
- prop_phis (dest);
- make_edge (src, dest, EDGE_FALLTHRU);
+ edge exit = single_exit (loop);
+ basic_block src = loop_preheader_edge (loop)->src, dest = exit->dest;
+ redirect_edge_pred (exit, src);
+ exit->flags &= ~(EDGE_TRUE_VALUE|EDGE_FALSE_VALUE);
+ exit->flags |= EDGE_FALLTHRU;
cancel_loop_tree (loop);
+ rescan_loop_exit (exit, false, true);
for (i = 0; i < nbbs; i++)
delete_basic_block (bbs[i]);