Skip to content

Commit

Permalink
[mlir] NFC: Expose tiled_loop->scf pattern.
Browse files Browse the repository at this point in the history
Differential Revision: https://reviews.llvm.org/D102921
  • Loading branch information
pifon2a committed May 21, 2021
1 parent cc5f6ae commit 335fa18
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 1 deletion.
3 changes: 3 additions & 0 deletions mlir/include/mlir/Dialect/Linalg/Transforms/Transforms.h
Expand Up @@ -81,6 +81,9 @@ void populateFoldUnitExtentDimsPatterns(RewritePatternSet &patterns);
/// Patterns that are used to inline constant operands into linalg generic ops.
void populateInlineConstantOperandsPatterns(RewritePatternSet &patterns);

/// Pattern to convert TiledLoopOp to SCF loops.
void populateTiledLoopToSCFPattern(RewritePatternSet &patterns);

/// Options that control fusion of elementwise operations.
struct LinalgElementwiseFusionOptions {
/// Enable fusion of reshapes into the shape with elementwise operations. By
Expand Down
6 changes: 5 additions & 1 deletion mlir/lib/Dialect/Linalg/Transforms/Loops.cpp
Expand Up @@ -597,12 +597,16 @@ struct LowerTiledLoopsToSCF
void runOnFunction() override {
MLIRContext *context = &getContext();
RewritePatternSet patterns(context);
patterns.add<TiledLoopToSCFPattern>(context);
populateTiledLoopToSCFPattern(patterns);
(void)applyPatternsAndFoldGreedily(getFunction(), std::move(patterns));
}
};
} // namespace

void mlir::linalg::populateTiledLoopToSCFPattern(RewritePatternSet &patterns) {
patterns.add<TiledLoopToSCFPattern>(patterns.getContext());
}

std::unique_ptr<OperationPass<FuncOp>>
mlir::createConvertLinalgTiledLoopsToSCFPass() {
return std::make_unique<LowerTiledLoopsToSCF>();
Expand Down

0 comments on commit 335fa18

Please sign in to comment.