[Mlir-commits] [mlir] [MLIR][Vector] Implement memory effects for print (PR #80400)
lorenzo chelini
llvmlistbot at llvm.org
Fri Feb 2 00:10:27 PST 2024
https://github.com/chelini created https://github.com/llvm/llvm-project/pull/80400
Add write memory effect for the print operation. The exact memory behavior is implemented in other print-like operations such as `transform::PrintOp` or `gpu::printf`.
Providing memory behavior allows using the operation in passes like buffer deallocation instead of emitting an error.
>From ac66fd7a5261d83209ec274345aa06d21e9d5c9b Mon Sep 17 00:00:00 2001
From: Lorenzo Chelini <l.chelini at icloud.com>
Date: Fri, 26 Jan 2024 21:53:41 +0100
Subject: [PATCH] [MLIR][Vector] Implement memory effects for print
Add write memory effect for the print operation. The exact memory
behavior is implemented in other print-like operations such as
`transform::PrintOp` or `gpu::printf`.
Providing memory behavior allows using the operation in passes like
buffer deallocation instead of emitting an error.
---
mlir/include/mlir/Dialect/Vector/IR/VectorOps.td | 1 +
.../OwnershipBasedBufferDeallocation/dealloc-other.mlir | 9 +++++++++
2 files changed, 10 insertions(+)
diff --git a/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td b/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
index fdf51f0173511..bc08f8d07fb0d 100644
--- a/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
+++ b/mlir/include/mlir/Dialect/Vector/IR/VectorOps.td
@@ -2497,6 +2497,7 @@ def Vector_TransposeOp :
def Vector_PrintOp :
Vector_Op<"print", [
+ MemoryEffects<[MemWrite]>,
PredOpTrait<
"`source` or `punctuation` are not set when printing strings",
CPred<"!getStringLiteral() || (!getSource() && getPunctuation() == PrintPunctuation::NewLine)">
diff --git a/mlir/test/Dialect/Bufferization/Transforms/OwnershipBasedBufferDeallocation/dealloc-other.mlir b/mlir/test/Dialect/Bufferization/Transforms/OwnershipBasedBufferDeallocation/dealloc-other.mlir
index 9bfa91589482b..4fae622c510a2 100644
--- a/mlir/test/Dialect/Bufferization/Transforms/OwnershipBasedBufferDeallocation/dealloc-other.mlir
+++ b/mlir/test/Dialect/Bufferization/Transforms/OwnershipBasedBufferDeallocation/dealloc-other.mlir
@@ -38,3 +38,12 @@ func.func @no_side_effects() {
"test.unregistered_op_foo"(%0) : (memref<5xf32>) -> ()
return
}
+
+// -----
+
+// Buffer deallocation should not emit any error here as the operation does not
+// operate on buffer and has known memory effect (write).
+func.func @no_buffer_semantics_with_write_effect(%v0: vector<9x6xf32>) {
+ vector.print %v0 : vector<9x6xf32>
+ return
+}
More information about the Mlir-commits
mailing list