annotate gcc/testsuite/gcc.dg/pr64536.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* PR rtl-optimization/64536 */
kono
parents:
diff changeset
2 /* { dg-do link } */
kono
parents:
diff changeset
3 /* { dg-options "-O2" } */
kono
parents:
diff changeset
4 /* { dg-additional-options "-fPIC" { target fpic } } */
kono
parents:
diff changeset
5 /* { dg-require-effective-target ptr32plus } */
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 struct S { long q; } *h;
kono
parents:
diff changeset
8 long a, b, g, j, k, *c, *d, *e, *f, *i;
kono
parents:
diff changeset
9 long *baz (void)
kono
parents:
diff changeset
10 {
kono
parents:
diff changeset
11 asm volatile ("" : : : "memory");
kono
parents:
diff changeset
12 return e;
kono
parents:
diff changeset
13 }
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 void
kono
parents:
diff changeset
16 bar (int x)
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 int y;
kono
parents:
diff changeset
19 for (y = 0; y < x; y++)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 switch (b)
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 case 0:
kono
parents:
diff changeset
24 case 2:
kono
parents:
diff changeset
25 a++;
kono
parents:
diff changeset
26 break;
kono
parents:
diff changeset
27 case 3:
kono
parents:
diff changeset
28 a++;
kono
parents:
diff changeset
29 break;
kono
parents:
diff changeset
30 case 1:
kono
parents:
diff changeset
31 a++;
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33 if (d)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 f = baz ();
kono
parents:
diff changeset
36 g = k++;
kono
parents:
diff changeset
37 if (&h->q)
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 j = *f;
kono
parents:
diff changeset
40 h->q = *f;
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42 else
kono
parents:
diff changeset
43 i = (long *) (h->q = *f);
kono
parents:
diff changeset
44 *c++ = (long) f;
kono
parents:
diff changeset
45 e += 6;
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47 else
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 f = baz ();
kono
parents:
diff changeset
50 g = k++;
kono
parents:
diff changeset
51 if (&h->q)
kono
parents:
diff changeset
52 {
kono
parents:
diff changeset
53 j = *f;
kono
parents:
diff changeset
54 h->q = *f;
kono
parents:
diff changeset
55 }
kono
parents:
diff changeset
56 else
kono
parents:
diff changeset
57 i = (long *) (h->q = *f);
kono
parents:
diff changeset
58 *c++ = (long) f;
kono
parents:
diff changeset
59 e += 6;
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62 }
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 int
kono
parents:
diff changeset
65 main ()
kono
parents:
diff changeset
66 {
kono
parents:
diff changeset
67 return 0;
kono
parents:
diff changeset
68 }