[Mlir-commits] [mlir] 9926ad1 - [mlir] Move getDimsOfType to StructuredOpsUtils.h.
Oleg Shyshkov
llvmlistbot at llvm.org
Wed Sep 21 05:49:53 PDT 2022
Author: Oleg Shyshkov
Date: 2022-09-21T12:49:25Z
New Revision: 9926ad17525a3424618b710a5bb882b392793e8d
URL: https://github.com/llvm/llvm-project/commit/9926ad17525a3424618b710a5bb882b392793e8d
DIFF: https://github.com/llvm/llvm-project/commit/9926ad17525a3424618b710a5bb882b392793e8d.diff
LOG: [mlir] Move getDimsOfType to StructuredOpsUtils.h.
Summary:
This change will bring all helpers that work with iterator types to one place.
Currently getDimsOfType is is declared in Linalg.h, but not directly included by
LinalgInterfaces. It worked so far only because all the places that include
LinalgInterfaces.h also include Linalg.h directly or indirectly.
Differential Revision: https://reviews.llvm.org/D134350
Added:
Modified:
mlir/include/mlir/Dialect/Linalg/IR/Linalg.h
mlir/include/mlir/Dialect/Linalg/IR/LinalgInterfaces.td
mlir/include/mlir/Dialect/Utils/StructuredOpsUtils.h
mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp
Removed:
################################################################################
diff --git a/mlir/include/mlir/Dialect/Linalg/IR/Linalg.h b/mlir/include/mlir/Dialect/Linalg/IR/Linalg.h
index 4cf2e93823e1c..70e7fc9778632 100644
--- a/mlir/include/mlir/Dialect/Linalg/IR/Linalg.h
+++ b/mlir/include/mlir/Dialect/Linalg/IR/Linalg.h
@@ -69,11 +69,6 @@ AffineMap extractOrIdentityMap(Optional<AffineMap> maybeMap, unsigned rank,
SmallVector<AffineExpr, 4> concat(ArrayRef<AffineExpr> a,
ArrayRef<AffineExpr> b);
-/// Return the dims that are `iteratorTypeName` loops in the LinalgOp `op`.
-/// Assumes `op` is a LinalgOp.
-void getDimsOfType(Operation *op, StringRef iteratorTypeName,
- SmallVectorImpl<unsigned> &res);
-
} // namespace linalg
} // namespace mlir
diff --git a/mlir/include/mlir/Dialect/Linalg/IR/LinalgInterfaces.td b/mlir/include/mlir/Dialect/Linalg/IR/LinalgInterfaces.td
index 513aedcb82c4c..bf2509f23beb3 100644
--- a/mlir/include/mlir/Dialect/Linalg/IR/LinalgInterfaces.td
+++ b/mlir/include/mlir/Dialect/Linalg/IR/LinalgInterfaces.td
@@ -206,7 +206,8 @@ def LinalgStructuredInterface : OpInterface<"LinalgOp"> {
/*args=*/(ins "SmallVectorImpl<unsigned> &":$res),
/*methodBody=*/"",
/*defaultImplementation=*/[{
- return getDimsOfType($_op, getParallelIteratorTypeName(), res);
+ return findPositionsOfType($_op.iterator_types(),
+ getParallelIteratorTypeName(), res);
}]
>,
InterfaceMethod<
@@ -231,7 +232,8 @@ def LinalgStructuredInterface : OpInterface<"LinalgOp"> {
/*args=*/(ins "SmallVectorImpl<unsigned> &":$res),
/*methodBody=*/"",
/*defaultImplementation=*/[{
- return getDimsOfType($_op, getReductionIteratorTypeName(), res);
+ return findPositionsOfType($_op.iterator_types(),
+ getReductionIteratorTypeName(), res);
}]
>,
InterfaceMethod<
@@ -256,7 +258,8 @@ def LinalgStructuredInterface : OpInterface<"LinalgOp"> {
/*args=*/(ins "SmallVectorImpl<unsigned> &":$res),
/*methodBody=*/"",
/*defaultImplementation=*/[{
- return getDimsOfType($_op.getOperation(), getWindowIteratorTypeName(), res);
+ return findPositionsOfType($_op.iterator_types(),
+ getWindowIteratorTypeName(), res);
}]
>,
InterfaceMethod<
diff --git a/mlir/include/mlir/Dialect/Utils/StructuredOpsUtils.h b/mlir/include/mlir/Dialect/Utils/StructuredOpsUtils.h
index 9dfde80e793bd..fd470c1330841 100644
--- a/mlir/include/mlir/Dialect/Utils/StructuredOpsUtils.h
+++ b/mlir/include/mlir/Dialect/Utils/StructuredOpsUtils.h
@@ -110,6 +110,17 @@ inline unsigned getNumIterators(ArrayAttr iteratorTypes) {
return res;
}
+/// Return positions in `iteratorTypes` that match `iteratorTypeName`.
+inline void findPositionsOfType(ArrayAttr iteratorTypes,
+ StringRef iteratorTypeName,
+ SmallVectorImpl<unsigned> &res) {
+ for (const auto &en :
+ llvm::enumerate(iteratorTypes.getAsValueRange<StringAttr>())) {
+ if (en.value() == iteratorTypeName)
+ res.push_back(en.index());
+ }
+}
+
/// Helper StructuredGenerator class to manipulate and rewrite ops with
/// `StructuredOpInterface`. This is templated for now because VectorOps do not
/// yet implement the StructuredOpInterface itself.
diff --git a/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp b/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp
index 5190073902e0a..c088310eddc2d 100644
--- a/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp
+++ b/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp
@@ -1540,22 +1540,6 @@ LogicalResult IndexOp::verify() {
#define GET_OP_CLASSES
#include "mlir/Dialect/Linalg/IR/LinalgStructuredOps.cpp.inc"
-/// Return the dims that are `iteratorTypeName` loops in the LinalgOp `op`.
-/// Assumes `op` is a LinalgOp.
-void mlir::linalg::getDimsOfType(Operation *op, StringRef iteratorTypeName,
- SmallVectorImpl<unsigned> &res) {
- if (!cast<LinalgOp>(op).iterator_types())
- return;
-
- unsigned dim = 0;
- for (auto tn :
- cast<LinalgOp>(op).iterator_types().getAsValueRange<StringAttr>()) {
- if (tn == iteratorTypeName)
- res.push_back(dim);
- ++dim;
- }
-}
-
AffineMap mlir::linalg::extractOrIdentityMap(Optional<AffineMap> maybeMap,
unsigned rank,
MLIRContext *context) {
More information about the Mlir-commits
mailing list