aboutsummaryrefslogtreecommitdiff
path: root/mlir/lib/Dialect/Affine/Utils/Utils.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'mlir/lib/Dialect/Affine/Utils/Utils.cpp')
-rw-r--r--mlir/lib/Dialect/Affine/Utils/Utils.cpp9
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.