aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.c-torture/compile/pr43066.c14
-rw-r--r--gcc/tree-sra.c2
4 files changed, 26 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index bb696ae..fc1135d 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2010-02-18 Martin Jambor <mjambor@suse.cz>
+
+ PR tree-optimization/43066
+ * tree-sra.c (build_ref_for_offset_1): Return false on encountering an
+ array with zero-sized element type.
+
2010-02-18 Jakub Jelinek <jakub@redhat.com>
* dwarf2out.c (add_var_loc_to_decl): Change last argument to
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 95f460c..9c82d35 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2010-02-18 Martin Jambor <mjambor@suse.cz>
+
+ PR tree-optimization/43066
+ * gcc.c-torture/compile/pr43066.c: New test.
+
2010-02-18 Uros Bizjak <ubizjak@gmail.com>
* g++.dg/ext/attrib35.C: Fix target selector string.
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr43066.c b/gcc/testsuite/gcc.c-torture/compile/pr43066.c
new file mode 100644
index 0000000..2ded912
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/pr43066.c
@@ -0,0 +1,14 @@
+struct S {
+ struct { } empty[1];
+ int i;
+};
+
+int foo(int i, ...)
+{
+ struct S s;
+ __builtin_va_list va;
+ __builtin_va_start(va, i);
+ s = __builtin_va_arg(va, struct S);
+ __builtin_va_end(va);
+ return s.i;
+}
diff --git a/gcc/tree-sra.c b/gcc/tree-sra.c
index 12b365f..86620e0 100644
--- a/gcc/tree-sra.c
+++ b/gcc/tree-sra.c
@@ -1432,7 +1432,7 @@ build_ref_for_offset_1 (tree *res, tree type, HOST_WIDE_INT offset,
el_size = tree_low_cst (tr_size, 1);
minidx = TYPE_MIN_VALUE (TYPE_DOMAIN (type));
- if (TREE_CODE (minidx) != INTEGER_CST)
+ if (TREE_CODE (minidx) != INTEGER_CST || el_size == 0)
return false;
if (res)
{