re PR rtl-optimization/33673 (ICE in verify_flow_info, missing barrier, when multiple...
authorJakub Jelinek <jakub@redhat.com>
Thu, 1 Nov 2007 08:48:05 +0000 (09:48 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Thu, 1 Nov 2007 08:48:05 +0000 (09:48 +0100)
PR rtl-optimization/33673
* gcse.c (cprop_jump): If a conditional jump has been optimized
into unconditional jump, make the remaining normal edge fallthru
and delete the jump insn.

* gcc.dg/pr33673.c: New test.

From-SVN: r129819

gcc/ChangeLog
gcc/gcse.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr33673.c [new file with mode: 0644]

index 61d1e38d219a0e91f1711d1e2f6dc4065735b78c..0aa3b00c8b6ba20d1393551becfe693242a3bffa 100644 (file)
@@ -1,3 +1,10 @@
+2007-11-01  Jakub Jelinek  <jakub@redhat.com>
+
+       PR rtl-optimization/33673
+       * gcse.c (cprop_jump): If a conditional jump has been optimized
+       into unconditional jump, make the remaining normal edge fallthru
+       and delete the jump insn.
+
 2007-11-01  Ben Elliston  <bje@au.ibm.com>
 
        * emit-rtl.c (set_reg_attrs_from_mem): Clarify function comment.
index 79aa8afd31dd7656bf5cfcc9a2072a4bc9e7efec..a519acbf0545042e176e0c22ba73476c00cb246e 100644 (file)
@@ -2875,6 +2875,24 @@ cprop_jump (basic_block bb, rtx setcc, rtx jump, rtx from, rtx src)
     }
   purge_dead_edges (bb);
 
+  /* If a conditional jump has been changed into unconditional jump, remove
+     the jump and make the edge fallthru - this is always called in
+     cfglayout mode.  */
+  if (new != pc_rtx && simplejump_p (jump))
+    {
+      edge e;
+      edge_iterator ei;
+
+      for (ei = ei_start (bb->succs); (e = ei_safe_edge (ei)); ei_next (&ei))
+       if (e->dest != EXIT_BLOCK_PTR
+           && BB_HEAD (e->dest) == JUMP_LABEL (jump))
+         {
+           e->flags |= EDGE_FALLTHRU;
+           break;
+         }
+      delete_insn (jump);
+    }
+
   return 1;
 }
 
index 8332c432bebdcc2b7fe47fbf3c6bb3e7c27bf388..fd1f046ac218d218f810ce9351ad6fd44e5d90fb 100644 (file)
@@ -1,3 +1,8 @@
+2007-11-01  Jakub Jelinek  <jakub@redhat.com>
+
+       PR rtl-optimization/33673
+       * gcc.dg/pr33673.c: New test.
+
 2007-11-01  Michael Matz  <matz@suse.de>
 
        PR tree-optimization/33961
diff --git a/gcc/testsuite/gcc.dg/pr33673.c b/gcc/testsuite/gcc.dg/pr33673.c
new file mode 100644 (file)
index 0000000..d238d11
--- /dev/null
@@ -0,0 +1,43 @@
+/* PR rtl-optimization/33673 */
+/* { dg-do compile } */
+/* { dg-options "-Os -fno-forward-propagate -fno-guess-branch-probability -fno-move-loop-invariants -fno-tree-dominator-opts -fno-tree-loop-optimize" } */
+
+extern int f1 (int);
+extern int f2 (int);
+
+extern int *a;
+
+static void
+find_reg (int n)
+{
+  int i, pass;
+  unsigned int used[2], used1[2];
+
+  int c = n ? f1 (a[1]) : f2 (a[1]);
+
+  for (i = 64, pass = 0; pass <= 1 && i >= 64; pass++)
+    {
+      if (pass == 1)
+       {
+         unsigned int *scan_tp_ = used;
+         unsigned int *scan_fp_ = used1;
+         int j;
+         for (j = 0; j < 2; j++)
+           *scan_tp_++ = *scan_fp_++;
+       }
+      for (i = 0; i < 64; i++)
+       {
+         int regno = i;
+         if (n == 0)
+           if (i == regno)
+             break;
+       }
+    }
+}
+
+void
+global_alloc ()
+{
+  find_reg (0);
+  find_reg (1);
+}