annotate gcc/testsuite/gcc.dg/vect/pr64404.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-additional-options "--param=sccvn-max-alias-queries-per-access=1" } */
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 #include "tree-vect.h"
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 extern void abort (void);
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 typedef struct
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 int l, h;
kono
parents:
diff changeset
10 } tFPinterval;
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 tFPinterval X[1024];
kono
parents:
diff changeset
13 tFPinterval Y[1024];
kono
parents:
diff changeset
14 tFPinterval Z[1024];
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 void __attribute__((noinline))
kono
parents:
diff changeset
17 Compute (void)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 int d;
kono
parents:
diff changeset
20 for (d = 0; d < 1024; d++)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 Y[d].l = X[d].l + X[d].h;
kono
parents:
diff changeset
23 Y[d].h = Y[d].l;
kono
parents:
diff changeset
24 Z[d].l = X[d].l;
kono
parents:
diff changeset
25 Z[d].h = X[d].h;
kono
parents:
diff changeset
26 }
kono
parents:
diff changeset
27 }
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 int
kono
parents:
diff changeset
30 main (void)
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 int d;
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 check_vect ();
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 for (d = 0; d < 1024; d++)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 X[d].l = d;
kono
parents:
diff changeset
39 X[d].h = d + 1;
kono
parents:
diff changeset
40 __asm__ volatile ("");
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 Compute ();
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 for (d = 0; d < 1024; d++)
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 if (Y[d].l != X[d].l + X[d].h
kono
parents:
diff changeset
48 || Y[d].h != Y[d].l
kono
parents:
diff changeset
49 || Z[d].l != X[d].l
kono
parents:
diff changeset
50 || Z[d].h != X[d].h)
kono
parents:
diff changeset
51 abort ();
kono
parents:
diff changeset
52 __asm__ volatile ("");
kono
parents:
diff changeset
53 }
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 return 0;
kono
parents:
diff changeset
56 }
kono
parents:
diff changeset
57