summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2019-04-10 07:10:44 +0000
committerNikita Popov <nikita.ppv@gmail.com>2019-04-10 07:10:44 +0000
commit596cbeb7058b98518952612069e2bb0b13863ef8 (patch)
tree0984a5beac25050ee80f65b8b07fec779033749f /llvm/lib
parent5e13ff1da20bf02bbb256b2006dcbb42e06d300e (diff)
downloadbcm5719-llvm-596cbeb7058b98518952612069e2bb0b13863ef8.tar.gz
bcm5719-llvm-596cbeb7058b98518952612069e2bb0b13863ef8.zip
[InstCombine] Directly call computeOverflow methods in OptimizeOverflowCheck; NFC
Instead of using the willOverflow helpers. This makes it easier to extend handling of AlwaysOverflows. llvm-svn: 358051
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp19
1 files changed, 13 insertions, 6 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
index 3c0ef7e44bf..e274d7efddb 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
@@ -3967,8 +3967,9 @@ bool InstCombiner::OptimizeOverflowCheck(OverflowCheckFlavor OCF, Value *LHS,
if (match(RHS, m_Zero()))
return SetResult(LHS, Builder.getFalse(), false);
+ OverflowResult OR;
if (OCF == OCF_UNSIGNED_ADD) {
- OverflowResult OR = computeOverflowForUnsignedAdd(LHS, RHS, &OrigI);
+ OR = computeOverflowForUnsignedAdd(LHS, RHS, &OrigI);
if (OR == OverflowResult::NeverOverflows)
return SetResult(Builder.CreateNUWAdd(LHS, RHS), Builder.getFalse(),
true);
@@ -3976,7 +3977,8 @@ bool InstCombiner::OptimizeOverflowCheck(OverflowCheckFlavor OCF, Value *LHS,
if (OR == OverflowResult::AlwaysOverflows)
return SetResult(Builder.CreateAdd(LHS, RHS), Builder.getTrue(), true);
} else {
- if (willNotOverflowSignedAdd(LHS, RHS, OrigI))
+ OR = computeOverflowForSignedAdd(LHS, RHS, &OrigI);
+ if (OR == OverflowResult::NeverOverflows)
return SetResult(Builder.CreateNSWAdd(LHS, RHS), Builder.getFalse(),
true);
}
@@ -3989,12 +3991,15 @@ bool InstCombiner::OptimizeOverflowCheck(OverflowCheckFlavor OCF, Value *LHS,
if (match(RHS, m_Zero()))
return SetResult(LHS, Builder.getFalse(), false);
+ OverflowResult OR;
if (OCF == OCF_UNSIGNED_SUB) {
- if (willNotOverflowUnsignedSub(LHS, RHS, OrigI))
+ OR = computeOverflowForUnsignedSub(LHS, RHS, &OrigI);
+ if (OR == OverflowResult::NeverOverflows)
return SetResult(Builder.CreateNUWSub(LHS, RHS), Builder.getFalse(),
true);
} else {
- if (willNotOverflowSignedSub(LHS, RHS, OrigI))
+ OR = computeOverflowForSignedSub(LHS, RHS, &OrigI);
+ if (OR == OverflowResult::NeverOverflows)
return SetResult(Builder.CreateNSWSub(LHS, RHS), Builder.getFalse(),
true);
}
@@ -4015,15 +4020,17 @@ bool InstCombiner::OptimizeOverflowCheck(OverflowCheckFlavor OCF, Value *LHS,
if (match(RHS, m_One()))
return SetResult(LHS, Builder.getFalse(), false);
+ OverflowResult OR;
if (OCF == OCF_UNSIGNED_MUL) {
- OverflowResult OR = computeOverflowForUnsignedMul(LHS, RHS, &OrigI);
+ OR = computeOverflowForUnsignedMul(LHS, RHS, &OrigI);
if (OR == OverflowResult::NeverOverflows)
return SetResult(Builder.CreateNUWMul(LHS, RHS), Builder.getFalse(),
true);
if (OR == OverflowResult::AlwaysOverflows)
return SetResult(Builder.CreateMul(LHS, RHS), Builder.getTrue(), true);
} else {
- if (willNotOverflowSignedMul(LHS, RHS, OrigI))
+ OR = computeOverflowForSignedMul(LHS, RHS, &OrigI);
+ if (OR == OverflowResult::NeverOverflows)
return SetResult(Builder.CreateNSWMul(LHS, RHS), Builder.getFalse(),
true);
}
OpenPOWER on IntegriCloud