forked from OSchip/llvm-project
[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
This commit is contained in:
parent
59387c0dd7
commit
16c642fa39
|
@ -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;
|
||||
|
|
|
@ -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
|
||||
|
|
Loading…
Reference in New Issue