|
| 1 | +! This reproducer hit an issue where when finding directive's, and end directive's would iterate over the block.end() |
| 2 | +! so Flang would crash. We should be able to parse this subroutine without flang crashing. |
| 3 | +! Reported in https://github.com/llvm/llvm-project/issues/147309 and https://github.com/llvm/llvm-project/pull/145917#issuecomment-3041570824 |
| 4 | + |
| 5 | +!RUN: %flang_fc1 -fdebug-dump-parse-tree -fopenmp -fopenmp-version=51 %s | FileCheck %s --check-prefix=CHECK-PARSE |
| 6 | +!RUN: %flang_fc1 -fdebug-unparse -fopenmp -fopenmp-version=51 %s | FileCheck %s --check-prefix=CHECK-UNPARSE |
| 7 | + |
| 8 | +subroutine loop_transformation_construct7 |
| 9 | +implicit none |
| 10 | +real(kind=8), dimension(1:10, 2) :: a |
| 11 | +integer :: b,c |
| 12 | + |
| 13 | +!$omp target teams distribute parallel do collapse(2) private(b) |
| 14 | +do b = 1, 10 |
| 15 | + do c = 1, 10 |
| 16 | + a(b, 2) = a(c, 1) |
| 17 | + end do |
| 18 | +end do |
| 19 | +end subroutine |
| 20 | + |
| 21 | +!CHECK-PARSE: | ExecutionPart -> Block |
| 22 | +!CHECK-PARSE-NEXT: | | ExecutionPartConstruct -> ExecutableConstruct -> OpenMPConstruct -> OpenMPLoopConstruct |
| 23 | +!CHECK-PARSE-NEXT: | | | OmpBeginLoopDirective |
| 24 | +!CHECK-PARSE-NEXT: | | | | OmpLoopDirective -> llvm::omp::Directive = target teams distribute parallel do |
| 25 | +!CHECK-PARSE-NEXT: | | | | OmpClauseList -> OmpClause -> Collapse -> Scalar -> Integer -> Constant -> Expr = '2_4' |
| 26 | +!CHECK-PARSE-NEXT: | | | | | LiteralConstant -> IntLiteralConstant = '2' |
| 27 | +!CHECK-PARSE-NEXT: | | | | OmpClause -> Private -> OmpObjectList -> OmpObject -> Designator -> DataRef -> Name = 'b' |
| 28 | +!CHECK-PARSE-NEXT: | | | DoConstruct |
| 29 | +!CHECK-PARSE-NEXT: | | | | NonLabelDoStmt |
| 30 | +!CHECK-PARSE-NEXT: | | | | | LoopControl -> LoopBounds |
| 31 | +!CHECK-PARSE-NEXT: | | | | | | Scalar -> Name = 'b' |
| 32 | +!CHECK-PARSE-NEXT: | | | | | | Scalar -> Expr = '1_4' |
| 33 | +!CHECK-PARSE-NEXT: | | | | | | | LiteralConstant -> IntLiteralConstant = '1' |
| 34 | +!CHECK-PARSE-NEXT: | | | | | | Scalar -> Expr = '10_4' |
| 35 | +!CHECK-PARSE-NEXT: | | | | | | | LiteralConstant -> IntLiteralConstant = '10' |
| 36 | +!CHECK-PARSE-NEXT: | | | | Block |
| 37 | +!CHECK-PARSE-NEXT: | | | | | ExecutionPartConstruct -> ExecutableConstruct -> DoConstruct |
| 38 | +!CHECK-PARSE-NEXT: | | | | | | NonLabelDoStmt |
| 39 | +!CHECK-PARSE-NEXT: | | | | | | | LoopControl -> LoopBounds |
| 40 | +!CHECK-PARSE-NEXT: | | | | | | | | Scalar -> Name = 'c' |
| 41 | +!CHECK-PARSE-NEXT: | | | | | | | | Scalar -> Expr = '1_4' |
| 42 | +!CHECK-PARSE-NEXT: | | | | | | | | | LiteralConstant -> IntLiteralConstant = '1' |
| 43 | +!CHECK-PARSE-NEXT: | | | | | | | | Scalar -> Expr = '10_4' |
| 44 | +!CHECK-PARSE-NEXT: | | | | | | | | | LiteralConstant -> IntLiteralConstant = '10' |
| 45 | +!CHECK-PARSE-NEXT: | | | | | | Block |
| 46 | +!CHECK-PARSE-NEXT: | | | | | | | ExecutionPartConstruct -> ExecutableConstruct -> ActionStmt -> AssignmentStmt = 'a(int(b,kind=8),2_8)=a(int(c,kind=8),1_8)' |
| 47 | +!CHECK-PARSE-NEXT: | | | | | | | | Variable = 'a(int(b,kind=8),2_8)' |
| 48 | +!CHECK-PARSE-NEXT: | | | | | | | | | Designator -> DataRef -> ArrayElement |
| 49 | +!CHECK-PARSE-NEXT: | | | | | | | | | | DataRef -> Name = 'a' |
| 50 | +!CHECK-PARSE-NEXT: | | | | | | | | | | SectionSubscript -> Integer -> Expr = 'b' |
| 51 | +!CHECK-PARSE-NEXT: | | | | | | | | | | | Designator -> DataRef -> Name = 'b' |
| 52 | +!CHECK-PARSE-NEXT: | | | | | | | | | | SectionSubscript -> Integer -> Expr = '2_4' |
| 53 | +!CHECK-PARSE-NEXT: | | | | | | | | | | | LiteralConstant -> IntLiteralConstant = '2' |
| 54 | +!CHECK-PARSE-NEXT: | | | | | | | | Expr = 'a(int(c,kind=8),1_8)' |
| 55 | +!CHECK-PARSE-NEXT: | | | | | | | | | Designator -> DataRef -> ArrayElement |
| 56 | +!CHECK-PARSE-NEXT: | | | | | | | | | | DataRef -> Name = 'a' |
| 57 | +!CHECK-PARSE-NEXT: | | | | | | | | | | SectionSubscript -> Integer -> Expr = 'c' |
| 58 | +!CHECK-PARSE-NEXT: | | | | | | | | | | | Designator -> DataRef -> Name = 'c' |
| 59 | +!CHECK-PARSE-NEXT: | | | | | | | | | | SectionSubscript -> Integer -> Expr = '1_4' |
| 60 | +!CHECK-PARSE-NEXT: | | | | | | | | | | | LiteralConstant -> IntLiteralConstant = '1' |
| 61 | +!CHECK-PARSE-NEXT: | | | | | | EndDoStmt -> |
| 62 | +!CHECK-PARSE-NEXT: | | | | EndDoStmt -> |
| 63 | +!CHECK-PARSE-NEXT: | EndSubroutineStmt -> |
| 64 | + |
| 65 | +!CHECK-UNPARSE: SUBROUTINE loop_transformation_construct7 |
| 66 | +!CHECK-UNPARSE-NEXT: IMPLICIT NONE |
| 67 | +!CHECK-UNPARSE-NEXT: REAL(KIND=8_4), DIMENSION(1_4:10_4,2_4) :: a |
| 68 | +!CHECK-UNPARSE-NEXT: INTEGER b, c |
| 69 | +!CHECK-UNPARSE-NEXT: !$OMP TARGET TEAMS DISTRIBUTE PARALLEL DO COLLAPSE(2_4) PRIVATE(b) |
| 70 | +!CHECK-UNPARSE-NEXT: DO b=1_4,10_4 |
| 71 | +!CHECK-UNPARSE-NEXT: DO c=1_4,10_4 |
| 72 | +!CHECK-UNPARSE-NEXT: a(int(b,kind=8),2_8)=a(int(c,kind=8),1_8) |
| 73 | +!CHECK-UNPARSE-NEXT: END DO |
| 74 | +!CHECK-UNPARSE-NEXT: END DO |
| 75 | +!CHECK-UNPARSE-NEXT: END SUBROUTINE |
0 commit comments