From: Jakub Jelinek Date: Sun, 26 May 2002 19:59:45 +0000 (+0200) Subject: cse.c (fold_rtx): Don't optimize if SUBREG changes mode class. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=9059e33cbbb601ed3a7f36d62a4dc7600b72bc60;p=gcc.git cse.c (fold_rtx): Don't optimize if SUBREG changes mode class. * cse.c (fold_rtx): Don't optimize if SUBREG changes mode class. * g++.dg/opt/cse2.C: New test. From-SVN: r53905 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b5298d5f5fe..800233d43db 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2002-05-26 Jakub Jelinek + + * cse.c (fold_rtx): Don't optimize if SUBREG changes mode class. + 2002-05-26 Andreas Jaeger * cfg.c (dump_flow_info): Remove extra argument to fprintf. diff --git a/gcc/cse.c b/gcc/cse.c index 9cc048b85f0..0b91d99d448 100644 --- 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)); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 51e46fb12f0..0b8b5f15fba 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2002-05-26 Jakub Jelinek + + * g++.dg/opt/cse2.C: New test. + 2002-05-26 Neil Booth * 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 index 00000000000..5a04bf53ecb --- /dev/null +++ b/gcc/testsuite/g++.dg/opt/cse2.C @@ -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); +}