re PR rtl-optimization/46878 (V850 ICE in in maybe_add_or_update_dep_1, at sched...
authorDJ Delorie <dj@redhat.com>
Wed, 26 Jan 2011 22:03:47 +0000 (17:03 -0500)
committerDJ Delorie <dj@gcc.gnu.org>
Wed, 26 Jan 2011 22:03:47 +0000 (17:03 -0500)
PR rtl-optimization/46878
* combine.c (insn_a_feeds_b): Check for the implicit cc0
setter/user dependency as well.

* gcc.dg/pr46878-1.c: New test.

From-SVN: r169307

gcc/ChangeLog
gcc/combine.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr46878-1.c [new file with mode: 0644]

index fa574e8182502d3625fc36ee116ce4e7ae58109e..67ce1d2bd69400d90bf717f7e61aa988e27a03f3 100644 (file)
@@ -1,3 +1,9 @@
+2011-01-26  DJ Delorie  <dj@redhat.com>
+
+       PR rtl-optimization/46878
+       * combine.c (insn_a_feeds_b): Check for the implicit cc0
+       setter/user dependency as well.
+
 2011-01-26  Eric Botcazou  <ebotcazou@adacore.com>
 
        PR rtl-optimization/44469
index 3ee53e6ccd9637b915cd5a7511b75f1ff91b3e0c..4fe71f334174822cbe9c0a7f7ea1ee4063f7f5bb 100644 (file)
@@ -1032,7 +1032,9 @@ clear_log_links (void)
 /* Walk the LOG_LINKS of insn B to see if we find a reference to A.  Return
    true if we found a LOG_LINK that proves that A feeds B.  This only works
    if there are no instructions between A and B which could have a link
-   depending on A, since in that case we would not record a link for B.  */
+   depending on A, since in that case we would not record a link for B.
+   We also check the implicit dependency created by a cc0 setter/user
+   pair.  */
 
 static bool
 insn_a_feeds_b (rtx a, rtx b)
@@ -1041,6 +1043,10 @@ insn_a_feeds_b (rtx a, rtx b)
   for (links = LOG_LINKS (b); links; links = XEXP (links, 1))
     if (XEXP (links, 0) == a)
       return true;
+#ifdef HAVE_cc0
+  if (sets_cc0_p (a))
+    return true;
+#endif
   return false;
 }
 \f
index 527b3ed676f5e1c8a990b78a7c343b9c1bf3b333..a4ed36535de4983aab37db6a3b2bc1935ae9d1e2 100644 (file)
@@ -1,3 +1,8 @@
+2011-01-26  DJ Delorie  <dj@redhat.com>
+
+       PR rtl-optimization/46878
+       * gcc.dg/pr46878-1.c: New test.
+
 2011-01-26  Jakub Jelinek  <jakub@redhat.com>
 
        PR c++/47476
diff --git a/gcc/testsuite/gcc.dg/pr46878-1.c b/gcc/testsuite/gcc.dg/pr46878-1.c
new file mode 100644 (file)
index 0000000..f5b42de
--- /dev/null
@@ -0,0 +1,30 @@
+/* PR rtl-optimization/46878 */
+/* Make sure this doesn't ICE.  */
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+
+struct baz
+{
+  int *newp;
+};
+
+int
+get_ice (int *op, struct baz *ret)
+{
+  int *tmpp;
+  int c;
+  c = (__foo () != 1);
+  if (__bar ())
+    {
+      return (1);
+    }
+  if (c)
+    tmpp = op;
+  if (tmpp)
+    {
+    }
+  else if (c)
+    {
+      ret->newp = tmpp;
+    }
+}