]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR middle-end/60597 (ICE in df_refs_verify, at df-scan.c:4323)
authorJakub Jelinek <jakub@redhat.com>
Thu, 20 Mar 2014 19:47:09 +0000 (20:47 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Thu, 20 Mar 2014 19:47:09 +0000 (20:47 +0100)
PR middle-end/60597
* ira.c (adjust_cleared_regs): Call copy_rtx on
*reg_equiv[REGNO (loc)].src_p before passing it to
simplify_replace_fn_rtx.

* g++.dg/opt/pr60597.C: New test.

From-SVN: r208735

gcc/ChangeLog
gcc/ira.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/opt/pr60597.C [new file with mode: 0644]

index bc43ad231f12699542e29401c35b0c2f77ec02fe..6821c91516da5229248f9d5e9912db0ce8c3241e 100644 (file)
@@ -1,5 +1,10 @@
 2014-03-20  Jakub Jelinek  <jakub@redhat.com>
 
+       PR middle-end/60597
+       * ira.c (adjust_cleared_regs): Call copy_rtx on
+       *reg_equiv[REGNO (loc)].src_p before passing it to
+       simplify_replace_fn_rtx.
+
        PR target/60568
        * config/i386/i386.c (x86_output_mi_thunk): Surround UNSPEC_GOT
        into CONST, put pic register as first operand of PLUS.  Use
index 7c49b7f6b744295b80d0b35534f656358ac32204..4d91d2196a631e41468daaef5fbb8ed977e1802f 100644 (file)
--- a/gcc/ira.c
+++ b/gcc/ira.c
@@ -3428,7 +3428,7 @@ adjust_cleared_regs (rtx loc, const_rtx old_rtx ATTRIBUTE_UNUSED, void *data)
     {
       bitmap cleared_regs = (bitmap) data;
       if (bitmap_bit_p (cleared_regs, REGNO (loc)))
-       return simplify_replace_fn_rtx (*reg_equiv[REGNO (loc)].src_p,
+       return simplify_replace_fn_rtx (copy_rtx (*reg_equiv[REGNO (loc)].src_p),
                                        NULL_RTX, adjust_cleared_regs, data);
     }
   return NULL_RTX;
index 3cadcfea47ca9ea1bd01cd57379aed96e015cde2..2475787808c9e98780de8cc9a8403a669861f3c2 100644 (file)
@@ -1,5 +1,8 @@
 2014-03-20  Jakub Jelinek  <jakub@redhat.com>
 
+       PR middle-end/60597
+       * g++.dg/opt/pr60597.C: New test.
+
        PR c++/60572
        * g++.dg/init/pr60572.C: New test.
 
diff --git a/gcc/testsuite/g++.dg/opt/pr60597.C b/gcc/testsuite/g++.dg/opt/pr60597.C
new file mode 100644 (file)
index 0000000..c61f767
--- /dev/null
@@ -0,0 +1,46 @@
+// PR middle-end/60597
+// { dg-do compile }
+// { dg-options "-O2 -g" }
+
+struct A
+{
+  int foo () const;
+  int bar () const;
+  int a;
+};
+
+struct B
+{
+  int foo ();
+  int bar ();
+};
+
+int *c, d;
+
+int
+A::foo () const
+{
+  int b = a >> 16;
+  return b;
+}
+
+int
+A::bar () const
+{
+  int b = a;
+  return b;
+}
+
+void
+baz (A &x, B h, int i, int j)
+{
+  for (; i < h.bar (); ++i)
+    for (; h.foo (); ++j)
+      {
+       int g = x.foo ();
+       int f = x.bar ();
+       int e = c[0] & 1;
+       d = (e << 1) | (g << 16) | (f & 1);
+       c[j] = 0;
+      }
+}