annotate gcc/testsuite/gcc.dg/vect/pr59591-1.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 tree-optimization/59591 */
kono
parents:
diff changeset
2 /* { dg-additional-options "-fopenmp-simd" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #ifndef CHECK_H
kono
parents:
diff changeset
5 #include "tree-vect.h"
kono
parents:
diff changeset
6 #endif
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 extern void abort (void);
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 int p[256], q[256], r[256], t[256];
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 __attribute__((noinline, noclone)) void
kono
parents:
diff changeset
13 foo (void)
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 int i;
kono
parents:
diff changeset
16 #pragma omp simd safelen(64)
kono
parents:
diff changeset
17 for (i = 0; i < 256; i++)
kono
parents:
diff changeset
18 if (r[i] > 32)
kono
parents:
diff changeset
19 t[i] = p[q[i] * 3L + 2L];
kono
parents:
diff changeset
20 }
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 __attribute__((noinline, noclone)) void
kono
parents:
diff changeset
23 bar (void)
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 int i;
kono
parents:
diff changeset
26 for (i = 0; i < 256; i++)
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 r[i] = ((i >> 2) & (1 << (i & 3))) ? 32 + i : 32 - i;
kono
parents:
diff changeset
29 q[i] = r[i] > 32 ? ((i * 7) % 84) : 99 + i;
kono
parents:
diff changeset
30 p[i] = i * 11;
kono
parents:
diff changeset
31 t[i] = i * 13;
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33 foo ();
kono
parents:
diff changeset
34 for (i = 0; i < 256; i++)
kono
parents:
diff changeset
35 if ((i >> 2) & (1 << (i & 3)))
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 if (t[i] != (((i * 7) % 84) * 3 + 2) * 11)
kono
parents:
diff changeset
38 abort ();
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40 else if (t[i] != i * 13)
kono
parents:
diff changeset
41 abort ();
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 #ifndef CHECK_H
kono
parents:
diff changeset
45 int
kono
parents:
diff changeset
46 main ()
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 check_vect ();
kono
parents:
diff changeset
49 bar ();
kono
parents:
diff changeset
50 return 0;
kono
parents:
diff changeset
51 }
kono
parents:
diff changeset
52 #endif
kono
parents:
diff changeset
53