annotate gcc/testsuite/gcc.dg/tree-ssa/loop-35.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
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 "-O2 -fdump-tree-lim2-details" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 int x;
kono
parents:
diff changeset
5 int a[100];
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 struct a
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 int X;
kono
parents:
diff changeset
10 int Y;
kono
parents:
diff changeset
11 };
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 /* Word size is long long for 64-bit mingw target. */
kono
parents:
diff changeset
14 #ifdef _WIN64
kono
parents:
diff changeset
15 #define LONG long long
kono
parents:
diff changeset
16 #else
kono
parents:
diff changeset
17 #define LONG long
kono
parents:
diff changeset
18 #endif
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 struct a arr[100];
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 void test1(int b)
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 unsigned i;
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 /* And here. */
kono
parents:
diff changeset
27 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 arr[b+8].X += i;
kono
parents:
diff changeset
30 arr[b+9].X += i;
kono
parents:
diff changeset
31 }
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 void test2(struct a *A, int b)
kono
parents:
diff changeset
35 {
kono
parents:
diff changeset
36 unsigned i;
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 /* And here as well. */
kono
parents:
diff changeset
39 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 A[b].X += i;
kono
parents:
diff changeset
42 A[b+1].Y += i;
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 void test3(unsigned LONG b)
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 unsigned i;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 /* And here. */
kono
parents:
diff changeset
51 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
52 {
kono
parents:
diff changeset
53 arr[b+8].X += i;
kono
parents:
diff changeset
54 arr[b+9].X += i;
kono
parents:
diff changeset
55 }
kono
parents:
diff changeset
56 }
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 void test4(struct a *A, unsigned LONG b)
kono
parents:
diff changeset
59 {
kono
parents:
diff changeset
60 unsigned i;
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 /* And here as well. */
kono
parents:
diff changeset
63 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 A[b].X += i;
kono
parents:
diff changeset
66 A[b+1].Y += i;
kono
parents:
diff changeset
67 }
kono
parents:
diff changeset
68 }
kono
parents:
diff changeset
69 /* long index not hoisted for avr target PR 36561 */
kono
parents:
diff changeset
70 /* { dg-final { scan-tree-dump-times "Executing store motion of" 8 "lim2" { xfail { "avr-*-*" } } } } */
kono
parents:
diff changeset
71 /* { dg-final { scan-tree-dump-times "Executing store motion of" 6 "lim2" { target { "avr-*-*" } } } } */