summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSanjay Patel <spatel@rotateright.com>2016-05-17 20:20:40 +0000
committerSanjay Patel <spatel@rotateright.com>2016-05-17 20:20:40 +0000
commit22b01febd4a92a0f38febf5aec6cf4e0de04fd8d (patch)
tree0788e593b94fb0ae9bd8516e3d39c678a0ae095e
parent12de0b91ac1f585ed7d11a25fc7cb841a1826aa3 (diff)
downloadbcm5719-llvm-22b01febd4a92a0f38febf5aec6cf4e0de04fd8d.tar.gz
bcm5719-llvm-22b01febd4a92a0f38febf5aec6cf4e0de04fd8d.zip
[InstCombine] add another test for wrong icmp constant (PR27792)
It doesn't matter if the comparison is unsigned; the inc/dec is always signed. llvm-svn: 269831
-rw-r--r--llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp2
-rw-r--r--llvm/test/Transforms/InstCombine/icmp.ll11
2 files changed, 11 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
index f51cf7321f2..6a38baefe5a 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
@@ -3150,7 +3150,7 @@ static ICmpInst *canonicalizeCmpWithConstant(ICmpInst &I) {
// Increment or decrement the constant and set the new comparison predicate:
// ULE -> ULT ; UGE -> UGT ; SLE -> SLT ; SGE -> SGT
- Constant *OneOrNegOne = ConstantInt::get(Op1Type, IsLE ? 1 : -1, IsSigned);
+ Constant *OneOrNegOne = ConstantInt::get(Op1Type, IsLE ? 1 : -1, true);
CmpInst::Predicate NewPred = IsLE ? ICmpInst::ICMP_ULT: ICmpInst::ICMP_UGT;
NewPred = IsSigned ? ICmpInst::getSignedPredicate(NewPred) : NewPred;
return new ICmpInst(NewPred, Op0, ConstantExpr::getAdd(Op1C, OneOrNegOne));
diff --git a/llvm/test/Transforms/InstCombine/icmp.ll b/llvm/test/Transforms/InstCombine/icmp.ll
index 099d15944ab..4575e1017ff 100644
--- a/llvm/test/Transforms/InstCombine/icmp.ll
+++ b/llvm/test/Transforms/InstCombine/icmp.ll
@@ -2098,7 +2098,7 @@ return: ; preds = %if.end, %entry, %if
ret void
}
-; When canonicalizing to 'sgt', make sure the constant is correct.
+; When canonicalizing to 'gt/lt', make sure the constant is correct.
define i1 @PR27792(i128 %a) {
; CHECK-LABEL: @PR27792(
@@ -2109,3 +2109,12 @@ define i1 @PR27792(i128 %a) {
ret i1 %cmp
}
+define i1 @PR27792_2(i128 %a) {
+; CHECK-LABEL: @PR27792_2(
+; CHECK-NEXT: [[B:%.*]] = icmp ne i128 %a, 0
+; CHECK-NEXT: ret i1 [[B]]
+;
+ %b = icmp uge i128 %a, 1
+ ret i1 %b
+}
+
OpenPOWER on IntegriCloud