[PATCH] D59471: [InstCombine] Fold add nuw + uadd.with.overflow

Sanjay Patel via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Mar 19 11:09:08 PDT 2019


spatel accepted this revision.
spatel added a comment.

Logic looks fine, so I won't hold it up, but seems better to not duplicate code for sibling transforms?

  diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp
  index 49524d7f42e..9de4e60c1b9 100644
  --- a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp
  +++ b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp
  @@ -2046,6 +2046,7 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) {
         return &CI;
       break;
     }
  +  case Intrinsic::uadd_with_overflow:
     case Intrinsic::sadd_with_overflow: {
       if (Instruction *I = canonicalizeConstantArg0ToArg1(CI))
         return I;
  @@ -2053,25 +2054,28 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) {
         return I;
   
       // Given 2 constant operands whose sum does not overflow:
  +    // uaddo (X +nuw C0), C1 -> uaddo X, C0 + C1
       // saddo (X +nsw C0), C1 -> saddo X, C0 + C1
  +    bool IsUnsigned = II->getIntrinsicID() == Intrinsic::uadd_with_overflow;
       Value *X;
       const APInt *C0, *C1;
       Value *Arg0 = II->getArgOperand(0);
       Value *Arg1 = II->getArgOperand(1);
  -    if (match(Arg0, m_NSWAdd(m_Value(X), m_APInt(C0))) &&
  -        match(Arg1, m_APInt(C1))) {
  +    bool HasAdd = IsUnsigned ? match(Arg0, m_NUWAdd(m_Value(X), m_APInt(C0)))
  +                             : match(Arg0, m_NSWAdd(m_Value(X), m_APInt(C0)));
  +    if (HasAdd && match(Arg1, m_APInt(C1))) {
         bool Overflow;
  -      APInt NewC = C1->sadd_ov(*C0, Overflow);
  +      APInt NewC = IsUnsigned ? C1->uadd_ov(*C0, Overflow)
  +                              : C1->sadd_ov(*C0, Overflow);
         if (!Overflow)
           return replaceInstUsesWith(
               *II, Builder.CreateBinaryIntrinsic(
  -                     Intrinsic::sadd_with_overflow, X,
  +                     II->getIntrinsicID(), X,
                        ConstantInt::get(Arg1->getType(), NewC)));
       }
   
       break;
     }
  -  case Intrinsic::uadd_with_overflow:
     case Intrinsic::umul_with_overflow:
     case Intrinsic::smul_with_overflow:
       if (Instruction *I = canonicalizeConstantArg0ToArg1(CI))


CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D59471/new/

https://reviews.llvm.org/D59471





More information about the llvm-commits mailing list