annotate gcc/testsuite/gcc.dg/tree-ssa/loop-25.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 /* { dg-do compile } */
kono
parents:
diff changeset
2 /* { dg-options "-O1 -fdump-tree-profile_estimate" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 int foo(void);
kono
parents:
diff changeset
5 void bla(void);
kono
parents:
diff changeset
6 void bar(void);
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 void test1 (void)
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 unsigned i;
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 /* Only one loop should be found here. */
kono
parents:
diff changeset
13 i = 0;
kono
parents:
diff changeset
14 while (1)
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 i++;
kono
parents:
diff changeset
17 if (i == 100)
kono
parents:
diff changeset
18 break;
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 if (foo ())
kono
parents:
diff changeset
21 bla ();
kono
parents:
diff changeset
22 else
kono
parents:
diff changeset
23 bar ();
kono
parents:
diff changeset
24 }
kono
parents:
diff changeset
25 }
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 void test2 (void)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 unsigned i, j;
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 /* Two loops should be found, in this case. */
kono
parents:
diff changeset
32 i = j = 0;
kono
parents:
diff changeset
33 while (1)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 j++;
kono
parents:
diff changeset
36 foo ();
kono
parents:
diff changeset
37 if (j < 100)
kono
parents:
diff changeset
38 continue;
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 i++;
kono
parents:
diff changeset
41 j = 0;
kono
parents:
diff changeset
42 if (i == 100)
kono
parents:
diff changeset
43 break;
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 void test3 (void)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 unsigned i, j, k;
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 /* Three loops. */
kono
parents:
diff changeset
52 i = j = k = 0;
kono
parents:
diff changeset
53 while (1)
kono
parents:
diff changeset
54 {
kono
parents:
diff changeset
55 j++;
kono
parents:
diff changeset
56 foo ();
kono
parents:
diff changeset
57 if (j < 100)
kono
parents:
diff changeset
58 continue;
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 j = 0;
kono
parents:
diff changeset
61 k++;
kono
parents:
diff changeset
62 if (k < 100)
kono
parents:
diff changeset
63 continue;
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 k = 0;
kono
parents:
diff changeset
66 i++;
kono
parents:
diff changeset
67 if (i == 100)
kono
parents:
diff changeset
68 break;
kono
parents:
diff changeset
69 }
kono
parents:
diff changeset
70 }
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 void test4 (void)
kono
parents:
diff changeset
73 {
kono
parents:
diff changeset
74 unsigned i, j, k;
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 /* Two loops with a nested subloop. */
kono
parents:
diff changeset
77 i = j = 0;
kono
parents:
diff changeset
78 while (1)
kono
parents:
diff changeset
79 {
kono
parents:
diff changeset
80 j++;
kono
parents:
diff changeset
81 foo ();
kono
parents:
diff changeset
82 for (k = 0; k < 100; k++)
kono
parents:
diff changeset
83 foo ();
kono
parents:
diff changeset
84
kono
parents:
diff changeset
85 if (j < 100)
kono
parents:
diff changeset
86 continue;
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 i++;
kono
parents:
diff changeset
89 j = 0;
kono
parents:
diff changeset
90 if (i == 100)
kono
parents:
diff changeset
91 break;
kono
parents:
diff changeset
92 }
kono
parents:
diff changeset
93 }
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 void test5 (void)
kono
parents:
diff changeset
97 {
kono
parents:
diff changeset
98 unsigned i, j;
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 /* Both subloop and non-subloop back edges. */
kono
parents:
diff changeset
101 i = j = 0;
kono
parents:
diff changeset
102 while (1)
kono
parents:
diff changeset
103 {
kono
parents:
diff changeset
104 j++;
kono
parents:
diff changeset
105 foo ();
kono
parents:
diff changeset
106 if (j < 100)
kono
parents:
diff changeset
107 continue;
kono
parents:
diff changeset
108 j = 0;
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 i++;
kono
parents:
diff changeset
111 if (i == 100)
kono
parents:
diff changeset
112 break;
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 if (foo ())
kono
parents:
diff changeset
115 bla ();
kono
parents:
diff changeset
116 else
kono
parents:
diff changeset
117 bar ();
kono
parents:
diff changeset
118 }
kono
parents:
diff changeset
119 }
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 /* { dg-final { scan-tree-dump-times "Disambiguating loop" 5 "profile_estimate" } } */
kono
parents:
diff changeset
122 /* For the following xfail marks, see PR35629. */
kono
parents:
diff changeset
123 /* { dg-final { scan-tree-dump-times "Found latch edge" 5 "profile_estimate" { xfail *-*-* } } } */
kono
parents:
diff changeset
124 /* { dg-final { scan-tree-dump-times "Merged latch edges" 2 "profile_estimate" { xfail *-*-* } } } */
kono
parents:
diff changeset
125 /* { dg-final { scan-tree-dump-times "4 loops found" 2 "profile_estimate" { xfail *-*-* } } } */
kono
parents:
diff changeset
126 /* { dg-final { scan-tree-dump-times "3 loops found" 2 "profile_estimate" { xfail *-*-* } } } */
kono
parents:
diff changeset
127 /* { dg-final { scan-tree-dump-times "2 loops found" 1 "profile_estimate" { xfail *-*-* } } } */
kono
parents:
diff changeset
128