diff options
Diffstat (limited to 'llvm/lib/Transforms/Scalar')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LICM.cpp | 4 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/MergeICmps.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/SROA.cpp | 16 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp | 2 | 
4 files changed, 15 insertions, 9 deletions
| diff --git a/llvm/lib/Transforms/Scalar/LICM.cpp b/llvm/lib/Transforms/Scalar/LICM.cpp index 2d27a660102..3c5e773f793 100644 --- a/llvm/lib/Transforms/Scalar/LICM.cpp +++ b/llvm/lib/Transforms/Scalar/LICM.cpp @@ -2016,8 +2016,8 @@ bool llvm::promoteLoopAccessesToScalars(          // deref info through it.          if (!DereferenceableInPH) {            DereferenceableInPH = isDereferenceableAndAlignedPointer( -              Store->getPointerOperand(), Store->getAlignment(), MDL, -              Preheader->getTerminator(), DT); +              Store->getPointerOperand(), Store->getValueOperand()->getType(), +              Store->getAlignment(), MDL, Preheader->getTerminator(), DT);          }        } else          return false; // Not a load or store. diff --git a/llvm/lib/Transforms/Scalar/MergeICmps.cpp b/llvm/lib/Transforms/Scalar/MergeICmps.cpp index 630f029850c..3d047a19326 100644 --- a/llvm/lib/Transforms/Scalar/MergeICmps.cpp +++ b/llvm/lib/Transforms/Scalar/MergeICmps.cpp @@ -162,7 +162,7 @@ BCEAtom visitICmpLoadOperand(Value *const Val, BaseIdentifier &BaseId) {      return {};    }    const auto &DL = GEP->getModule()->getDataLayout(); -  if (!isDereferenceablePointer(GEP, DL)) { +  if (!isDereferenceablePointer(GEP, LoadI->getType(), DL)) {      LLVM_DEBUG(dbgs() << "not dereferenceable\n");      // We need to make sure that we can do comparison in any order, so we      // require memory to be unconditionnally dereferencable. diff --git a/llvm/lib/Transforms/Scalar/SROA.cpp b/llvm/lib/Transforms/Scalar/SROA.cpp index cc79afdb05a..33f90d0b01e 100644 --- a/llvm/lib/Transforms/Scalar/SROA.cpp +++ b/llvm/lib/Transforms/Scalar/SROA.cpp @@ -1190,12 +1190,16 @@ static Type *findCommonType(AllocaSlices::const_iterator B,  /// FIXME: This should be hoisted into a generic utility, likely in  /// Transforms/Util/Local.h  static bool isSafePHIToSpeculate(PHINode &PN) { +  const DataLayout &DL = PN.getModule()->getDataLayout(); +    // For now, we can only do this promotion if the load is in the same block    // as the PHI, and if there are no stores between the phi and load.    // TODO: Allow recursive phi users.    // TODO: Allow stores.    BasicBlock *BB = PN.getParent();    unsigned MaxAlign = 0; +  uint64_t APWidth = DL.getIndexTypeSizeInBits(PN.getType()); +  APInt MaxSize(APWidth, 0);    bool HaveLoad = false;    for (User *U : PN.users()) {      LoadInst *LI = dyn_cast<LoadInst>(U); @@ -1214,15 +1218,15 @@ static bool isSafePHIToSpeculate(PHINode &PN) {        if (BBI->mayWriteToMemory())          return false; +    uint64_t Size = DL.getTypeStoreSizeInBits(LI->getType());      MaxAlign = std::max(MaxAlign, LI->getAlignment()); +    MaxSize = MaxSize.ult(Size) ? APInt(APWidth, Size) : MaxSize;      HaveLoad = true;    }    if (!HaveLoad)      return false; -  const DataLayout &DL = PN.getModule()->getDataLayout(); -    // We can only transform this if it is safe to push the loads into the    // predecessor blocks. The only thing to watch out for is that we can't put    // a possibly trapping load in the predecessor if it is a critical edge. @@ -1244,7 +1248,7 @@ static bool isSafePHIToSpeculate(PHINode &PN) {      // If this pointer is always safe to load, or if we can prove that there      // is already a load in the block, then we can move the load to the pred      // block. -    if (isSafeToLoadUnconditionally(InVal, MaxAlign, DL, TI)) +    if (isSafeToLoadUnconditionally(InVal, MaxAlign, MaxSize, DL, TI))        continue;      return false; @@ -1334,9 +1338,11 @@ static bool isSafeSelectToSpeculate(SelectInst &SI) {      // Both operands to the select need to be dereferenceable, either      // absolutely (e.g. allocas) or at this point because we can see other      // accesses to it. -    if (!isSafeToLoadUnconditionally(TValue, LI->getAlignment(), DL, LI)) +    if (!isSafeToLoadUnconditionally(TValue, LI->getType(), LI->getAlignment(), +                                     DL, LI))        return false; -    if (!isSafeToLoadUnconditionally(FValue, LI->getAlignment(), DL, LI)) +    if (!isSafeToLoadUnconditionally(FValue, LI->getType(), LI->getAlignment(), +                                     DL, LI))        return false;    } diff --git a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp index c3ccfde8acc..f0b79079d81 100644 --- a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp +++ b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp @@ -340,7 +340,7 @@ static bool canMoveAboveCall(Instruction *I, CallInst *CI, AliasAnalysis *AA) {        // being loaded from.        const DataLayout &DL = L->getModule()->getDataLayout();        if (isModSet(AA->getModRefInfo(CI, MemoryLocation::get(L))) || -          !isSafeToLoadUnconditionally(L->getPointerOperand(), +          !isSafeToLoadUnconditionally(L->getPointerOperand(), L->getType(),                                         L->getAlignment(), DL, L))          return false;      } | 

