aboutsummaryrefslogtreecommitdiff
path: root/gcc/rtlhooks.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2018-04-17 11:16:48 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2018-04-17 11:16:48 +0200
commit50ffe7adc0d686e9f193c4e53ea2f0d617309f35 (patch)
tree3afce06c88ff6ba31c34a8e72d514a9a1d9bb56a /gcc/rtlhooks.c
parent5bf31c642ec176701629edc19504b79be3c12ee5 (diff)
downloadgcc-50ffe7adc0d686e9f193c4e53ea2f0d617309f35.zip
gcc-50ffe7adc0d686e9f193c4e53ea2f0d617309f35.tar.gz
gcc-50ffe7adc0d686e9f193c4e53ea2f0d617309f35.tar.bz2
re PR middle-end/85414 (ICE: in ix86_expand_prologue, at config/i386/i386.c:13810 with -Og -fgcse)
PR middle-end/85414 * rtlhooks.c (gen_lowpart_if_possible): Don't call gen_lowpart_SUBREG on a SUBREG. * gcc.dg/pr85414.c: New test. From-SVN: r259433
Diffstat (limited to 'gcc/rtlhooks.c')
-rw-r--r--gcc/rtlhooks.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/gcc/rtlhooks.c b/gcc/rtlhooks.c
index ecdebbb..5914550 100644
--- a/gcc/rtlhooks.c
+++ b/gcc/rtlhooks.c
@@ -123,9 +123,9 @@ gen_lowpart_if_possible (machine_mode mode, rtx x)
return new_rtx;
}
- else if (mode != GET_MODE (x) && GET_MODE (x) != VOIDmode
+ else if (mode != GET_MODE (x) && GET_MODE (x) != VOIDmode && !SUBREG_P (x)
&& validate_subreg (mode, GET_MODE (x), x,
- subreg_lowpart_offset (mode, GET_MODE (x))))
+ subreg_lowpart_offset (mode, GET_MODE (x))))
return gen_lowpart_SUBREG (mode, x);
else
return 0;