diff options
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/include/llvm/Constants.h | 1 | ||||
| -rw-r--r-- | llvm/include/llvm/InstrTypes.h | 21 | ||||
| -rw-r--r-- | llvm/include/llvm/Support/ConstantFolder.h | 3 | ||||
| -rw-r--r-- | llvm/include/llvm/Support/IRBuilder.h | 6 | ||||
| -rw-r--r-- | llvm/include/llvm/Support/NoFolder.h | 3 | ||||
| -rw-r--r-- | llvm/include/llvm/Support/TargetFolder.h | 3 | ||||
| -rw-r--r-- | llvm/lib/VMCore/Constants.cpp | 5 | 
7 files changed, 42 insertions, 0 deletions
| diff --git a/llvm/include/llvm/Constants.h b/llvm/include/llvm/Constants.h index 7440f99c50d..79c1eaab8b5 100644 --- a/llvm/include/llvm/Constants.h +++ b/llvm/include/llvm/Constants.h @@ -695,6 +695,7 @@ public:    static Constant *getNSWNeg(Constant *C);    static Constant *getNSWAdd(Constant *C1, Constant *C2);    static Constant *getNSWSub(Constant *C1, Constant *C2); +  static Constant *getNSWMul(Constant *C1, Constant *C2);    static Constant *getExactSDiv(Constant *C1, Constant *C2);    /// Transparently provide more efficient getOperand methods. diff --git a/llvm/include/llvm/InstrTypes.h b/llvm/include/llvm/InstrTypes.h index b25290226bb..109aa2605b8 100644 --- a/llvm/include/llvm/InstrTypes.h +++ b/llvm/include/llvm/InstrTypes.h @@ -277,6 +277,27 @@ public:      return BO;    } +  /// CreateNSWMul - Create a Mul operator with the NSW flag set. +  /// +  static BinaryOperator *CreateNSWMul(Value *V1, Value *V2, +                                      const Twine &Name = "") { +    BinaryOperator *BO = CreateMul(V1, V2, Name); +    BO->setHasNoSignedWrap(true); +    return BO; +  } +  static BinaryOperator *CreateNSWMul(Value *V1, Value *V2, +                                      const Twine &Name, BasicBlock *BB) { +    BinaryOperator *BO = CreateMul(V1, V2, Name, BB); +    BO->setHasNoSignedWrap(true); +    return BO; +  } +  static BinaryOperator *CreateNSWMul(Value *V1, Value *V2, +                                      const Twine &Name, Instruction *I) { +    BinaryOperator *BO = CreateMul(V1, V2, Name, I); +    BO->setHasNoSignedWrap(true); +    return BO; +  } +    /// CreateExactSDiv - Create an SDiv operator with the exact flag set.    ///    static BinaryOperator *CreateExactSDiv(Value *V1, Value *V2, diff --git a/llvm/include/llvm/Support/ConstantFolder.h b/llvm/include/llvm/Support/ConstantFolder.h index eea33dfff61..1339e9fac6a 100644 --- a/llvm/include/llvm/Support/ConstantFolder.h +++ b/llvm/include/llvm/Support/ConstantFolder.h @@ -54,6 +54,9 @@ public:    Constant *CreateMul(Constant *LHS, Constant *RHS) const {      return ConstantExpr::getMul(LHS, RHS);    } +  Constant *CreateNSWMul(Constant *LHS, Constant *RHS) const { +    return ConstantExpr::getNSWMul(LHS, RHS); +  }    Constant *CreateFMul(Constant *LHS, Constant *RHS) const {      return ConstantExpr::getFMul(LHS, RHS);    } diff --git a/llvm/include/llvm/Support/IRBuilder.h b/llvm/include/llvm/Support/IRBuilder.h index 22b05d6a10d..543ea856ad9 100644 --- a/llvm/include/llvm/Support/IRBuilder.h +++ b/llvm/include/llvm/Support/IRBuilder.h @@ -353,6 +353,12 @@ public:          return Folder.CreateMul(LC, RC);      return Insert(BinaryOperator::CreateMul(LHS, RHS), Name);    } +  Value *CreateNSWMul(Value *LHS, Value *RHS, const Twine &Name = "") { +    if (Constant *LC = dyn_cast<Constant>(LHS)) +      if (Constant *RC = dyn_cast<Constant>(RHS)) +        return Folder.CreateNSWMul(LC, RC); +    return Insert(BinaryOperator::CreateNSWMul(LHS, RHS), Name); +  }    Value *CreateFMul(Value *LHS, Value *RHS, const Twine &Name = "") {      if (Constant *LC = dyn_cast<Constant>(LHS))        if (Constant *RC = dyn_cast<Constant>(RHS)) diff --git a/llvm/include/llvm/Support/NoFolder.h b/llvm/include/llvm/Support/NoFolder.h index f6f4c5b3c85..78a9035b6c1 100644 --- a/llvm/include/llvm/Support/NoFolder.h +++ b/llvm/include/llvm/Support/NoFolder.h @@ -60,6 +60,9 @@ public:    Value *CreateMul(Constant *LHS, Constant *RHS) const {      return BinaryOperator::CreateMul(LHS, RHS);    } +  Value *CreateNSWMul(Constant *LHS, Constant *RHS) const { +    return BinaryOperator::CreateNSWMul(LHS, RHS); +  }    Value *CreateFMul(Constant *LHS, Constant *RHS) const {      return BinaryOperator::CreateFMul(LHS, RHS);    } diff --git a/llvm/include/llvm/Support/TargetFolder.h b/llvm/include/llvm/Support/TargetFolder.h index 9aa762570e8..59dd29be7a8 100644 --- a/llvm/include/llvm/Support/TargetFolder.h +++ b/llvm/include/llvm/Support/TargetFolder.h @@ -67,6 +67,9 @@ public:    Constant *CreateMul(Constant *LHS, Constant *RHS) const {      return Fold(ConstantExpr::getMul(LHS, RHS));    } +  Constant *CreateNSWMul(Constant *LHS, Constant *RHS) const { +    return Fold(ConstantExpr::getNSWMul(LHS, RHS)); +  }    Constant *CreateFMul(Constant *LHS, Constant *RHS) const {      return Fold(ConstantExpr::getFMul(LHS, RHS));    } diff --git a/llvm/lib/VMCore/Constants.cpp b/llvm/lib/VMCore/Constants.cpp index 2507402f899..34fc9a8ea4f 100644 --- a/llvm/lib/VMCore/Constants.cpp +++ b/llvm/lib/VMCore/Constants.cpp @@ -643,6 +643,11 @@ Constant* ConstantExpr::getNSWSub(Constant* C1, Constant* C2) {                 OverflowingBinaryOperator::NoSignedWrap);  } +Constant* ConstantExpr::getNSWMul(Constant* C1, Constant* C2) { +  return getTy(C1->getType(), Instruction::Mul, C1, C2, +               OverflowingBinaryOperator::NoSignedWrap); +} +  Constant* ConstantExpr::getExactSDiv(Constant* C1, Constant* C2) {    return getTy(C1->getType(), Instruction::SDiv, C1, C2,                 SDivOperator::IsExact); | 

