diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-12-18 20:10:56 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-12-18 20:10:56 +0000 | 
| commit | 044eb2f6afba375a914ac9d8024f8f5142bb912e (patch) | |
| tree | 1475247dc9f9fe5be155ebd4c9069c75aadf8c20 /lib/Transforms/Scalar/LoopDataPrefetch.cpp | |
| parent | eb70dddbd77e120e5d490bd8fbe7ff3f8fa81c6b (diff) | |
Notes
Diffstat (limited to 'lib/Transforms/Scalar/LoopDataPrefetch.cpp')
| -rw-r--r-- | lib/Transforms/Scalar/LoopDataPrefetch.cpp | 17 | 
1 files changed, 6 insertions, 11 deletions
| diff --git a/lib/Transforms/Scalar/LoopDataPrefetch.cpp b/lib/Transforms/Scalar/LoopDataPrefetch.cpp index d09af32a99fd..7f7c6de76450 100644 --- a/lib/Transforms/Scalar/LoopDataPrefetch.cpp +++ b/lib/Transforms/Scalar/LoopDataPrefetch.cpp @@ -18,25 +18,20 @@  #include "llvm/ADT/Statistic.h"  #include "llvm/Analysis/AssumptionCache.h"  #include "llvm/Analysis/CodeMetrics.h" -#include "llvm/Analysis/InstructionSimplify.h"  #include "llvm/Analysis/LoopInfo.h" -#include "llvm/Analysis/OptimizationDiagnosticInfo.h" +#include "llvm/Analysis/OptimizationRemarkEmitter.h"  #include "llvm/Analysis/ScalarEvolution.h" -#include "llvm/Analysis/ScalarEvolutionAliasAnalysis.h"  #include "llvm/Analysis/ScalarEvolutionExpander.h"  #include "llvm/Analysis/ScalarEvolutionExpressions.h"  #include "llvm/Analysis/TargetTransformInfo.h" -#include "llvm/Analysis/ValueTracking.h"  #include "llvm/IR/CFG.h"  #include "llvm/IR/Dominators.h"  #include "llvm/IR/Function.h" -#include "llvm/IR/IntrinsicInst.h"  #include "llvm/IR/Module.h"  #include "llvm/Support/CommandLine.h"  #include "llvm/Support/Debug.h"  #include "llvm/Transforms/Scalar.h"  #include "llvm/Transforms/Utils/BasicBlockUtils.h" -#include "llvm/Transforms/Utils/Local.h"  #include "llvm/Transforms/Utils/ValueMapper.h"  using namespace llvm; @@ -120,9 +115,7 @@ public:      AU.addPreserved<LoopInfoWrapperPass>();      AU.addRequired<OptimizationRemarkEmitterWrapperPass>();      AU.addRequired<ScalarEvolutionWrapperPass>(); -    // FIXME: For some reason, preserving SE here breaks LSR (even if -    // this pass changes nothing). -    // AU.addPreserved<ScalarEvolutionWrapperPass>(); +    AU.addPreserved<ScalarEvolutionWrapperPass>();      AU.addRequired<TargetTransformInfoWrapperPass>();    } @@ -329,8 +322,10 @@ bool LoopDataPrefetch::runOnLoop(Loop *L) {        ++NumPrefetches;        DEBUG(dbgs() << "  Access: " << *PtrValue << ", SCEV: " << *LSCEV                     << "\n"); -      ORE->emit(OptimizationRemark(DEBUG_TYPE, "Prefetched", MemI) -                << "prefetched memory access"); +      ORE->emit([&]() { +        return OptimizationRemark(DEBUG_TYPE, "Prefetched", MemI) +               << "prefetched memory access"; +      });        MadeChange = true;      } | 
