52class ClauseProcessor {
56 const List<Clause> &clauses)
57 : converter(converter), semaCtx(semaCtx), clauses(clauses) {}
60 bool processBare(mlir::omp::BareClauseOps &result)
const;
61 bool processBind(mlir::omp::BindClauseOps &result)
const;
62 bool processCancelDirectiveName(
63 mlir::omp::CancelDirectiveNameClauseOps &result)
const;
66 mlir::omp::LoopRelatedClauseOps &loopResult,
67 mlir::omp::CollapseClauseOps &collapseResult,
68 llvm::SmallVectorImpl<const semantics::Symbol *> &iv)
const;
70 mlir::omp::SizesClauseOps &result)
const;
72 mlir::omp::LooprangeClauseOps &result,
73 int64_t &count)
const;
75 mlir::omp::DeviceClauseOps &result)
const;
76 bool processDeviceType(mlir::omp::DeviceTypeClauseOps &result)
const;
78 mlir::omp::DistScheduleClauseOps &result)
const;
79 bool processExclusive(mlir::Location currentLocation,
80 mlir::omp::ExclusiveClauseOps &result)
const;
82 mlir::omp::FilterClauseOps &result)
const;
84 mlir::omp::FinalClauseOps &result)
const;
86 mlir::omp::GrainsizeClauseOps &result)
const;
87 bool processHasDeviceAddr(
89 mlir::omp::HasDeviceAddrClauseOps &result,
90 llvm::SmallVectorImpl<const semantics::Symbol *> &hasDeviceSyms)
const;
91 bool processHint(mlir::omp::HintClauseOps &result)
const;
92 bool processInbranch(mlir::omp::InbranchClauseOps &result)
const;
93 bool processInclusive(mlir::Location currentLocation,
94 mlir::omp::InclusiveClauseOps &result)
const;
95 bool processInitializer(
97 ReductionProcessor::GenInitValueCBTy &genInitValueCB)
const;
98 bool processMergeable(mlir::omp::MergeableClauseOps &result)
const;
99 bool processNogroup(mlir::omp::NogroupClauseOps &result)
const;
100 bool processNotinbranch(mlir::omp::NotinbranchClauseOps &result)
const;
101 bool processNowait(mlir::omp::NowaitClauseOps &result)
const;
103 mlir::omp::NumTasksClauseOps &result)
const;
105 mlir::omp::NumTeamsClauseOps &result)
const;
107 mlir::omp::NumThreadsClauseOps &result)
const;
108 bool processOrder(mlir::omp::OrderClauseOps &result)
const;
109 bool processOrdered(mlir::omp::OrderedClauseOps &result)
const;
111 mlir::omp::PriorityClauseOps &result)
const;
112 bool processProcBind(mlir::omp::ProcBindClauseOps &result)
const;
114 mlir::omp::LoopNestOperands &result)
const;
115 bool processSafelen(mlir::omp::SafelenClauseOps &result)
const;
117 mlir::omp::ScheduleClauseOps &result)
const;
118 bool processSimdlen(mlir::omp::SimdlenClauseOps &result)
const;
120 mlir::omp::ThreadLimitClauseOps &result)
const;
121 bool processUntied(mlir::omp::UntiedClauseOps &result)
const;
123 bool processDetach(mlir::omp::DetachClauseOps &result)
const;
125 bool processAffinity(mlir::omp::AffinityClauseOps &result)
const;
126 bool processAligned(mlir::omp::AlignedClauseOps &result)
const;
127 bool processAllocate(mlir::omp::AllocateClauseOps &result)
const;
128 bool processCopyin()
const;
129 bool processCopyprivate(mlir::Location currentLocation,
130 mlir::omp::CopyprivateClauseOps &result)
const;
132 DefaultMapsTy &result)
const;
134 mlir::omp::DependClauseOps &result)
const;
136 processEnter(llvm::SmallVectorImpl<DeclareTargetCaptureInfo> &result)
const;
137 bool processIf(omp::clause::If::DirectiveNameModifier directiveName,
138 mlir::omp::IfClauseOps &result)
const;
139 bool processInReduction(
140 mlir::Location currentLocation, mlir::omp::InReductionClauseOps &result,
141 llvm::SmallVectorImpl<const semantics::Symbol *> &outReductionSyms)
const;
142 bool processIsDevicePtr(
144 llvm::SmallVectorImpl<const semantics::Symbol *> &isDeviceSyms)
const;
145 bool processLinear(mlir::omp::LinearClauseOps &result)
const;
147 processLink(llvm::SmallVectorImpl<DeclareTargetCaptureInfo> &result)
const;
153 bool processMap(mlir::Location currentLocation,
155 mlir::omp::MapClauseOps &result,
156 llvm::omp::Directive directive = llvm::omp::OMPD_unknown,
157 llvm::SmallVectorImpl<const semantics::Symbol *> *mapSyms =
160 mlir::omp::MapClauseOps &result);
161 bool processNontemporal(mlir::omp::NontemporalClauseOps &result)
const;
162 bool processReduction(
163 mlir::Location currentLocation, mlir::omp::ReductionClauseOps &result,
164 llvm::SmallVectorImpl<const semantics::Symbol *> &reductionSyms)
const;
165 bool processTaskReduction(
166 mlir::Location currentLocation, mlir::omp::TaskReductionClauseOps &result,
167 llvm::SmallVectorImpl<const semantics::Symbol *> &outReductionSyms)
const;
168 bool processTo(llvm::SmallVectorImpl<DeclareTargetCaptureInfo> &result)
const;
169 bool processUseDeviceAddr(
171 mlir::omp::UseDeviceAddrClauseOps &result,
172 llvm::SmallVectorImpl<const semantics::Symbol *> &useDeviceSyms)
const;
173 bool processUseDevicePtr(
175 mlir::omp::UseDevicePtrClauseOps &result,
176 llvm::SmallVectorImpl<const semantics::Symbol *> &useDeviceSyms)
const;
177 bool processUniform(mlir::omp::UniformClauseOps &result)
const;
182 template <
typename... Ts>
183 void processTODO(mlir::Location currentLocation,
184 llvm::omp::Directive directive)
const;
187 using ClauseIterator = List<Clause>::const_iterator;
192 template <
typename T>
197 template <
typename T>
198 bool findRepeatableClause(
203 template <
typename T>
204 bool markClauseOccurrence(mlir::UnitAttr &result)
const;
206 void processMapObjects(
208 const omp::ObjectList &objects, mlir::omp::ClauseMapFlags mapTypeBits,
209 std::map<Object, OmpMapParentAndMemberData> &parentMemberIndices,
210 llvm::SmallVectorImpl<mlir::Value> &mapVars,
211 llvm::SmallVectorImpl<const semantics::Symbol *> &mapSyms,
212 llvm::StringRef mapperIdNameRef =
"")
const;
216 List<Clause> clauses;