blob: 1a2bbbcbc3d240b9be3ebfac9bcdde6364c36920 [file] [log] [blame] [edit]
! RUN: %flang_fc1 -fdebug-unparse -fopenmp %s | FileCheck --ignore-case %s
! RUN: %flang_fc1 -fdebug-dump-parse-tree -fopenmp %s | FileCheck --check-prefix="PARSE-TREE" %s
! Check for parsing scan directive
subroutine test_scan(n, a, b)
implicit none
integer n
integer a(n), b(n)
integer x,y,k
! a(k) is included in the computation of producing results in b(k)
!$omp parallel do simd reduction(inscan,+: x)
do k = 1, n
x = x + a(k)
!PARSE-TREE: ExecutionPartConstruct -> ExecutableConstruct -> OpenMPConstruct -> OpenMPStandaloneConstruct -> OpenMPSimpleStandaloneConstruct -> OmpDirectiveSpecification
!PARSE-TREE-NEXT: OmpDirectiveName -> llvm::omp::Directive = scan
!PARSE-TREE-NEXT: OmpClauseList -> OmpClause -> Inclusive -> OmpObjectList -> OmpObject -> Designator -> DataRef -> Name = 'x'
!CHECK: !$omp scan inclusive(x)
!$omp scan inclusive(x)
b(k) = x
end do
! a(k) is not included in the computation of producing results in b(k)
!$omp parallel do simd reduction(inscan,+: x)
do k = 1, n
b(k) = x
!PARSE-TREE: ExecutionPartConstruct -> ExecutableConstruct -> OpenMPConstruct -> OpenMPStandaloneConstruct -> OpenMPSimpleStandaloneConstruct -> OmpDirectiveSpecification
!PARSE-TREE-NEXT: OmpDirectiveName -> llvm::omp::Directive = scan
!PARSE-TREE-NEXT: OmpClauseList -> OmpClause -> Exclusive -> OmpObjectList -> OmpObject -> Designator -> DataRef -> Name = 'x'
!CHECK: !$omp scan exclusive(x)
!$omp scan exclusive(x)
x = x + a(k)
end do
!$omp parallel do simd reduction(inscan,+: x, y)
do k = 1, n
x = x + a(k)
!PARSE-TREE: ExecutionPartConstruct -> ExecutableConstruct -> OpenMPConstruct -> OpenMPStandaloneConstruct -> OpenMPSimpleStandaloneConstruct -> OmpDirectiveSpecification
!PARSE-TREE-NEXT: OmpDirectiveName -> llvm::omp::Directive = scan
!PARSE-TREE-NEXT: OmpClauseList -> OmpClause -> Inclusive -> OmpObjectList -> OmpObject -> Designator -> DataRef -> Name = 'x'
!PARSE-TREE-NEXT: OmpObject -> Designator -> DataRef -> Name = 'y'
!CHECK: !$omp scan inclusive(x,y)
!$omp scan inclusive(x, y)
b(k) = x
end do
!$omp parallel do simd reduction(inscan,+: x, y)
do k = 1, n
x = x + a(k)
!PARSE-TREE: ExecutionPartConstruct -> ExecutableConstruct -> OpenMPConstruct -> OpenMPStandaloneConstruct -> OpenMPSimpleStandaloneConstruct -> OmpDirectiveSpecification
!PARSE-TREE-NEXT: OmpDirectiveName -> llvm::omp::Directive = scan
!PARSE-TREE-NEXT: OmpClauseList -> OmpClause -> Exclusive -> OmpObjectList -> OmpObject -> Designator -> DataRef -> Name = 'x'
!PARSE-TREE-NEXT: OmpObject -> Designator -> DataRef -> Name = 'y'
!CHECK: !$omp scan exclusive(x,y)
!$omp scan exclusive(x, y)
b(k) = x
end do
end subroutine