Commit b188ebb1 by Richard Henderson Committed by Richard Henderson

re PR target/17692 (ICE splitting sse conditional move)

        PR target/17692
        * config/i386/i386.c (ix86_split_sse_movcc): Emit DELETED note
        when expanding to nothing.

From-SVN: r102509
parent baa92306
2005-07-28 Richard Henderson <rth@redhat.com>
PR target/17692
* config/i386/i386.c (ix86_split_sse_movcc): Emit DELETED note
when expanding to nothing.
2005-07-28 Josh Conner <jconner@apple.com> 2005-07-28 Josh Conner <jconner@apple.com>
* ipa-inline.c (update_caller_keys): Fix estimated_growth caching. * ipa-inline.c (update_caller_keys): Fix estimated_growth caching.
......
/* { dg-do compile } */
/* { dg-options "-O -mfpmath=sse -msse2" } */
/* The fact that t1 and t2 are uninitialized is critical. With them
uninitialized, the register allocator is free to put them in the same
hard register, which results in
xmm0 = xmm0 >= xmm0 ? xmm0 : xmm0
Which is of course a nop, but one for which we would ICE splitting the
pattern. */
double out;
static void foo(void)
{
double t1, t2, t3, t4;
t4 = t1 >= t2 ? t1 : t2;
t4 = t4 >= t3 ? t4 : t3;
out = t4;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment