[AArch64] Merge stores of D-register values with different modes
[official-gcc.git] / gcc / testsuite / c-c++-common / gomp / ordered-1.c
blob11022593e3e594b21ee22f3d02c77a58d376e4be
1 /* { dg-do run } */
2 /* { dg-options "-O2 -fopenmp-simd" } */
3 /* { dg-additional-options "-msse2" { target sse2_runtime } } */
4 /* { dg-additional-options "-mavx" { target avx_runtime } } */
6 #define N 1024
7 extern
8 #ifdef __cplusplus
9 "C"
10 #endif
11 void abort (void);
13 int last;
15 void
16 bar (unsigned char *a, int i, int safelen)
18 int j, k;
19 if (i != last++)
20 abort ();
21 for (j = i - safelen - 32; j < i; j++)
22 if (j >= 0 && a[j] != 2)
23 break;
24 if (j <= i - safelen || a[j] != 1)
25 abort ();
26 for (k = j; k < i + safelen + 32; k++)
27 if (k >= N || a[k] != 1)
28 break;
29 if (k <= i || k > j + safelen)
30 abort ();
31 if (k < N && a[k] != 0)
32 abort ();
33 for (; k < i + safelen + 32; k++)
34 if (k < N && a[k] != 0)
35 abort ();
38 static inline void
39 foo (unsigned char *a, int i)
41 #pragma omp ordered simd
42 bar (a, i, 64);
45 int
46 main ()
48 unsigned char a[N], b[N];
49 int i;
50 #pragma omp simd
51 for (i = 0; i < N; i++)
52 a[i] = 0;
53 #pragma omp simd safelen (64)
54 for (i = 0; i < N; i++)
56 a[i]++;
57 foo (a, i);
58 a[i]++;
60 #pragma omp simd
61 for (i = 0; i < N; i++)
63 a[i] = 0;
64 b[i] = 0;
66 last = 0;
67 #pragma omp simd safelen (32)
68 for (i = 0; i < N; i++)
70 a[i]++;
71 #pragma omp ordered simd
72 bar (a, i, 32);
73 a[i]++;
75 for (i = 0; i < N; i++)
76 if (a[i] != 2)
77 abort ();
78 #pragma omp simd safelen (32)
79 for (i = 1; i < N; i++)
81 #pragma omp ordered simd
82 b[i] = b[i - 1] + 1;
83 a[i]++;
84 #pragma omp ordered simd
85 a[i] += a[i - 1];
87 for (i = 0; i < N; i++)
88 if (a[i] != (unsigned char) (2 + 3 * i) || b[i] != (unsigned char) i)
89 abort ();
90 return 0;