aboutsummaryrefslogtreecommitdiff
path: root/gcc/expr.c
diff options
context:
space:
mode:
authorUros Bizjak <uros@gcc.gnu.org>2009-09-09 21:25:31 +0200
committerUros Bizjak <uros@gcc.gnu.org>2009-09-09 21:25:31 +0200
commited9d5a4a1a6e2d9660759164556ceaa7dec1da14 (patch)
treeb456b7854cccbfd703167da199781923fe249c39 /gcc/expr.c
parent3d887721064c855f5743b0d8884642b39b44c9ab (diff)
downloadgcc-ed9d5a4a1a6e2d9660759164556ceaa7dec1da14.zip
gcc-ed9d5a4a1a6e2d9660759164556ceaa7dec1da14.tar.gz
gcc-ed9d5a4a1a6e2d9660759164556ceaa7dec1da14.tar.bz2
re PR c/39779 (ICE shifting byte to the right with constant > 7FFFFFFF)
PR rtl-optimization/39779 * expr.c (convert_modes): Return when mode == oldmode after CONST_INTs are processed. testsuite/ChangeLog: PR rtl-optimization/39779 * gcc.dg/pr39979.c: New test. From-SVN: r151573
Diffstat (limited to 'gcc/expr.c')
-rw-r--r--gcc/expr.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/gcc/expr.c b/gcc/expr.c
index cd5eae1..fe74280 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -761,9 +761,6 @@ convert_modes (enum machine_mode mode, enum machine_mode oldmode, rtx x, int uns
if (GET_MODE (x) != VOIDmode)
oldmode = GET_MODE (x);
- if (mode == oldmode)
- return x;
-
/* There is one case that we must handle specially: If we are converting
a CONST_INT into a mode whose size is twice HOST_BITS_PER_WIDE_INT and
we are to interpret the constant as unsigned, gen_lowpart will do
@@ -829,6 +826,9 @@ convert_modes (enum machine_mode mode, enum machine_mode oldmode, rtx x, int uns
return gen_lowpart (mode, x);
}
+ if (mode == oldmode)
+ return x;
+
/* Converting from integer constant into mode is always equivalent to an
subreg operation. */
if (VECTOR_MODE_P (mode) && GET_MODE (x) == VOIDmode)