forked from OSchip/llvm-project
[InstCombine] (-NSW x) s<= x --> x s>= 0 (PR39480)
Name: (-x) s<= x --> x >= 0 %neg_x = sub nsw i8 0, %x ; %x must not be INT_MIN %r = icmp sle i8 %neg_x, %x => %r = icmp sge i8 %x, 0 https://rise4fun.com/Alive/91k https://bugs.llvm.org/show_bug.cgi?id=39480
This commit is contained in:
parent
01a6c4bd26
commit
59387c0dd7
|
@ -3743,6 +3743,11 @@ Instruction *foldICmpXNegX(ICmpInst &I) {
|
|||
NewRHS = Constant::getNullValue(X->getType());
|
||||
break;
|
||||
|
||||
case ICmpInst::ICMP_SLE:
|
||||
NewPred = ICmpInst::ICMP_SGE;
|
||||
NewRHS = Constant::getNullValue(X->getType());
|
||||
break;
|
||||
|
||||
case ICmpInst::ICMP_EQ:
|
||||
case ICmpInst::ICMP_NE:
|
||||
NewPred = Pred;
|
||||
|
|
|
@ -61,8 +61,7 @@ define i1 @t2(i8 %x) {
|
|||
|
||||
define i1 @t3(i8 %x) {
|
||||
; CHECK-LABEL: @t3(
|
||||
; CHECK-NEXT: [[NEG_X:%.*]] = sub nsw i8 0, [[X:%.*]]
|
||||
; CHECK-NEXT: [[CMP:%.*]] = icmp sle i8 [[NEG_X]], [[X]]
|
||||
; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i8 [[X:%.*]], -1
|
||||
; CHECK-NEXT: ret i1 [[CMP]]
|
||||
;
|
||||
%neg_x = sub nsw i8 0, %x
|
||||
|
|
Loading…
Reference in New Issue