diff options
Diffstat (limited to 'llvm/lib/Analysis/Loads.cpp')
| -rw-r--r-- | llvm/lib/Analysis/Loads.cpp | 29 | 
1 files changed, 19 insertions, 10 deletions
| diff --git a/llvm/lib/Analysis/Loads.cpp b/llvm/lib/Analysis/Loads.cpp index 7da9bd718a5..31da4e9ec78 100644 --- a/llvm/lib/Analysis/Loads.cpp +++ b/llvm/lib/Analysis/Loads.cpp @@ -125,7 +125,8 @@ bool llvm::isDereferenceableAndAlignedPointer(const Value *V, unsigned Align,                                                Visited);  } -bool llvm::isDereferenceableAndAlignedPointer(const Value *V, unsigned Align, +bool llvm::isDereferenceableAndAlignedPointer(const Value *V, Type *Ty, +                                              unsigned Align,                                                const DataLayout &DL,                                                const Instruction *CtxI,                                                const DominatorTree *DT) { @@ -133,8 +134,6 @@ bool llvm::isDereferenceableAndAlignedPointer(const Value *V, unsigned Align,    // attribute, we know exactly how many bytes are dereferenceable. If we can    // determine the exact offset to the attributed variable, we can use that    // information here. -  Type *VTy = V->getType(); -  Type *Ty = VTy->getPointerElementType();    // Require ABI alignment for loads without alignment specification    if (Align == 0) @@ -145,14 +144,16 @@ bool llvm::isDereferenceableAndAlignedPointer(const Value *V, unsigned Align,    SmallPtrSet<const Value *, 32> Visited;    return ::isDereferenceableAndAlignedPointer( -      V, Align, APInt(DL.getIndexTypeSizeInBits(VTy), DL.getTypeStoreSize(Ty)), DL, -      CtxI, DT, Visited); +      V, Align, +      APInt(DL.getIndexTypeSizeInBits(V->getType()), DL.getTypeStoreSize(Ty)), +      DL, CtxI, DT, Visited);  } -bool llvm::isDereferenceablePointer(const Value *V, const DataLayout &DL, +bool llvm::isDereferenceablePointer(const Value *V, Type *Ty, +                                    const DataLayout &DL,                                      const Instruction *CtxI,                                      const DominatorTree *DT) { -  return isDereferenceableAndAlignedPointer(V, 1, DL, CtxI, DT); +  return isDereferenceableAndAlignedPointer(V, Ty, 1, DL, CtxI, DT);  }  /// Test if A and B will obviously have the same value. @@ -197,7 +198,7 @@ static bool AreEquivalentAddressValues(const Value *A, const Value *B) {  ///  /// This uses the pointee type to determine how many bytes need to be safe to  /// load from the pointer. -bool llvm::isSafeToLoadUnconditionally(Value *V, unsigned Align, +bool llvm::isSafeToLoadUnconditionally(Value *V, unsigned Align, APInt &Size,                                         const DataLayout &DL,                                         Instruction *ScanFrom,                                         const DominatorTree *DT) { @@ -208,7 +209,7 @@ bool llvm::isSafeToLoadUnconditionally(Value *V, unsigned Align,    // If DT is not specified we can't make context-sensitive query    const Instruction* CtxI = DT ? ScanFrom : nullptr; -  if (isDereferenceableAndAlignedPointer(V, Align, DL, CtxI, DT)) +  if (isDereferenceableAndAlignedPointer(V, Align, Size, DL, CtxI, DT))      return true;    int64_t ByteOffset = 0; @@ -313,7 +314,15 @@ bool llvm::isSafeToLoadUnconditionally(Value *V, unsigned Align,    return false;  } -/// DefMaxInstsToScan - the default number of maximum instructions +bool llvm::isSafeToLoadUnconditionally(Value *V, Type *Ty, unsigned Align, +                                       const DataLayout &DL, +                                       Instruction *ScanFrom, +                                       const DominatorTree *DT) { +  APInt Size(DL.getIndexTypeSizeInBits(V->getType()), DL.getTypeStoreSize(Ty)); +  return isSafeToLoadUnconditionally(V, Align, Size, DL, ScanFrom, DT); +} + +  /// DefMaxInstsToScan - the default number of maximum instructions  /// to scan in the block, used by FindAvailableLoadedValue().  /// FindAvailableLoadedValue() was introduced in r60148, to improve jump  /// threading in part by eliminating partially redundant loads. | 

