diff options
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/IPO/ArgumentPromotion.cpp | 14 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LICM.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/SROA.cpp | 6 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp | 6 | 
4 files changed, 17 insertions, 11 deletions
| diff --git a/llvm/lib/Transforms/IPO/ArgumentPromotion.cpp b/llvm/lib/Transforms/IPO/ArgumentPromotion.cpp index 97a119b01bc..f9de54a173d 100644 --- a/llvm/lib/Transforms/IPO/ArgumentPromotion.cpp +++ b/llvm/lib/Transforms/IPO/ArgumentPromotion.cpp @@ -39,6 +39,7 @@  #include "llvm/IR/CFG.h"  #include "llvm/IR/CallSite.h"  #include "llvm/IR/Constants.h" +#include "llvm/IR/DataLayout.h"  #include "llvm/IR/DebugInfo.h"  #include "llvm/IR/DerivedTypes.h"  #include "llvm/IR/Instructions.h" @@ -68,13 +69,14 @@ namespace {      bool runOnSCC(CallGraphSCC &SCC) override;      static char ID; // Pass identification, replacement for typeid      explicit ArgPromotion(unsigned maxElements = 3) -        : CallGraphSCCPass(ID), maxElements(maxElements) { +        : CallGraphSCCPass(ID), DL(nullptr), maxElements(maxElements) {        initializeArgPromotionPass(*PassRegistry::getPassRegistry());      }      /// A vector used to hold the indices of a single GEP instruction      typedef std::vector<uint64_t> IndicesVector; +    const DataLayout *DL;    private:      CallGraphNode *PromoteArguments(CallGraphNode *CGN);      bool isSafeToPromoteArgument(Argument *Arg, bool isByVal) const; @@ -103,6 +105,9 @@ Pass *llvm::createArgumentPromotionPass(unsigned maxElements) {  bool ArgPromotion::runOnSCC(CallGraphSCC &SCC) {    bool Changed = false, LocalChange; +  DataLayoutPass *DLP = getAnalysisIfAvailable<DataLayoutPass>(); +  DL = DLP ? &DLP->getDataLayout() : nullptr; +    do {  // Iterate until we stop promoting from this SCC.      LocalChange = false;      // Attempt to promote arguments from all functions in this SCC. @@ -218,7 +223,8 @@ CallGraphNode *ArgPromotion::PromoteArguments(CallGraphNode *CGN) {  /// AllCallersPassInValidPointerForArgument - Return true if we can prove that  /// all callees pass in a valid pointer for the specified function argument. -static bool AllCallersPassInValidPointerForArgument(Argument *Arg) { +static bool AllCallersPassInValidPointerForArgument(Argument *Arg, +                                                    const DataLayout *DL) {    Function *Callee = Arg->getParent();    unsigned ArgNo = Arg->getArgNo(); @@ -229,7 +235,7 @@ static bool AllCallersPassInValidPointerForArgument(Argument *Arg) {      CallSite CS(U);      assert(CS && "Should only have direct calls!"); -    if (!CS.getArgument(ArgNo)->isDereferenceablePointer()) +    if (!CS.getArgument(ArgNo)->isDereferenceablePointer(DL))        return false;    }    return true; @@ -337,7 +343,7 @@ bool ArgPromotion::isSafeToPromoteArgument(Argument *Arg,    GEPIndicesSet ToPromote;    // If the pointer is always valid, any load with first index 0 is valid. -  if (isByValOrInAlloca || AllCallersPassInValidPointerForArgument(Arg)) +  if (isByValOrInAlloca || AllCallersPassInValidPointerForArgument(Arg, DL))      SafeToUnconditionallyLoad.insert(IndicesVector(1, 0));    // First, iterate the entry block and mark loads of (geps of) arguments as diff --git a/llvm/lib/Transforms/Scalar/LICM.cpp b/llvm/lib/Transforms/Scalar/LICM.cpp index bc1db373313..abcceb20050 100644 --- a/llvm/lib/Transforms/Scalar/LICM.cpp +++ b/llvm/lib/Transforms/Scalar/LICM.cpp @@ -639,7 +639,7 @@ void LICM::hoist(Instruction &I) {  ///  bool LICM::isSafeToExecuteUnconditionally(Instruction &Inst) {    // If it is not a trapping instruction, it is always safe to hoist. -  if (isSafeToSpeculativelyExecute(&Inst)) +  if (isSafeToSpeculativelyExecute(&Inst, DL))      return true;    return isGuaranteedToExecute(Inst); diff --git a/llvm/lib/Transforms/Scalar/SROA.cpp b/llvm/lib/Transforms/Scalar/SROA.cpp index 6532b7a09b9..8c7f253290b 100644 --- a/llvm/lib/Transforms/Scalar/SROA.cpp +++ b/llvm/lib/Transforms/Scalar/SROA.cpp @@ -1130,7 +1130,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 (InVal->isDereferenceablePointer() || +    if (InVal->isDereferenceablePointer(DL) ||          isSafeToLoadUnconditionally(InVal, TI, MaxAlign, DL))        continue; @@ -1198,8 +1198,8 @@ static bool isSafeSelectToSpeculate(SelectInst &SI,                                      const DataLayout *DL = nullptr) {    Value *TValue = SI.getTrueValue();    Value *FValue = SI.getFalseValue(); -  bool TDerefable = TValue->isDereferenceablePointer(); -  bool FDerefable = FValue->isDereferenceablePointer(); +  bool TDerefable = TValue->isDereferenceablePointer(DL); +  bool FDerefable = FValue->isDereferenceablePointer(DL);    for (User *U : SI.users()) {      LoadInst *LI = dyn_cast<LoadInst>(U); diff --git a/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp b/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp index 58192fc02be..e2a24a7fd4a 100644 --- a/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp +++ b/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp @@ -1142,8 +1142,8 @@ public:  /// We can do this to a select if its only uses are loads and if the operand to  /// the select can be loaded unconditionally.  static bool isSafeSelectToSpeculate(SelectInst *SI, const DataLayout *DL) { -  bool TDerefable = SI->getTrueValue()->isDereferenceablePointer(); -  bool FDerefable = SI->getFalseValue()->isDereferenceablePointer(); +  bool TDerefable = SI->getTrueValue()->isDereferenceablePointer(DL); +  bool FDerefable = SI->getFalseValue()->isDereferenceablePointer(DL);    for (User *U : SI->users()) {      LoadInst *LI = dyn_cast<LoadInst>(U); @@ -1226,7 +1226,7 @@ static bool isSafePHIToSpeculate(PHINode *PN, const DataLayout *DL) {      // 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 (InVal->isDereferenceablePointer() || +    if (InVal->isDereferenceablePointer(DL) ||          isSafeToLoadUnconditionally(InVal, Pred->getTerminator(), MaxAlign, DL))        continue; | 

