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 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
|
! RUN: %python %S/../test_errors.py %s %flang -fopenmp
! OpenMP Version 4.5
! 2.7.1 Loop Construct
program omp
integer i, j, k
logical cond(10,10,10)
cond = .false.
!ERROR: The value of the parameter in the COLLAPSE or ORDERED clause must not be larger than the number of nested loops following the construct.
!$omp do collapse(3)
do i = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (i .lt. 1) cycle
do j = 0, 10
do k = 0, 10
print *, i, j, k
end do
end do
end do
!$omp end do
!ERROR: The value of the parameter in the COLLAPSE or ORDERED clause must not be larger than the number of nested loops following the construct.
!$omp do collapse(3)
do i = 0, 10
do j = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (i .lt. 1) cycle
do k = 0, 10
print *, i, j, k
end do
end do
end do
!$omp end do
!ERROR: The value of the parameter in the COLLAPSE or ORDERED clause must not be larger than the number of nested loops following the construct.
!$omp do collapse(2)
do i = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (i .lt. 1) cycle
do j = 0, 10
do k = 0, 10
print *, i, j, k
end do
end do
end do
!$omp end do
!ERROR: The value of the parameter in the COLLAPSE or ORDERED clause must not be larger than the number of nested loops following the construct.
!$omp do collapse(2)
foo: do i = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (i .lt. 1) cycle foo
do j = 0, 10
do k = 0, 10
print *, i, j, k
end do
end do
end do foo
!$omp end do
!ERROR: The value of the parameter in the COLLAPSE or ORDERED clause must not be larger than the number of nested loops following the construct.
!$omp do collapse(3)
do 60 i=2,200,2
do j=1,10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if(i==100) cycle
do k=1,10
print *,i
end do
end do
60 continue
!$omp end do
!$omp do collapse(3)
foo: do i = 0, 10
foo1: do j = 0, 10
foo2: do k = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (k .lt. 1) cycle foo
print *, i, j, k
end do foo2
end do foo1
end do foo
!$omp end do
!$omp do collapse(3)
foo: do i = 0, 10
foo1: do j = 0, 10
foo2: do k = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (k .lt. 1) cycle foo1
print *, i, j, k
end do foo2
end do foo1
end do foo
!$omp end do
!$omp do collapse(2)
foo: do i = 0, 10
foo1: do j = 0, 10
foo2: do k = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (k .lt. 1) cycle foo
print *, i, j, k
end do foo2
end do foo1
end do foo
!$omp end do
!$omp do ordered(2)
foo: do i = 0, 10
foo1: do j = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (k .lt. 1) cycle foo
foo2: do k = 0, 10
print *, i, j, k
end do foo2
end do foo1
end do foo
!$omp end do
!ERROR: The value of the parameter in the COLLAPSE or ORDERED clause must not be larger than the number of nested loops following the construct.
!$omp do collapse(2) ordered(3)
foo: do i = 0, 10
foo1: do j = 0, 10
!ERROR: CYCLE statement to non-innermost associated loop of an OpenMP DO construct
if (k .lt. 1) cycle foo
foo2: do k = 0, 10
print *, i, j, k
end do foo2
end do foo1
end do foo
!$omp end do
!$omp do collapse(3)
loopk: do k=1,10
loopj: do j=1,10
loopi: do i=1,10
ifi : if (.true.) then
!ERROR: EXIT statement terminates associated loop of an OpenMP DO construct
if (cond(i,j,k)) exit
if (cond(i,j,k)) exit ifi
!ERROR: EXIT statement terminates associated loop of an OpenMP DO construct
if (cond(i,j,k)) exit loopi
!ERROR: EXIT statement terminates associated loop of an OpenMP DO construct
if (cond(i,j,k)) exit loopj
end if ifi
end do loopi
end do loopj
end do loopk
!$omp end do
!$omp do collapse(2)
loopk: do k=1,10
loopj: do j=1,10
do i=1,10
end do
!ERROR: EXIT statement terminates associated loop of an OpenMP DO construct
if (cond(i,j,k)) exit
end do loopj
end do loopk
!$omp end do
end program omp
|