diff --git a/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp b/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp --- a/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp +++ b/mlir/lib/Dialect/Linalg/IR/LinalgOps.cpp @@ -1453,7 +1453,8 @@ template static void printCommonStructuredOpParts(OpAsmPrinter &p, NamedStructuredOpType op) { - p << " ins(" << op.inputs() << " : " << op.inputs().getTypes() << ")"; + if (!op.inputs().empty()) + p << " ins(" << op.inputs() << " : " << op.inputs().getTypes() << ")"; if (!op.output_buffers().empty()) p << " outs(" << op.output_buffers() << " : " << op.output_buffers().getTypes() << ")"; diff --git a/mlir/test/Dialect/Linalg/roundtrip.mlir b/mlir/test/Dialect/Linalg/roundtrip.mlir --- a/mlir/test/Dialect/Linalg/roundtrip.mlir +++ b/mlir/test/Dialect/Linalg/roundtrip.mlir @@ -319,6 +319,18 @@ // CHECK-SAME: outs({{.*}} : memref) // CHECK-SAME: {foo = 1 : i64} +#map0 = affine_map<(d0, d1, d2) -> (d0, d1, d2)> +func @generic_without_inputs(%arg0 : memref) { + linalg.generic {indexing_maps = [#map0], + iterator_types = ["parallel", "parallel", "parallel"]} + outs(%arg0 : memref) { + ^bb0(%arg3: f32): // no predecessors + %cst = constant 0.000000e+00 : f32 + linalg.yield %cst : f32 + } + return +} + func @generic_with_tensor_input(%arg0: tensor>, %arg1: memref) { linalg.generic #trait