annotate gcc/testsuite/gcc.dg/vect/vect-outer-simd-3.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-require-effective-target vect_simd_clones } */
kono
parents:
diff changeset
2 /* { dg-additional-options "-O3 -fopenmp-simd -ffast-math" } */
kono
parents:
diff changeset
3 #include <stdlib.h>
kono
parents:
diff changeset
4 #include "tree-vect.h"
kono
parents:
diff changeset
5 #define N 64
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 float *px, *py;
kono
parents:
diff changeset
8 float *tx, *ty;
kono
parents:
diff changeset
9 float *x1, *z1, *t1, *t2;
kono
parents:
diff changeset
10 int bound[N];
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 static void inline bar(const float cx, float cy,
kono
parents:
diff changeset
13 float *vx, float *vy, int n)
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 int j;
kono
parents:
diff changeset
16 for (j = 0; j < n; ++j)
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 const float dx = cx - px[j];
kono
parents:
diff changeset
19 const float dy = cy - py[j];
kono
parents:
diff changeset
20 *vx -= dx * tx[j];
kono
parents:
diff changeset
21 *vy -= dy * ty[j];
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 __attribute__((noinline, noclone)) void foo1 ()
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 int i;
kono
parents:
diff changeset
28 int n = bound[63];
kono
parents:
diff changeset
29 #pragma omp simd
kono
parents:
diff changeset
30 for (i=0; i<N; i++)
kono
parents:
diff changeset
31 bar(px[i], py[i], x1+i, z1+i, n);
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 __attribute__((noinline, noclone)) void foo2 ()
kono
parents:
diff changeset
35 {
kono
parents:
diff changeset
36 volatile int i;
kono
parents:
diff changeset
37 int n = bound[63];
kono
parents:
diff changeset
38 for (i=0; i<N; i++)
kono
parents:
diff changeset
39 bar(px[i], py[i], x1+i, z1+i, n);
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 int main()
kono
parents:
diff changeset
44 {
kono
parents:
diff changeset
45 float *X = (float*)malloc(N * 8 * sizeof (float));
kono
parents:
diff changeset
46 int i;
kono
parents:
diff changeset
47 /* check_vect (); */
kono
parents:
diff changeset
48 px = &X[0];
kono
parents:
diff changeset
49 py = &X[N * 1];
kono
parents:
diff changeset
50 tx = &X[N * 2];
kono
parents:
diff changeset
51 ty = &X[N * 3];
kono
parents:
diff changeset
52 x1 = &X[N * 4];
kono
parents:
diff changeset
53 z1 = &X[N * 5];
kono
parents:
diff changeset
54 t1 = &X[N * 6];
kono
parents:
diff changeset
55 t2 = &X[N * 7];
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 for (i=0; i<N; i++)
kono
parents:
diff changeset
58 {
kono
parents:
diff changeset
59 px[i] = (float) (i+2);
kono
parents:
diff changeset
60 tx[i] = (float) (i+1);
kono
parents:
diff changeset
61 py[i] = (float) (i+4);
kono
parents:
diff changeset
62 ty[i] = (float) (i+3);
kono
parents:
diff changeset
63 x1[i] = z1[i] = 1.0f;
kono
parents:
diff changeset
64 bound[i] = i + 1;
kono
parents:
diff changeset
65 }
kono
parents:
diff changeset
66 foo1 (); /* vector variant. */
kono
parents:
diff changeset
67 for (i=0; i<N;i++)
kono
parents:
diff changeset
68 {
kono
parents:
diff changeset
69 t1[i] = x1[i]; x1[i] = 1.0f;
kono
parents:
diff changeset
70 t2[i] = z1[i]; z1[i] = 1.0f;
kono
parents:
diff changeset
71 }
kono
parents:
diff changeset
72 foo2 (); /* scalar variant. */
kono
parents:
diff changeset
73 for (i=0; i<N; i++)
kono
parents:
diff changeset
74 if (x1[i] != t1[i] || z1[i] != t2[i])
kono
parents:
diff changeset
75 abort ();
kono
parents:
diff changeset
76 return 0;
kono
parents:
diff changeset
77 }
kono
parents:
diff changeset
78 /* { dg-final { scan-tree-dump "OUTER LOOP VECTORIZED" "vect" } } */