annotate gcc/testsuite/gcc.dg/20020310-1.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* PR optimization/5844
kono
parents:
diff changeset
2 This testcase was miscompiled because of an rtx sharing bug. */
kono
parents:
diff changeset
3 /* { dg-do run } */
kono
parents:
diff changeset
4 /* { dg-options "-O2" } */
kono
parents:
diff changeset
5 /* { dg-options "-O2 -mtune=i586" { target { { i?86-*-* x86_64-*-* } && ia32 } } } */
kono
parents:
diff changeset
6 /* { dg-xfail-if "doesn't support self-referential initializers" { nvptx-*-* } } */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 struct A
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 struct A *a;
kono
parents:
diff changeset
11 int b;
kono
parents:
diff changeset
12 };
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 struct B
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 struct A *c;
kono
parents:
diff changeset
17 unsigned int d;
kono
parents:
diff changeset
18 };
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 struct A p = { &p, -1 };
kono
parents:
diff changeset
21 struct B q = { &p, 0 };
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 extern void abort (void);
kono
parents:
diff changeset
24 extern void exit (int);
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 struct B *
kono
parents:
diff changeset
27 foo (void)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 return &q;
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 void
kono
parents:
diff changeset
33 bar (void)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 struct B *e = foo ();
kono
parents:
diff changeset
36 struct A *f = e->c;
kono
parents:
diff changeset
37 int g = f->b;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 if (++g == 0)
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 e->d++;
kono
parents:
diff changeset
42 e->c = f->a;
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 f->b = g;
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 int
kono
parents:
diff changeset
49 main ()
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 bar ();
kono
parents:
diff changeset
52 if (p.b != 0 || q.d != 1 || q.c != &p)
kono
parents:
diff changeset
53 abort ();
kono
parents:
diff changeset
54 exit (0);
kono
parents:
diff changeset
55 }