//===-- Decomposer.h -- Compound directive decomposition ------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #ifndef FORTRAN_LOWER_OPENMP_DECOMPOSER_H #define FORTRAN_LOWER_OPENMP_DECOMPOSER_H #include "flang/Lower/OpenMP/Clauses.h" #include "mlir/IR/BuiltinOps.h" #include "llvm/Frontend/OpenMP/ConstructDecompositionT.h" #include "llvm/Frontend/OpenMP/OMP.h" #include "llvm/Support/Compiler.h" namespace llvm { class raw_ostream; } namespace Fortran { namespace semantics { class SemanticsContext; } namespace lower::pft { struct Evaluation; } } // namespace Fortran namespace Fortran::lower::omp { using UnitConstruct = tomp::DirectiveWithClauses; using ConstructQueue = List; LLVM_DUMP_METHOD llvm::raw_ostream &operator<<(llvm::raw_ostream &os, const UnitConstruct &uc); // Given a potentially compound construct with a list of clauses that // apply to it, break it up into individual sub-constructs each with // the subset of applicable clauses (plus implicit clauses, if any). // From that create a work queue where each work item corresponds to // the sub-construct with its clauses. ConstructQueue buildConstructQueue(mlir::ModuleOp modOp, semantics::SemanticsContext &semaCtx, lower::pft::Evaluation &eval, const parser::CharBlock &source, llvm::omp::Directive compound, const List &clauses); bool isLastItemInQueue(ConstructQueue::const_iterator item, const ConstructQueue &queue); /// Try to match the leaf constructs conforming the given \c directive to the /// range of leaf constructs starting from \c item to the end of the \c queue. /// If \c directive doesn't represent a compound directive, check that \c item /// matches that directive and is the only element before the end of the /// \c queue. bool matchLeafSequence(ConstructQueue::const_iterator item, const ConstructQueue &queue, llvm::omp::Directive directive); } // namespace Fortran::lower::omp #endif // FORTRAN_LOWER_OPENMP_DECOMPOSER_H