aboutsummaryrefslogtreecommitdiff
path: root/libgomp/testsuite/libgomp.fortran/target2.f90
blob: 11b8af737e37112ea70de74dcbf2a0cb3a343a6b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
! { dg-do run }
! { dg-options "-ffree-line-length-160" }

module target2
contains
  subroutine foo (a, b, c, d, e, f, g, n, q)
    integer :: n, q
    integer :: a, b(3:n), c(5:), d(2:*), e(:,:)
    integer, pointer :: f, g(:)
    integer :: h, i(3:n)
    integer, pointer :: j, k(:)
    logical :: r
    allocate (j, k(4:n))
    h = 14
    i = 15
    j = 16
    k = 17
    !$omp target map (to: a, b, c, d(2:n+1), e, f, g, h, i, j, k, n) map (from: r)
      r = a /= 7
      r = r .or. (any (b /= 8)) .or. (lbound (b, 1) /= 3) .or. (ubound (b, 1) /= n)
      r = r .or. (any (c /= 9)) .or. (lbound (c, 1) /= 5) .or. (ubound (c, 1) /= n + 4)
      r = r .or. (any (d(2:n+1) /= 10)) .or. (lbound (d, 1) /= 2)
      r = r .or. (any (e /= 11)) .or. (lbound (e, 1) /= 1) .or. (ubound (e, 1) /= 2)
      r = r .or. (lbound (e, 2) /= 1) .or. (ubound (e, 2) /= 2)
      r = r .or. (f /= 12)
      r = r .or. (any (g /= 13)) .or. (lbound (g, 1) /= 3) .or. (ubound (g, 1) /= n)
      r = r .or. (h /= 14)
      r = r .or. (any (i /= 15)) .or. (lbound (i, 1) /= 3) .or. (ubound (i, 1) /= n)
      r = r .or. (j /= 16)
      r = r .or. (any (k /= 17)) .or. (lbound (k, 1) /= 4) .or. (ubound (k, 1) /= n)
    !$omp end target
    if (r) stop 1
    !$omp target map (to: b(3:n), c(5:n+4), d(2:n+1), e(1:,:2), g(3:n), i(3:n), k(4:n), n) map (from: r)
      r = (any (b /= 8)) .or. (lbound (b, 1) /= 3) .or. (ubound (b, 1) /= n)
      r = r .or. (any (c /= 9)) .or. (lbound (c, 1) /= 5) .or. (ubound (c, 1) /= n + 4)
      r = r .or. (any (d(2:n+1) /= 10)) .or. (lbound (d, 1) /= 2)
      r = r .or. (any (e /= 11)) .or. (lbound (e, 1) /= 1) .or. (ubound (e, 1) /= 2)
      r = r .or. (lbound (e, 2) /= 1) .or. (ubound (e, 2) /= 2)
      r = r .or. (any (g /= 13)) .or. (lbound (g, 1) /= 3) .or. (ubound (g, 1) /= n)
      r = r .or. (any (i /= 15)) .or. (lbound (i, 1) /= 3) .or. (ubound (i, 1) /= n)
      r = r .or. (any (k /= 17)) .or. (lbound (k, 1) /= 4) .or. (ubound (k, 1) /= n)
    !$omp end target
    if (r) stop 2
    !$omp target map (to: b(5:n-2), c(7:n), d(4:n-2), e(1:,2:), g(5:n-3), i(6:n-4), k(5:n-5), n) map (from: r)
      r = (any (b(5:n-2) /= 8)) .or. (lbound (b, 1) /= 3) .or. (ubound (b, 1) /= n)
      r = r .or. (any (c(7:n) /= 9)) .or. (lbound (c, 1) /= 5) .or. (ubound (c, 1) /= n + 4)
      r = r .or. (any (d(4:n-2) /= 10)) .or. (lbound (d, 1) /= 2)
      r = r .or. (any (e(1:,2:) /= 11)) .or. (lbound (e, 1) /= 1) .or. (ubound (e, 1) /= 2)
      r = r .or. (lbound (e, 2) /= 1) .or. (ubound (e, 2) /= 2)
      r = r .or. (any (g(5:n-3) /= 13)) .or. (lbound (g, 1) /= 3) .or. (ubound (g, 1) /= n)
      r = r .or. (any (i(6:n-4) /= 15)) .or. (lbound (i, 1) /= 3) .or. (ubound (i, 1) /= n)
      r = r .or. (any (k(5:n-5) /= 17)) .or. (lbound (k, 1) /= 4) .or. (ubound (k, 1) /= n)
    !$omp end target
    !$omp target map (to: b(q+5:n-2+q), c(q+7:q+n), d(q+4:q+n-2), e(1:q+2,2:q+2), g(5+q:n-3+q), &
    !$omp & i(6+q:n-4+q), k(5+q:n-5+q), n) map (from: r)
      r = (any (b(5:n-2) /= 8)) .or. (lbound (b, 1) /= 3) .or. (ubound (b, 1) /= n)
      r = r .or. (any (c(7:n) /= 9)) .or. (lbound (c, 1) /= 5) .or. (ubound (c, 1) /= n + 4)
      r = r .or. (any (d(4:n-2) /= 10)) .or. (lbound (d, 1) /= 2)
      r = r .or. (any (e(1:,2:) /= 11)) .or. (lbound (e, 1) /= 1) .or. (ubound (e, 1) /= 2)
      r = r .or. (lbound (e, 2) /= 1) .or. (ubound (e, 2) /= 2)
      r = r .or. (any (g(5:n-3) /= 13)) .or. (lbound (g, 1) /= 3) .or. (ubound (g, 1) /= n)
      r = r .or. (any (i(6:n-4) /= 15)) .or. (lbound (i, 1) /= 3) .or. (ubound (i, 1) /= n)
      r = r .or. (any (k(5:n-5) /= 17)) .or. (lbound (k, 1) /= 4) .or. (ubound (k, 1) /= n)
    !$omp end target
    if (r) stop 3
    !$omp target map (to: d(2:n+1), n)
      r = a /= 7
      r = r .or. (any (b /= 8)) .or. (lbound (b, 1) /= 3) .or. (ubound (b, 1) /= n)
      r = r .or. (any (c /= 9)) .or. (lbound (c, 1) /= 5) .or. (ubound (c, 1) /= n + 4)
      r = r .or. (any (d(2:n+1) /= 10)) .or. (lbound (d, 1) /= 2)
      r = r .or. (any (e /= 11)) .or. (lbound (e, 1) /= 1) .or. (ubound (e, 1) /= 2)
      r = r .or. (lbound (e, 2) /= 1) .or. (ubound (e, 2) /= 2)
      r = r .or. (f /= 12)
      r = r .or. (any (g /= 13)) .or. (lbound (g, 1) /= 3) .or. (ubound (g, 1) /= n)
      r = r .or. (h /= 14)
      r = r .or. (any (i /= 15)) .or. (lbound (i, 1) /= 3) .or. (ubound (i, 1) /= n)
      r = r .or. (j /= 16)
      r = r .or. (any (k /= 17)) .or. (lbound (k, 1) /= 4) .or. (ubound (k, 1) /= n)
    !$omp end target
    if (r) stop 4
  end subroutine foo
end module target2
  use target2, only : foo
  integer, parameter :: n = 15, q = 0
  integer :: a, b(2:n-1), c(n), d(n), e(3:4, 3:4)
  integer, pointer :: f, g(:)
  allocate (f, g(3:n))
  a = 7
  b = 8
  c = 9
  d = 10
  e = 11
  f = 12
  g = 13
  call foo (a, b, c, d, e, f, g, n, q)
end