forked from OSchip/llvm-project
[flang][OpenMP] Added parser support for defaultmap (OpenMP 5.0)
This patch adds parser support for defaultmap clause [OpenMP 5.0]. Reviewed By: kiranchandramohan, peixin, shraiysh Differential Revision: https://reviews.llvm.org/D124190
This commit is contained in:
parent
6d75c89783
commit
e72f573848
|
@ -3346,8 +3346,9 @@ struct OmpMapClause {
|
||||||
// 2.15.5.2 defaultmap -> DEFAULTMAP (implicit-behavior[:variable-category])
|
// 2.15.5.2 defaultmap -> DEFAULTMAP (implicit-behavior[:variable-category])
|
||||||
struct OmpDefaultmapClause {
|
struct OmpDefaultmapClause {
|
||||||
TUPLE_CLASS_BOILERPLATE(OmpDefaultmapClause);
|
TUPLE_CLASS_BOILERPLATE(OmpDefaultmapClause);
|
||||||
ENUM_CLASS(ImplicitBehavior, Tofrom)
|
ENUM_CLASS(
|
||||||
ENUM_CLASS(VariableCategory, Scalar)
|
ImplicitBehavior, Alloc, To, From, Tofrom, Firstprivate, None, Default)
|
||||||
|
ENUM_CLASS(VariableCategory, Scalar, Aggregate, Allocatable, Pointer)
|
||||||
std::tuple<ImplicitBehavior, std::optional<VariableCategory>> t;
|
std::tuple<ImplicitBehavior, std::optional<VariableCategory>> t;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3754,7 +3755,6 @@ struct OpenMPCancelConstruct {
|
||||||
std::tuple<Verbatim, OmpCancelType, std::optional<If>> t;
|
std::tuple<Verbatim, OmpCancelType, std::optional<If>> t;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// 2.17.8 flush -> FLUSH [memory-order-clause] [(variable-name-list)]
|
// 2.17.8 flush -> FLUSH [memory-order-clause] [(variable-name-list)]
|
||||||
struct OpenMPFlushConstruct {
|
struct OpenMPFlushConstruct {
|
||||||
TUPLE_CLASS_BOILERPLATE(OpenMPFlushConstruct);
|
TUPLE_CLASS_BOILERPLATE(OpenMPFlushConstruct);
|
||||||
|
|
|
@ -52,12 +52,30 @@ TYPE_PARSER(construct<OmpMapType>(
|
||||||
TYPE_PARSER(construct<OmpMapClause>(
|
TYPE_PARSER(construct<OmpMapClause>(
|
||||||
maybe(Parser<OmpMapType>{}), Parser<OmpObjectList>{}))
|
maybe(Parser<OmpMapType>{}), Parser<OmpObjectList>{}))
|
||||||
|
|
||||||
// 2.15.5.2 defaultmap -> DEFAULTMAP (TOFROM:SCALAR)
|
// [OpenMP 5.0]
|
||||||
|
// 2.19.7.2 defaultmap(implicit-behavior[:variable-category])
|
||||||
|
// implicit-behavior -> ALLOC | TO | FROM | TOFROM | FIRSRTPRIVATE | NONE |
|
||||||
|
// DEFAULT
|
||||||
|
// variable-category -> SCALAR | AGGREGATE | ALLOCATABLE | POINTER
|
||||||
TYPE_PARSER(construct<OmpDefaultmapClause>(
|
TYPE_PARSER(construct<OmpDefaultmapClause>(
|
||||||
construct<OmpDefaultmapClause::ImplicitBehavior>(
|
construct<OmpDefaultmapClause::ImplicitBehavior>(
|
||||||
"TOFROM" >> pure(OmpDefaultmapClause::ImplicitBehavior::Tofrom)),
|
"ALLOC" >> pure(OmpDefaultmapClause::ImplicitBehavior::Alloc) ||
|
||||||
maybe(":" >> construct<OmpDefaultmapClause::VariableCategory>("SCALAR" >>
|
"TO"_id >> pure(OmpDefaultmapClause::ImplicitBehavior::To) ||
|
||||||
pure(OmpDefaultmapClause::VariableCategory::Scalar)))))
|
"FROM" >> pure(OmpDefaultmapClause::ImplicitBehavior::From) ||
|
||||||
|
"TOFROM" >> pure(OmpDefaultmapClause::ImplicitBehavior::Tofrom) ||
|
||||||
|
"FIRSTPRIVATE" >>
|
||||||
|
pure(OmpDefaultmapClause::ImplicitBehavior::Firstprivate) ||
|
||||||
|
"NONE" >> pure(OmpDefaultmapClause::ImplicitBehavior::None) ||
|
||||||
|
"DEFAULT" >> pure(OmpDefaultmapClause::ImplicitBehavior::Default)),
|
||||||
|
maybe(":" >>
|
||||||
|
construct<OmpDefaultmapClause::VariableCategory>(
|
||||||
|
"SCALAR" >> pure(OmpDefaultmapClause::VariableCategory::Scalar) ||
|
||||||
|
"AGGREGATE" >>
|
||||||
|
pure(OmpDefaultmapClause::VariableCategory::Aggregate) ||
|
||||||
|
"ALLOCATABLE" >>
|
||||||
|
pure(OmpDefaultmapClause::VariableCategory::Allocatable) ||
|
||||||
|
"POINTER" >>
|
||||||
|
pure(OmpDefaultmapClause::VariableCategory::Pointer)))))
|
||||||
|
|
||||||
// 2.7.1 SCHEDULE ([modifier1 [, modifier2]:]kind[, chunk_size])
|
// 2.7.1 SCHEDULE ([modifier1 [, modifier2]:]kind[, chunk_size])
|
||||||
// Modifier -> MONITONIC | NONMONOTONIC | SIMD
|
// Modifier -> MONITONIC | NONMONOTONIC | SIMD
|
||||||
|
|
|
@ -0,0 +1,144 @@
|
||||||
|
! RUN: %flang_fc1 -fdebug-unparse-no-sema -fopenmp %s | FileCheck --ignore-case %s
|
||||||
|
! RUN: %flang_fc1 -fdebug-dump-parse-tree-no-sema -fopenmp %s | FileCheck --check-prefix="PARSE-TREE" %s
|
||||||
|
program main
|
||||||
|
!CHECK-LABEL: program main
|
||||||
|
implicit none
|
||||||
|
|
||||||
|
integer, parameter :: N = 256
|
||||||
|
|
||||||
|
type data01
|
||||||
|
integer :: a
|
||||||
|
integer :: arr(N)
|
||||||
|
end type
|
||||||
|
|
||||||
|
real :: arrA(N), arrB(N)
|
||||||
|
integer, target :: arrC(N)
|
||||||
|
type(data01) :: data01_a
|
||||||
|
integer, allocatable :: alloc_arr(:)
|
||||||
|
integer, pointer :: ptrArr(:)
|
||||||
|
|
||||||
|
arrA = 1.414
|
||||||
|
arrB = 3.14
|
||||||
|
arrC = -1
|
||||||
|
data01_a%a = -1
|
||||||
|
data01_arr = -1
|
||||||
|
allocate(alloc_arr(N))
|
||||||
|
alloc_arr = -1
|
||||||
|
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(tofrom:scalar)
|
||||||
|
!$omp target defaultmap(tofrom:scalar)
|
||||||
|
do i = 1, N
|
||||||
|
a = 3.14
|
||||||
|
enddo
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = Tofrom
|
||||||
|
!PARSE-TREE: VariableCategory = Scalar
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(alloc:scalar)
|
||||||
|
!$omp target defaultmap(alloc:scalar)
|
||||||
|
a = 4.56
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = Alloc
|
||||||
|
!PARSE-TREE: VariableCategory = Scalar
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(none)
|
||||||
|
!$omp target defaultmap(none)
|
||||||
|
a = 6.78
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = None
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(none:scalar)
|
||||||
|
!$omp target defaultmap(none:scalar)
|
||||||
|
a = 4.78
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = None
|
||||||
|
!PARSE-TREE: VariableCategory = Scalar
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(to:scalar)
|
||||||
|
!$omp target defaultmap(to:scalar)
|
||||||
|
a = 2.39
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = To
|
||||||
|
!PARSE-TREE: VariableCategory = Scalar
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(firstprivate:scalar)
|
||||||
|
!$omp target defaultmap(firstprivate:scalar)
|
||||||
|
a = 9.45
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = Firstprivate
|
||||||
|
!PARSE-TREE: VariableCategory = Scalar
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(tofrom:aggregate)
|
||||||
|
!$omp target defaultmap(tofrom:aggregate)
|
||||||
|
arrC(1) = 10
|
||||||
|
data01_a%a = 11
|
||||||
|
data01_a%arr(1) = 100
|
||||||
|
data01_a%arr(2) = 245
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = Tofrom
|
||||||
|
!PARSE-TREE: VariableCategory = Aggregate
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(tofrom:allocatable)
|
||||||
|
!$omp target defaultmap(tofrom:allocatable)
|
||||||
|
alloc_arr(23) = 234
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = Tofrom
|
||||||
|
!PARSE-TREE: VariableCategory = Allocatable
|
||||||
|
|
||||||
|
!CHECK: !$omp target defaultmap(default:pointer)
|
||||||
|
!$omp target defaultmap(default:pointer)
|
||||||
|
ptrArr=>arrC
|
||||||
|
ptrArr(2) = 5
|
||||||
|
prtArr(200) = 34
|
||||||
|
!CHECK: !$omp end target
|
||||||
|
!$omp end target
|
||||||
|
|
||||||
|
!PARSE-TREE: OmpBeginBlockDirective
|
||||||
|
!PARSE-TREE: OmpBlockDirective -> llvm::omp::Directive = target
|
||||||
|
!PARSE-TREE: OmpClauseList -> OmpClause -> Defaultmap -> OmpDefaultmapClause
|
||||||
|
!PARSE-TREE: ImplicitBehavior = Default
|
||||||
|
!PARSE-TREE: VariableCategory = Pointer
|
||||||
|
|
||||||
|
end program main
|
||||||
|
!CHECK-LABEL: end program main
|
Loading…
Reference in New Issue