aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2016-01-14 16:10:41 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2016-01-14 16:10:41 +0100
commita2ae4661ab37d05dc2610fb8bc1a6a32b2928748 (patch)
treee5b9d9876fb957027d6e8ec87808b576556c7808
parent21f88b7a131e29d1835dea1dd431ba939680878c (diff)
downloadgcc-a2ae4661ab37d05dc2610fb8bc1a6a32b2928748.zip
gcc-a2ae4661ab37d05dc2610fb8bc1a6a32b2928748.tar.gz
gcc-a2ae4661ab37d05dc2610fb8bc1a6a32b2928748.tar.bz2
re PR target/68269 (FAIL: gcc.dg/pr68129_1.c (internal compiler error))
PR target/68269 * combine.c (expand_field_assignment): Punt if compute_mode is unsupported scalar mode. From-SVN: r232366
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/combine.c4
2 files changed, 10 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 4cf1e81..fe9a60a 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2016-01-14 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/68269
+ * combine.c (expand_field_assignment): Punt if compute_mode is
+ unsupported scalar mode.
+
2016-01-14 Richard Biener <rguenther@suse.de>
PR tree-optimization/66856
diff --git a/gcc/combine.c b/gcc/combine.c
index d088031..2f913dd 100644
--- a/gcc/combine.c
+++ b/gcc/combine.c
@@ -7247,6 +7247,10 @@ expand_field_assignment (const_rtx x)
if (len >= HOST_BITS_PER_WIDE_INT)
break;
+ /* Don't try to compute in too wide unsupported modes. */
+ if (!targetm.scalar_mode_supported_p (compute_mode))
+ break;
+
/* Now compute the equivalent expression. Make a copy of INNER
for the SET_DEST in case it is a MEM into which we will substitute;
we don't want shared RTL in that case. */