aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJulian Gross <julian.gross@dfki.de>2020-04-22 11:22:43 +0200
committerJulian Gross <julian.gross@dfki.de>2020-04-27 12:17:18 +0200
commit262108e12ed92d54aafab4db80fa97af14570e9a (patch)
tree75a281c8649bf3277cef47841099143279c3f2f1
parent848876368235643fef2eb87783da97840549ca4a (diff)
downloadllvm-262108e12ed92d54aafab4db80fa97af14570e9a.zip
llvm-262108e12ed92d54aafab4db80fa97af14570e9a.tar.gz
llvm-262108e12ed92d54aafab4db80fa97af14570e9a.tar.bz2
[mlir] Extended Alloc and Dealloc operations with memory-effect traits.
Extended standard Alloc and Dealloc operations with memory-effect traits. Differential Revision: https://reviews.llvm.org/D78619
-rw-r--r--mlir/include/mlir/Dialect/StandardOps/IR/Ops.td12
1 files changed, 7 insertions, 5 deletions
diff --git a/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td b/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td
index eba2fc5..17b95939 100644
--- a/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td
+++ b/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td
@@ -129,12 +129,14 @@ class FloatArithmeticOp<string mnemonic, list<OpTrait> traits = []> :
//
// %0 = alloclike(%m)[%s] : memref<8x?xf32, (d0, d1)[s0] -> ((d0 + s0), d1)>
//
-class AllocLikeOp<string mnemonic, list<OpTrait> traits = []> :
+class AllocLikeOp<string mnemonic,
+ list<OpVariableDecorator> resultDecorators = [],
+ list<OpTrait> traits = []> :
Std_Op<mnemonic, traits> {
let arguments = (ins Variadic<Index>:$value,
Confined<OptionalAttr<I64Attr>, [IntMinValue<0>]>:$alignment);
- let results = (outs AnyMemRef);
+ let results = (outs Arg<AnyMemRef, "", resultDecorators>);
let builders = [OpBuilder<
"Builder *builder, OperationState &result, MemRefType memrefType", [{
@@ -276,7 +278,7 @@ def AddIOp : IntArithmeticOp<"addi", [Commutative]> {
// AllocOp
//===----------------------------------------------------------------------===//
-def AllocOp : AllocLikeOp<"alloc"> {
+def AllocOp : AllocLikeOp<"alloc", [MemAlloc], [MemoryEffects<[MemAlloc]>]> {
let summary = "memory allocation operation";
let description = [{
The `alloc` operation allocates a region of memory, as specified by its
@@ -1253,7 +1255,7 @@ def CosOp : FloatUnaryOp<"cos"> {
// DeallocOp
//===----------------------------------------------------------------------===//
-def DeallocOp : Std_Op<"dealloc"> {
+def DeallocOp : Std_Op<"dealloc", [MemoryEffects<[MemFree]>]> {
let summary = "memory deallocation operation";
let description = [{
The `dealloc` operation frees the region of memory referenced by a memref
@@ -1269,7 +1271,7 @@ def DeallocOp : Std_Op<"dealloc"> {
```
}];
- let arguments = (ins AnyMemRef:$memref);
+ let arguments = (ins Arg<AnyMemRef, "", [MemFree]>:$memref);
let hasCanonicalizer = 1;
let hasFolder = 1;