diff --git a/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td b/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td --- a/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td +++ b/mlir/include/mlir/Dialect/StandardOps/IR/Ops.td @@ -371,7 +371,7 @@ operands. For example: ```mlir - %0 = alloca() : memref<8x64xf32> + %0 = alloca() : memref<8x64xf32> ``` The optional list of dimension operands are bound to the dynamic dimensions @@ -379,7 +379,7 @@ bound to the second dimension of the memref (which is dynamic). ```mlir - %0 = alloca(%d) : memref<8x?xf32> + %0 = alloca(%d) : memref<8x?xf32> ``` The optional list of symbol operands are bound to the symbols of the @@ -387,7 +387,7 @@ the symbol 's0' in the affine map specified in the allocs memref type. ```mlir - %0 = alloca()[%s] : memref<8x64xf32, + %0 = alloca()[%s] : memref<8x64xf32, affine_map<(d0, d1)[s0] -> ((d0 + s0), d1)>> ``` @@ -433,6 +433,26 @@ let hasFolder = 1; } +//===----------------------------------------------------------------------===// +// AssertOp +//===----------------------------------------------------------------------===// + +def AssertOp : Std_Op<"assert"> { + let summary = "Assert operation with message attribute"; + let description = [{ + Assert operation with single Boolean operand and a message attribute. + If the Boolean operand is not true then the message will be printed and program execution aborts. + }]; + + let arguments = (ins I1:$arg, StrAttr:$msg); + let results = (outs); + + let assemblyFormat = "$arg `,` $msg attr-dict"; + + // AssertOp is fully verified by its traits. + let verifier = ?; +} + //===----------------------------------------------------------------------===// // AssumeAlignmentOp //===----------------------------------------------------------------------===// diff --git a/mlir/test/Dialect/Standard/ops.mlir b/mlir/test/Dialect/Standard/ops.mlir --- a/mlir/test/Dialect/Standard/ops.mlir +++ b/mlir/test/Dialect/Standard/ops.mlir @@ -18,3 +18,7 @@ return %0 : tensor } +func @assert(%arg : i1) { + assert %arg, "Some message in case this assertion fails." + return +}