From 16c642fa39d50dd066e364e0f258140a3dbaa64b Mon Sep 17 00:00:00 2001 From: Roman Lebedev Date: Thu, 6 Aug 2020 11:20:04 +0300 Subject: [PATCH] [InstCombine] (-NSW x) u> x --> x s> 0 (PR39480) Name: (-x) u> x --> x s> 0 %neg_x = sub nsw i8 0, %x ; %x must not be INT_MIN %r = icmp ugt i8 %neg_x, %x => %r = icmp sgt i8 %x, 0 https://rise4fun.com/Alive/Raea https://bugs.llvm.org/show_bug.cgi?id=39480 --- llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp | 5 +++++ llvm/test/Transforms/InstCombine/cmp-x-vs-neg-x.ll | 3 +-- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp index a2c1816fb8c1..59e5f5ad0a4f 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp @@ -3748,6 +3748,11 @@ Instruction *foldICmpXNegX(ICmpInst &I) { NewRHS = Constant::getNullValue(X->getType()); break; + case ICmpInst::ICMP_UGT: + NewPred = ICmpInst::ICMP_SGT; + NewRHS = Constant::getNullValue(X->getType()); + break; + case ICmpInst::ICMP_EQ: case ICmpInst::ICMP_NE: NewPred = Pred; diff --git a/llvm/test/Transforms/InstCombine/cmp-x-vs-neg-x.ll b/llvm/test/Transforms/InstCombine/cmp-x-vs-neg-x.ll index 594e84b5ce64..c2cbeab9ed91 100644 --- a/llvm/test/Transforms/InstCombine/cmp-x-vs-neg-x.ll +++ b/llvm/test/Transforms/InstCombine/cmp-x-vs-neg-x.ll @@ -71,8 +71,7 @@ define i1 @t3(i8 %x) { define i1 @t4(i8 %x) { ; CHECK-LABEL: @t4( -; CHECK-NEXT: [[NEG_X:%.*]] = sub nsw i8 0, [[X:%.*]] -; CHECK-NEXT: [[CMP:%.*]] = icmp ugt i8 [[NEG_X]], [[X]] +; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i8 [[X:%.*]], 0 ; CHECK-NEXT: ret i1 [[CMP]] ; %neg_x = sub nsw i8 0, %x