aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.c-torture/execute/20071219-1.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2007-12-20 16:09:54 +0000
committerJakub Jelinek <jakub@redhat.com>2007-12-20 16:09:54 +0000
commitedeea36425037a03cb28ff88309f75a630972138 (patch)
treeb90cfb44e0146a12ac35158675e84436f9ce9491 /gcc/testsuite/gcc.c-torture/execute/20071219-1.c
parent7f75912afb9803aa40901f90dd7104dc1f1ab75c (diff)
svn merge -r130787:131101 svn+ssh://gcc.gnu.org/svn/gcc/trunk/
git-svn-id: https://gcc.gnu.org/svn/gcc/branches/redhat/gcc-4_3-branch@131103 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/testsuite/gcc.c-torture/execute/20071219-1.c')
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/20071219-1.c71
1 files changed, 71 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.c-torture/execute/20071219-1.c b/gcc/testsuite/gcc.c-torture/execute/20071219-1.c
new file mode 100644
index 00000000000..4152711a304
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/20071219-1.c
@@ -0,0 +1,71 @@
+/* PR c++/34459 */
+
+extern void abort (void);
+extern void *memset (void *s, int c, __SIZE_TYPE__ n);
+
+struct S
+{
+ char s[25];
+};
+
+struct S *p;
+
+void __attribute__((noinline))
+foo (struct S *x, int set)
+{
+ int i;
+ for (i = 0; i < sizeof (x->s); ++i)
+ if (x->s[i] != 0)
+ abort ();
+ else if (set)
+ x->s[i] = set;
+ p = x;
+}
+
+void __attribute__((noinline))
+test1 (void)
+{
+ struct S a;
+ memset (&a.s, '\0', sizeof (a.s));
+ foo (&a, 0);
+ struct S b = a;
+ foo (&b, 1);
+ b = a;
+ b = b;
+ foo (&b, 0);
+}
+
+void __attribute__((noinline))
+test2 (void)
+{
+ struct S a;
+ memset (&a.s, '\0', sizeof (a.s));
+ foo (&a, 0);
+ struct S b = a;
+ foo (&b, 1);
+ b = a;
+ b = *p;
+ foo (&b, 0);
+}
+
+void __attribute__((noinline))
+test3 (void)
+{
+ struct S a;
+ memset (&a.s, '\0', sizeof (a.s));
+ foo (&a, 0);
+ struct S b = a;
+ foo (&b, 1);
+ *p = a;
+ *p = b;
+ foo (&b, 0);
+}
+
+int
+main (void)
+{
+ test1 ();
+ test2 ();
+ test3 ();
+ return 0;
+}