[Mlir-commits] [mlir] [mlir][vector] Use `result` consistently as the result argument name (PR #144739)
Andrzej WarzyĆski
llvmlistbot at llvm.org
Thu Jun 19 02:29:00 PDT 2025
https://github.com/banach-space updated https://github.com/llvm/llvm-project/pull/144739
>From 37ebb1d54736d3c60b90b60018e7a2bbd3287573 Mon Sep 17 00:00:00 2001
From: Andrzej Warzynski <andrzej.warzynski at arm.com>
Date: Wed, 18 Jun 2025 16:57:49 +0100
Subject: [PATCH 1/2] [mlir][vector] Use `result` consistently as the result
argument name
This patch updates the following ops to use `result` (instead of `res`)
as the name for their result argument:
* `vector.scalable.insert`
* `vector.scalable.extract`
* `vector.insert_strided_slice`
This change ensures naming consistency with other ops in the `vector`
dialect. It addresses part of:
* https://github.com/llvm/llvm-project/issues/131602
---
mlir/include/mlir/Dialect/Vector/IR/VectorOps.td | 16 ++++++++--------
1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td b/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
index 8353314ed958b..5373d5e356752 100644
--- a/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
+++ b/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
@@ -959,7 +959,7 @@ def Vector_InsertOp :
def Vector_ScalableInsertOp :
Vector_Op<"scalable.insert", [Pure,
AllElementTypesMatch<["valueToStore", "dest"]>,
- AllTypesMatch<["dest", "res"]>,
+ AllTypesMatch<["dest", "result"]>,
PredOpTrait<"position is a multiple of the source length.",
CPred<
"(getPos() % getSourceVectorType().getNumElements()) == 0"
@@ -967,7 +967,7 @@ def Vector_ScalableInsertOp :
Arguments<(ins VectorOfRank<[1]>:$valueToStore,
ScalableVectorOfRank<[1]>:$dest,
I64Attr:$pos)>,
- Results<(outs ScalableVectorOfRank<[1]>:$res)> {
+ Results<(outs ScalableVectorOfRank<[1]>:$result)> {
let summary = "insert subvector into scalable vector operation";
// NOTE: This operation is designed to map to `llvm.vector.insert`, and its
// documentation should be kept aligned with LLVM IR:
@@ -1015,14 +1015,14 @@ def Vector_ScalableInsertOp :
def Vector_ScalableExtractOp :
Vector_Op<"scalable.extract", [Pure,
- AllElementTypesMatch<["source", "res"]>,
+ AllElementTypesMatch<["source", "result"]>,
PredOpTrait<"position is a multiple of the result length.",
CPred<
"(getPos() % getResultVectorType().getNumElements()) == 0"
>>]>,
Arguments<(ins ScalableVectorOfRank<[1]>:$source,
I64Attr:$pos)>,
- Results<(outs VectorOfRank<[1]>:$res)> {
+ Results<(outs VectorOfRank<[1]>:$result)> {
let summary = "extract subvector from scalable vector operation";
// NOTE: This operation is designed to map to `llvm.vector.extract`, and its
// documentation should be kept aligned with LLVM IR:
@@ -1051,7 +1051,7 @@ def Vector_ScalableExtractOp :
}];
let assemblyFormat = [{
- $source `[` $pos `]` attr-dict `:` type($res) `from` type($source)
+ $source `[` $pos `]` attr-dict `:` type($result) `from` type($source)
}];
let extraClassDeclaration = extraPoisonClassDeclaration # [{
@@ -1059,7 +1059,7 @@ def Vector_ScalableExtractOp :
return ::llvm::cast<VectorType>(getSource().getType());
}
VectorType getResultVectorType() {
- return ::llvm::cast<VectorType>(getRes().getType());
+ return ::llvm::cast<VectorType>(getResult().getType());
}
}];
}
@@ -1068,10 +1068,10 @@ def Vector_InsertStridedSliceOp :
Vector_Op<"insert_strided_slice", [Pure,
PredOpTrait<"operand #0 and result have same element type",
TCresVTEtIsSameAsOpBase<0, 0>>,
- AllTypesMatch<["dest", "res"]>]>,
+ AllTypesMatch<["dest", "result"]>]>,
Arguments<(ins AnyVectorOfNonZeroRank:$valueToStore, AnyVectorOfNonZeroRank:$dest, I64ArrayAttr:$offsets,
I64ArrayAttr:$strides)>,
- Results<(outs AnyVectorOfNonZeroRank:$res)> {
+ Results<(outs AnyVectorOfNonZeroRank:$result)> {
let summary = "strided_slice operation";
let description = [{
Takes a k-D valueToStore vector, an n-D destination vector (n >= k), n-sized
>From b1ed4799a06d1aebb0aad1631b6890170b5a6eaf Mon Sep 17 00:00:00 2001
From: Andrzej Warzynski <andrzej.warzynski at arm.com>
Date: Thu, 19 Jun 2025 10:28:42 +0100
Subject: [PATCH 2/2] fixup! [mlir][vector] Use `result` consistently as the
result argument name
Add deprecated wrappers
---
mlir/include/mlir/Dialect/Vector/IR/VectorOps.td | 12 ++++++++++++
1 file changed, 12 insertions(+)
diff --git a/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td b/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
index 5373d5e356752..3b577625f351f 100644
--- a/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
+++ b/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
@@ -1010,6 +1010,10 @@ def Vector_ScalableInsertOp :
VectorType getDestVectorType() {
return ::llvm::cast<VectorType>(getDest().getType());
}
+ /// Wrapper for getResult, which replaced getRes.
+ [[deprecated("Use getResult instead!")]] ::mlir::Value getRes() {
+ return getResult();
+ }
}];
}
@@ -1061,6 +1065,10 @@ def Vector_ScalableExtractOp :
VectorType getResultVectorType() {
return ::llvm::cast<VectorType>(getResult().getType());
}
+ /// Wrapper for getResult, which replaced getRes.
+ [[deprecated("Use getResult instead!")]] ::mlir::Value getRes() {
+ return getResult();
+ }
}];
}
@@ -1115,6 +1123,10 @@ def Vector_InsertStridedSliceOp :
return ::llvm::cast<IntegerAttr>(attr).getInt() != 1;
});
}
+ /// Wrapper for getResult, which replaced getRes.
+ [[deprecated("Use getResult instead!")]] ::mlir::Value getRes() {
+ return getResult();
+ }
}];
let hasFolder = 1;
More information about the Mlir-commits
mailing list