aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2005-01-15 00:45:59 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2005-01-15 00:45:59 +0100
commit74aad7cc3cfb851fd1c0c08a037592b6014f884d (patch)
treea332770c734ad531043bf6d87a35a0e409703ebe /gcc
parent28bbb5504dbca4a972b8f3a9538acd280c18c3fc (diff)
downloadgcc-74aad7cc3cfb851fd1c0c08a037592b6014f884d.zip
gcc-74aad7cc3cfb851fd1c0c08a037592b6014f884d.tar.gz
gcc-74aad7cc3cfb851fd1c0c08a037592b6014f884d.tar.bz2
re PR c++/19263 (wrong-code: explicit initialization of v8qi miscompiled)
PR c++/19263 * typeck2.c (split_nonconstant_init_1) <case VECTOR_TYPE>: Put a copy of CONSTRUCTOR's node into MODIFY_EXPR, as the original is modified. * g++.dg/init/vector1.C: New test. From-SVN: r93672
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/typeck2.c3
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/init/vector1.C78
4 files changed, 91 insertions, 1 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 89207d3..b5e9d32 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2005-01-15 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/19263
+ * typeck2.c (split_nonconstant_init_1) <case VECTOR_TYPE>: Put a copy
+ of CONSTRUCTOR's node into MODIFY_EXPR, as the original is modified.
+
2005-01-12 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
* Make-lang.in (cp-warn): Don't append $(WERROR).
diff --git a/gcc/cp/typeck2.c b/gcc/cp/typeck2.c
index 8d97e45..7edfdd2 100644
--- a/gcc/cp/typeck2.c
+++ b/gcc/cp/typeck2.c
@@ -506,8 +506,9 @@ split_nonconstant_init_1 (tree dest, tree init)
case VECTOR_TYPE:
if (!initializer_constant_valid_p (init, type))
{
+ tree cons = copy_node (init);
CONSTRUCTOR_ELTS (init) = NULL;
- code = build2 (MODIFY_EXPR, type, dest, init);
+ code = build2 (MODIFY_EXPR, type, dest, cons);
code = build_stmt (EXPR_STMT, code);
add_stmt (code);
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b0e7898..8024db3 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2005-01-15 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/19263
+ * g++.dg/init/vector1.C: New test.
+
2005-01-14 James E. Wilson <wilson@specifixinc.com>
PR target/13158
diff --git a/gcc/testsuite/g++.dg/init/vector1.C b/gcc/testsuite/g++.dg/init/vector1.C
new file mode 100644
index 0000000..ce4f40c
--- /dev/null
+++ b/gcc/testsuite/g++.dg/init/vector1.C
@@ -0,0 +1,78 @@
+// PR c++/19263
+// { dg-do run }
+// { dg-options "-O2" }
+
+typedef signed char v8qi __attribute__ ((vector_size (8)));
+
+extern "C" void abort (void);
+
+static unsigned char S[16];
+
+struct A
+{
+ int i;
+ v8qi j, k;
+ int l;
+};
+
+void
+foo (unsigned char v)
+{
+ A a = { 1, { v, v, v, v, v, v, v, v },
+ { v + 1, v + 1, v + 1, v + 1, v + 1, v + 1, v + 1, v + 1 }, 3 };
+ v8qi *s = (v8qi *) &S[0];
+ *s = a.j;
+ s[1] = a.k;
+}
+
+void
+bar (unsigned char v)
+{
+ v8qi val8 = { v, v, v, v, v, v, v, v };
+ v8qi *s = (v8qi *) &S[0];
+ *s = val8;
+}
+
+int n = 5, cnt;
+
+int
+num (void)
+{
+ ++cnt;
+ return n;
+}
+
+void
+baz (void)
+{
+ static A a = { 0, { num (), num (), num (), num (), 6, 6, 6, 6 },
+ { 7, 7, 7, 7, 8, 8, 8, 8 }, 0 };
+ v8qi *s = (v8qi *) &S[0];
+ *s = a.j;
+ s[1] = a.k;
+}
+
+int
+main ()
+{
+ int i;
+ foo (1);
+ for (i = 0; i < 8; ++i)
+ if (S[i] != 1)
+ abort ();
+ for (; i < 16; ++i)
+ if (S[i] != 2)
+ abort ();
+ bar (3);
+ for (i = 0; i < 8; ++i)
+ if (S[i] != 3)
+ abort ();
+ return 0;
+ baz ();
+ if (cnt != 4)
+ abort ();
+ for (i = 0; i < 16; ++i)
+ if (S[i] != 5 + (i / 4))
+ abort ();
+ return 0;
+}