From: Roger Sayle Date: Sun, 14 May 2006 16:07:12 +0000 (+0000) Subject: re PR rtl-optimization/27538 (execute/20030128-1.c FAILs) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=56106c2ed0a3d5e312d14656f475abb9a3de7b9d;p=gcc.git re PR rtl-optimization/27538 (execute/20030128-1.c FAILs) PR rtl-optimization/27538 * combine.c (expand_compound_operation): Call gen_lowpart before calling simplify_shift_const. From-SVN: r113763 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1c6df66f205..c5ed8fc4ce5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2006-05-14 Roger Sayle + + PR rtl-optimization/27538 + * combine.c (expand_compound_operation): Call gen_lowpart + before calling simplify_shift_const. + 2006-05-14 Roger Sayle PR rtl-optimization/22563 diff --git a/gcc/combine.c b/gcc/combine.c index ed9c497e7d5..33512ec4635 100644 --- a/gcc/combine.c +++ b/gcc/combine.c @@ -5736,14 +5736,16 @@ expand_compound_operation (rtx x) modewidth = GET_MODE_BITSIZE (GET_MODE (x)); if (modewidth + len >= pos) - tem = simplify_shift_const (NULL_RTX, unsignedp ? LSHIFTRT : ASHIFTRT, - GET_MODE (x), - simplify_shift_const (NULL_RTX, ASHIFT, - GET_MODE (x), - XEXP (x, 0), - modewidth - pos - len), - modewidth - len); - + { + enum machine_mode mode = GET_MODE (x); + tem = gen_lowpart (mode, XEXP (x, 0)); + if (!tem || GET_CODE (tem) == CLOBBER) + return x; + tem = simplify_shift_const (NULL_RTX, ASHIFT, mode, + tem, modewidth - pos - len); + tem = simplify_shift_const (NULL_RTX, unsignedp ? LSHIFTRT : ASHIFTRT, + mode, tem, modewidth - len); + } else if (unsignedp && len < HOST_BITS_PER_WIDE_INT) tem = simplify_and_const_int (NULL_RTX, GET_MODE (x), simplify_shift_const (NULL_RTX, LSHIFTRT,