aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp
diff options
context:
space:
mode:
authorAdam Nemet <anemet@apple.com>2016-05-05 00:08:15 +0000
committerAdam Nemet <anemet@apple.com>2016-05-05 00:08:15 +0000
commit3c5eabfcbc62c0cddef3186f63c27d64395c04e0 (patch)
treeb73cb0758b11dfa3a88f97a7c54d0c51a783631e /llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp
parentfdcea9d78a7b17ede42a5f737d4be9153c316269 (diff)
downloadllvm-3c5eabfcbc62c0cddef3186f63c27d64395c04e0.zip
llvm-3c5eabfcbc62c0cddef3186f63c27d64395c04e0.tar.gz
llvm-3c5eabfcbc62c0cddef3186f63c27d64395c04e0.tar.bz2
[LoopDataPrefetch] Add optimization remark
With -Rpass=loop-data-prefetch, show the memory access that got prefetched. llvm-svn: 268578
Diffstat (limited to 'llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp')
-rw-r--r--llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp b/llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp
index b044fe8..6aea79f 100644
--- a/llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp
+++ b/llvm/lib/Transforms/Scalar/LoopDataPrefetch.cpp
@@ -26,6 +26,7 @@
#include "llvm/Analysis/TargetTransformInfo.h"
#include "llvm/Analysis/ValueTracking.h"
#include "llvm/IR/CFG.h"
+#include "llvm/IR/DiagnosticInfo.h"
#include "llvm/IR/Dominators.h"
#include "llvm/IR/Function.h"
#include "llvm/IR/IntrinsicInst.h"
@@ -209,9 +210,10 @@ bool LoopDataPrefetch::runOnLoop(Loop *L) {
if (ItersAhead > getMaxPrefetchIterationsAhead())
return MadeChange;
+ Function *F = L->getHeader()->getParent();
DEBUG(dbgs() << "Prefetching " << ItersAhead
<< " iterations ahead (loop size: " << LoopSize << ") in "
- << L->getHeader()->getParent()->getName() << ": " << *L);
+ << F->getName() << ": " << *L);
SmallVector<std::pair<Instruction *, const SCEVAddRecExpr *>, 16> PrefLoads;
for (Loop::block_iterator I = L->block_begin(), IE = L->block_end();
@@ -291,6 +293,9 @@ bool LoopDataPrefetch::runOnLoop(Loop *L) {
++NumPrefetches;
DEBUG(dbgs() << " Access: " << *PtrValue << ", SCEV: " << *LSCEV
<< "\n");
+ emitOptimizationRemark(F->getContext(), DEBUG_TYPE, *F,
+ MemI->getDebugLoc(), "prefetched memory access");
+
MadeChange = true;
}