[Mlir-commits] [mlir] [mlir][vectorize] Support affine.apply in SuperVectorize (PR #77968)
Sergei Grechanik
llvmlistbot at llvm.org
Thu Feb 15 18:39:26 PST 2024
================
@@ -1184,10 +1202,15 @@ static Operation *vectorizeAffineLoad(AffineLoadOp loadOp,
SmallVector<Value, 8> indices;
indices.reserve(memRefType.getRank());
if (loadOp.getAffineMap() !=
- state.builder.getMultiDimIdentityMap(memRefType.getRank()))
+ state.builder.getMultiDimIdentityMap(memRefType.getRank())) {
+ // Check the operand in loadOp affine map does not come from AffineApplyOp.
+ for (auto op : mapOperands) {
+ if (op.getDefiningOp<AffineApplyOp>())
+ return nullptr;
+ }
computeMemoryOpIndices(loadOp, loadOp.getAffineMap(), mapOperands, state,
indices);
- else
+ } else
----------------
sergei-grechanik wrote:
nit: the else branch must be surrounded with braces since the first branch is surrounded.
https://github.com/llvm/llvm-project/pull/77968
More information about the Mlir-commits
mailing list