diff --git a/mlir/include/mlir/Dialect/Affine/Utils.h b/mlir/include/mlir/Dialect/Affine/Utils.h index 3ea45f235ca967..db5637c024b7f0 100644 --- a/mlir/include/mlir/Dialect/Affine/Utils.h +++ b/mlir/include/mlir/Dialect/Affine/Utils.h @@ -247,10 +247,10 @@ LogicalResult replaceAllMemRefUsesWith(Value oldMemRef, Value newMemRef, /// and updates all its indexing uses. Returns failure if any of its uses /// escape (while leaving the IR in a valid state). template -LogicalResult normalizeMemRef(AllocLikeOp *op); -extern template LogicalResult +FailureOr normalizeMemRef(AllocLikeOp *op); +extern template FailureOr normalizeMemRef(memref::AllocaOp *op); -extern template LogicalResult +extern template FailureOr normalizeMemRef(memref::AllocOp *op); /// Normalizes `memrefType` so that the affine layout map of the memref is diff --git a/mlir/lib/Dialect/Affine/Utils/Utils.cpp b/mlir/lib/Dialect/Affine/Utils/Utils.cpp index cf2f084bba3153..222178904f9546 100644 --- a/mlir/lib/Dialect/Affine/Utils/Utils.cpp +++ b/mlir/lib/Dialect/Affine/Utils/Utils.cpp @@ -1689,7 +1689,7 @@ static void createNewDynamicSizes(MemRefType oldMemRefType, // TODO: Currently works for static memrefs with a single layout map. template -LogicalResult mlir::affine::normalizeMemRef(AllocLikeOp *allocOp) { +FailureOr mlir::affine::normalizeMemRef(AllocLikeOp *allocOp) { MemRefType memrefType = allocOp->getType(); OpBuilder b(*allocOp); @@ -1743,12 +1743,12 @@ LogicalResult mlir::affine::normalizeMemRef(AllocLikeOp *allocOp) { })); oldMemRef.replaceAllUsesWith(newAlloc); allocOp->erase(); - return success(); + return newAlloc; } -template LogicalResult +template FailureOr mlir::affine::normalizeMemRef(memref::AllocaOp *op); -template LogicalResult +template FailureOr mlir::affine::normalizeMemRef(memref::AllocOp *op); MemRefType mlir::affine::normalizeMemRefType(MemRefType memrefType) {