diff options
Diffstat (limited to 'mlir/lib/Dialect/Affine/Utils/Utils.cpp')
-rw-r--r-- | mlir/lib/Dialect/Affine/Utils/Utils.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/mlir/lib/Dialect/Affine/Utils/Utils.cpp b/mlir/lib/Dialect/Affine/Utils/Utils.cpp index 4d3ead20..9e3257a 100644 --- a/mlir/lib/Dialect/Affine/Utils/Utils.cpp +++ b/mlir/lib/Dialect/Affine/Utils/Utils.cpp @@ -51,12 +51,14 @@ public: loc(loc) {} template <typename OpTy> - Value buildBinaryExpr(AffineBinaryOpExpr expr) { + Value buildBinaryExpr(AffineBinaryOpExpr expr, + arith::IntegerOverflowFlags overflowFlags = + arith::IntegerOverflowFlags::none) { auto lhs = visit(expr.getLHS()); auto rhs = visit(expr.getRHS()); if (!lhs || !rhs) return nullptr; - auto op = builder.create<OpTy>(loc, lhs, rhs); + auto op = builder.create<OpTy>(loc, lhs, rhs, overflowFlags); return op.getResult(); } @@ -65,7 +67,8 @@ public: } Value visitMulExpr(AffineBinaryOpExpr expr) { - return buildBinaryExpr<arith::MulIOp>(expr); + return buildBinaryExpr<arith::MulIOp>(expr, + arith::IntegerOverflowFlags::nsw); } /// Euclidean modulo operation: negative RHS is not allowed. |