aboutsummaryrefslogtreecommitdiff
path: root/gcc/gimple-fold.c
diff options
context:
space:
mode:
authorMarek Polacek <polacek@redhat.com>2014-01-17 14:51:56 +0000
committerMarek Polacek <mpolacek@gcc.gnu.org>2014-01-17 14:51:56 +0000
commit30078c0a6521519cd18090edb554c62e8d9c1a8a (patch)
tree07068f367f80f8bc0e8385c4425d17154f983d33 /gcc/gimple-fold.c
parent14379e666810cff69f620fbad5a44ce2d68486c3 (diff)
downloadgcc-30078c0a6521519cd18090edb554c62e8d9c1a8a.zip
gcc-30078c0a6521519cd18090edb554c62e8d9c1a8a.tar.gz
gcc-30078c0a6521519cd18090edb554c62e8d9c1a8a.tar.bz2
re PR c/58346 (ICE with SIGFPE at -O1 and above on x86_64-linux-gnu (affecting trunk, 4.8, 4.7, and 4.6))
PR c/58346 * gimple-fold.c (fold_array_ctor_reference): Don't fold if element size is zero. testsuite/ * gcc.dg/pr58346.c: New test. From-SVN: r206715
Diffstat (limited to 'gcc/gimple-fold.c')
-rw-r--r--gcc/gimple-fold.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/gimple-fold.c b/gcc/gimple-fold.c
index 5dc27e1..bace6f8 100644
--- a/gcc/gimple-fold.c
+++ b/gcc/gimple-fold.c
@@ -2940,7 +2940,8 @@ fold_array_ctor_reference (tree type, tree ctor,
be larger than size of array element. */
if (!TYPE_SIZE_UNIT (type)
|| TREE_CODE (TYPE_SIZE_UNIT (type)) != INTEGER_CST
- || elt_size.slt (tree_to_double_int (TYPE_SIZE_UNIT (type))))
+ || elt_size.slt (tree_to_double_int (TYPE_SIZE_UNIT (type)))
+ || elt_size.is_zero ())
return NULL_TREE;
/* Compute the array index we look for. */