Add support for ARMv8-R architecture
[official-gcc.git] / libgomp / testsuite / libgomp.fortran / simd1.f90
blobb97d27f8dc50e72000ba867877f246a2f0350a93
1 ! { dg-do run }
2 ! { dg-additional-options "-msse2" { target sse2_runtime } }
3 ! { dg-additional-options "-mavx" { target avx_runtime } }
5 type dt
6 integer :: x = 0
7 end type
8 type (dt) :: t
9 integer :: i, j, k, l, r, s, a(30)
10 integer, target :: q(30)
11 integer, pointer :: p(:)
12 !$omp declare reduction (foo : integer : &
13 !$omp & omp_out = omp_out + omp_in) initializer (omp_priv = 0)
14 !$omp declare reduction (+ : dt : omp_out%x = omp_out%x &
15 !$omp & + omp_in%x)
16 a(:) = 1
17 q(:) = 1
18 p => q
19 r = 0
20 j = 10
21 k = 20
22 s = 0
23 !$omp simd safelen (8) reduction(+:r, t) linear(j, k : 2) &
24 !$omp& private (l) aligned(p : 4) reduction(foo:s)
25 do i = 1, 30
26 l = j + k + a(i) + p(i)
27 r = r + l
28 j = j + 2
29 k = k + 2
30 s = s + l
31 t%x = t%x + l
32 end do
33 if (r.ne.2700.or.j.ne.70.or.k.ne.80.or.s.ne.2700) call abort
34 if (t%x.ne.2700) call abort
35 end