//===- ParallelLoopTiling.cpp - Tiles scf.parallel ------------------------===// // // 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 // //===----------------------------------------------------------------------===// // // This file implements loop tiling on parallel loops. // //===----------------------------------------------------------------------===// #include "mlir/Dialect/SCF/Transforms/Passes.h" #include "mlir/Dialect/Affine/IR/AffineOps.h" #include "mlir/Dialect/Arith/IR/Arith.h" #include "mlir/Dialect/SCF/IR/SCF.h" #include "mlir/Dialect/SCF/Transforms/Transforms.h" #include "mlir/Dialect/SCF/Utils/Utils.h" namespace mlir { #define GEN_PASS_DEF_SCFPARALLELLOOPTILING #include "mlir/Dialect/SCF/Transforms/Passes.h.inc" } // namespace mlir usingnamespacemlir; usingnamespacemlir::scf; /// Tile a parallel loop of the form /// scf.parallel (%i0, %i1) = (%arg0, %arg1) to (%arg2, %arg3) /// step (%arg4, %arg5) /// /// into /// scf.parallel (%i0, %i1) = (%arg0, %arg1) to (%arg2, %arg3) /// step (%arg4*tileSize[0], /// %arg5*tileSize[1]) /// scf.parallel (%j0, %j1) = (0, 0) to (min(%arg4*tileSize[0], %arg2-%i0) /// min(%arg5*tileSize[1], %arg3-%i1)) /// step (%arg4, %arg5) /// /// or, when no-min-max-bounds is true, into /// scf.parallel (%i0, %i1) = (%arg0, %arg1) to (%arg2, %arg3) /// step (%arg4*tileSize[0], /// %arg5*tileSize[1]) /// scf.parallel (%j0, %j1) = (0, 0) to (%arg4*tileSize[0], /// %arg5*tileSize[1]) /// step (%arg4, %arg5) /// %inbound = (%j0 * %arg4 + %i0 < %arg2) && /// (%j1 * %arg5 + %i1 < %arg3) /// scf.if (%inbound) /// .... /// /// where the uses of %i0 and %i1 in the loop body are replaced by /// %i0 + j0 and %i1 + %j1. /// /// The old loop is replaced with the new one. std::pair<ParallelOp, ParallelOp> mlir::scf::tileParallelLoop(ParallelOp op, ArrayRef<int64_t> tileSizes, bool noMinMaxBounds) { … } namespace { struct ParallelLoopTiling : public impl::SCFParallelLoopTilingBase<ParallelLoopTiling> { … }; } // namespace std::unique_ptr<Pass> mlir::createParallelLoopTilingPass(ArrayRef<int64_t> tileSizes, bool noMinMaxBounds) { … }