forked from OSchip/llvm-project
109 lines
2.9 KiB
Fortran
109 lines
2.9 KiB
Fortran
! RUN: not %flang -fsyntax-only -fopenmp %s 2>&1 | FileCheck %s
|
|
! REQUIRES: shell
|
|
! OpenMP Version 4.5
|
|
! Check invalid branches into or out of OpenMP structured blocks.
|
|
|
|
subroutine omp_err_end_eor(a, b, x)
|
|
integer x
|
|
|
|
!$omp parallel
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing PARALLEL directive branched into
|
|
|
|
!CHECK: invalid branch leaving an OpenMP structured block
|
|
!CHECK: Outside the enclosing PARALLEL directive
|
|
open (10, file="myfile.dat", err=100)
|
|
!CHECK: invalid branch leaving an OpenMP structured block
|
|
!CHECK: Outside the enclosing PARALLEL directive
|
|
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing PARALLEL directive branched into
|
|
|
|
!CHECK: invalid branch leaving an OpenMP structured block
|
|
!CHECK: Outside the enclosing PARALLEL directive
|
|
read (10, 20, end=200, size=x, advance='no', eor=300) a
|
|
!$omp end parallel
|
|
|
|
goto 99
|
|
99 close (10)
|
|
goto 40
|
|
!$omp parallel
|
|
100 print *, "error opening"
|
|
!$omp end parallel
|
|
101 return
|
|
200 print *, "end of file"
|
|
202 return
|
|
|
|
!$omp parallel
|
|
300 print *, "end of record"
|
|
!$omp end parallel
|
|
|
|
303 return
|
|
20 format (1x,F5.1)
|
|
30 format (2x,F6.2)
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing PARALLEL directive branched into
|
|
40 open (11, file="myfile2.dat", err=100)
|
|
goto 50
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing PARALLEL directive branched into
|
|
50 write (11, 30, err=100) b
|
|
close (11)
|
|
end subroutine
|
|
|
|
subroutine omp_alt_return_spec(n, *, *)
|
|
if (n .eq. 0) return
|
|
if (n .eq. 1) return 1
|
|
return 2
|
|
end subroutine
|
|
|
|
program omp_invalid_branch
|
|
integer :: n = 0, a = 3, b
|
|
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing PARALLEL directive branched into
|
|
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing PARALLEL directive branched into
|
|
goto (1, 2, 3) a
|
|
|
|
assign 2 to b
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing PARALLEL directive branched into
|
|
goto b (1, 2)
|
|
|
|
!$omp parallel
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing SINGLE directive branched into
|
|
|
|
!CHECK: invalid branch leaving an OpenMP structured block
|
|
!CHECK: Outside the enclosing PARALLEL directive
|
|
3 if(n) 4, 5, 6
|
|
|
|
6 print *, 6
|
|
2 print *, 2
|
|
|
|
!$omp single
|
|
4 print *, 4
|
|
!$omp end single
|
|
!$omp end parallel
|
|
|
|
1 print *, 1
|
|
5 print *, 5
|
|
|
|
!$omp parallel
|
|
!CHECK: invalid branch into an OpenMP structured block
|
|
!CHECK: In the enclosing SINGLE directive branched into
|
|
|
|
!CHECK: invalid branch leaving an OpenMP structured block
|
|
!CHECK: Outside the enclosing PARALLEL directive
|
|
call omp_alt_return_spec(n, *8, *9)
|
|
print *, "Normal Return"
|
|
!$omp single
|
|
8 print *, "1st alternate return"
|
|
!$omp end single
|
|
!$omp end parallel
|
|
9 print *, "2nd alternate return"
|
|
|
|
end program
|