]> gcc.gnu.org Git - gcc.git/commitdiff
cse.c (fold_rtx): Don't optimize if SUBREG changes mode class.
authorJakub Jelinek <jakub@redhat.com>
Sun, 26 May 2002 19:59:45 +0000 (21:59 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Sun, 26 May 2002 19:59:45 +0000 (21:59 +0200)
* cse.c (fold_rtx): Don't optimize if SUBREG changes mode class.

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

From-SVN: r53905

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

index b5298d5f5fef43951b394f5d6ac02833c683f38a..800233d43db321452b05aa09000d9651f9b4626a 100644 (file)
@@ -1,3 +1,7 @@
+2002-05-26  Jakub Jelinek  <jakub@redhat.com>
+
+       * cse.c (fold_rtx): Don't optimize if SUBREG changes mode class.
+
 2002-05-26  Andreas Jaeger  <aj@suse.de>
 
        * cfg.c (dump_flow_info): Remove extra argument to fprintf.
index 9cc048b85f0f416b9d02288ae6dd267f7339f1bb..0b91d99d44894406c2d46654ff0f17db642481fa 100644 (file)
--- a/gcc/cse.c
+++ b/gcc/cse.c
@@ -3472,7 +3472,9 @@ fold_rtx (x, insn)
                  && GET_CODE (elt->exp) != SIGN_EXTEND
                  && GET_CODE (elt->exp) != ZERO_EXTEND
                  && GET_CODE (XEXP (elt->exp, 0)) == SUBREG
-                 && GET_MODE (SUBREG_REG (XEXP (elt->exp, 0))) == mode)
+                 && GET_MODE (SUBREG_REG (XEXP (elt->exp, 0))) == mode
+                 && (GET_MODE_CLASS (mode)
+                     == GET_MODE_CLASS (GET_MODE (XEXP (elt->exp, 0)))))
                {
                  rtx op0 = SUBREG_REG (XEXP (elt->exp, 0));
 
index 51e46fb12f029bc09a6af2ff860849fa9c504792..0b8b5f15fba1f4aba9004ec295541d550c50080a 100644 (file)
@@ -1,3 +1,7 @@
+2002-05-26  Jakub Jelinek  <jakub@redhat.com>
+
+       * g++.dg/opt/cse2.C: New test.
+
 2002-05-26  Neil Booth  <neil@daikokuya.demon.co.uk>
 
        * gcc.dg/cpp/arith-1.c: New semantic tests.
diff --git a/gcc/testsuite/g++.dg/opt/cse2.C b/gcc/testsuite/g++.dg/opt/cse2.C
new file mode 100644 (file)
index 0000000..5a04bf5
--- /dev/null
@@ -0,0 +1,39 @@
+// This testcase caused ICE on IA-32 in simplify_unary_operation
+// CSE did not assume SUBREGs changing mode from integral to floating.
+// { dg-do run { target i?86-*-* sparc*-*-* } }
+// { dg-options "-O2" }
+
+struct A
+{
+  union
+    {
+      float f;
+      unsigned int w;
+    } a;
+
+  static inline const A foo (void)
+    {
+      return A ((unsigned int) (__extension__ ((union { unsigned l; float d; })
+                                              { l: 0x3f800000 }).d));
+    }
+  inline A (float f) { a.f = f; }
+  A ();
+  inline A (unsigned int w) { a.w = w; }
+};
+
+A::A()
+{
+  *this = foo ();
+}
+
+A a;
+
+extern "C" void abort (void);
+extern "C" void exit (int);
+
+int main ()
+{
+  if (a.a.w != 1)
+    abort ();
+  exit (0);
+}
This page took 2.001339 seconds and 5 git commands to generate.