| //===-- lib/Support/OpenMP-utils.cpp ----------------------------*- C++ -*-===// |
| // |
| // 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 |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "flang/Support/OpenMP-utils.h" |
| |
| #include "mlir/IR/OpDefinition.h" |
| |
| namespace Fortran::common::openmp { |
| mlir::Block *genEntryBlock(mlir::OpBuilder &builder, const EntryBlockArgs &args, |
| mlir::Region ®ion) { |
| assert(args.isValid() && "invalid args"); |
| assert(region.empty() && "non-empty region"); |
| |
| llvm::SmallVector<mlir::Type> types; |
| llvm::SmallVector<mlir::Location> locs; |
| unsigned numVars = args.hostEvalVars.size() + args.inReduction.vars.size() + |
| args.map.vars.size() + args.priv.vars.size() + |
| args.reduction.vars.size() + args.taskReduction.vars.size() + |
| args.useDeviceAddr.vars.size() + args.useDevicePtr.vars.size(); |
| types.reserve(numVars); |
| locs.reserve(numVars); |
| |
| auto extractTypeLoc = [&types, &locs](llvm::ArrayRef<mlir::Value> vals) { |
| llvm::transform(vals, std::back_inserter(types), |
| [](mlir::Value v) { return v.getType(); }); |
| llvm::transform(vals, std::back_inserter(locs), |
| [](mlir::Value v) { return v.getLoc(); }); |
| }; |
| |
| // Populate block arguments in clause name alphabetical order to match |
| // expected order by the BlockArgOpenMPOpInterface. |
| extractTypeLoc(args.hostEvalVars); |
| extractTypeLoc(args.inReduction.vars); |
| extractTypeLoc(args.map.vars); |
| extractTypeLoc(args.priv.vars); |
| extractTypeLoc(args.reduction.vars); |
| extractTypeLoc(args.taskReduction.vars); |
| extractTypeLoc(args.useDeviceAddr.vars); |
| extractTypeLoc(args.useDevicePtr.vars); |
| |
| return builder.createBlock(®ion, {}, types, locs); |
| } |
| } // namespace Fortran::common::openmp |