diff --git a/mlir/lib/Dialect/Linalg/Transforms/LinalgToLoops.cpp b/mlir/lib/Dialect/Linalg/Transforms/LinalgToLoops.cpp --- a/mlir/lib/Dialect/Linalg/Transforms/LinalgToLoops.cpp +++ b/mlir/lib/Dialect/Linalg/Transforms/LinalgToLoops.cpp @@ -652,8 +652,8 @@ linalgOp.indexing_maps().template getAsRange(); auto maps = functional::map([](AffineMapAttr a) { return a.getValue(); }, mapsRange); - auto invertedMap = inversePermutation(concatAffineMaps(maps)); - if (!invertedMap) { + AffineMap invertedMap = inversePermutation(concatAffineMaps(maps)); + if (invertedMap.isEmpty()) { LinalgScopedEmitter::emitScalarImplementation( {}, linalgOp); return LinalgLoops(); diff --git a/mlir/test/Dialect/Linalg/loops.mlir b/mlir/test/Dialect/Linalg/loops.mlir --- a/mlir/test/Dialect/Linalg/loops.mlir +++ b/mlir/test/Dialect/Linalg/loops.mlir @@ -913,3 +913,46 @@ // CHECKPARALLEL: %[[CONST:.*]] = constant 1.000000e+00 : f32 // CHECKPARALLEL: loop.parallel (%[[i:.*]]) // CHECKPARALLEL: store %[[CONST]], %[[ARG0]] + +#scalar_access = [ + affine_map<() -> ()>, + affine_map<() -> ()>, + affine_map<() -> ()> +] +#scalar_trait = { + args_in = 2, + args_out = 1, + iterator_types = [], + indexing_maps = #scalar_access, + library_call = "some_external_fn" +} +func @scalar_code(%arg0: memref, %arg1 : memref, %arg2 : memref) +{ + linalg.generic #scalar_trait %arg0, %arg1, %arg2 { + ^bb(%a : f32, %b : f32, %c : f32) : + %0 = addf %a, %b : f32 + linalg.yield %0 : f32 + } : memref, memref, memref + return +} +// CHECKLOOP-LABEL: @scalar_code +// CHECKLOOP-SAME: %[[ARG0]]: memref +// CHECKLOOP-SAME: %[[ARG1]]: memref +// CHECKLOOP-SAME: %[[ARG2]]: memref +// CHECKLOOP-NOT: loop.for +// CHECKLOOP-DAG: load %[[ARG0]][] +// CHECKLOOP-DAG: load %[[ARG1]][] +// CHECKLOOP-DAG: load %[[ARG2]][] +// CHECKLOOP: addf +// CHECKLOOP: store %{{.*}}, %[[ARG2]][] + +// CHECKPARALLEL-LABEL: @scalar_code +// CHECKPARALLEL-SAME: %[[ARG0]]: memref +// CHECKPARALLEL-SAME: %[[ARG1]]: memref +// CHECKPARALLEL-SAME: %[[ARG2]]: memref +// CHECKPARALLEL-NOT: loop.for +// CHECKPARALLEL-DAG: load %[[ARG0]][] +// CHECKPARALLEL-DAG: load %[[ARG1]][] +// CHECKPARALLEL-DAG: load %[[ARG2]][] +// CHECKPARALLEL: addf +// CHECKPARALLEL: store %{{.*}}, %[[ARG2]][]