1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
// RUN: mlir-pdll %s -I %S -split-input-file -x mlir | FileCheck %s
//===----------------------------------------------------------------------===//
// EraseStmt
//===----------------------------------------------------------------------===//
// CHECK: pdl.pattern @EraseStmt
// CHECK: %[[OP:.*]] = operation
// CHECK: rewrite %[[OP]]
// CHECK: erase %[[OP]]
Pattern EraseStmt => erase op<>;
// -----
// CHECK: pdl.pattern @EraseStmtNested
// CHECK: %[[OP:.*]] = operation
// CHECK: rewrite %[[OP]]
// CHECK: erase %[[OP]]
Pattern EraseStmtNested => rewrite root: Op with { erase root; };
// -----
//===----------------------------------------------------------------------===//
// ReplaceStmt
//===----------------------------------------------------------------------===//
// CHECK: pdl.pattern @ReplaceStmt
// CHECK: %[[OPERANDS:.*]] = operands
// CHECK: %[[OP:.*]] = operation(%[[OPERANDS]]
// CHECK: rewrite %[[OP]]
// CHECK: replace %[[OP]] with(%[[OPERANDS]] : !pdl.range<value>)
Pattern ReplaceStmt => replace op<>(operands: ValueRange) with operands;
// -----
// CHECK: pdl.pattern @ReplaceStmtNested
// CHECK: %[[OPERANDS:.*]] = operands
// CHECK: %[[OP:.*]] = operation(%[[OPERANDS]]
// CHECK: rewrite %[[OP]]
// CHECK: replace %[[OP]] with(%[[OPERANDS]] : !pdl.range<value>)
Pattern ReplaceStmtNested {
let root = op<>(operands: ValueRange);
rewrite root with { replace root with operands; };
}
// -----
//===----------------------------------------------------------------------===//
// RewriteStmt
//===----------------------------------------------------------------------===//
// CHECK: pdl.pattern @RewriteStmtNested
// CHECK: %[[OP:.*]] = operation
// CHECK: rewrite %[[OP]]
// CHECK: erase %[[OP]]
Pattern RewriteStmtNested {
rewrite root: Op with {
rewrite root with { erase root; };
};
}
|