[PATCH] Add optimization remarks to the loop unroller and vectorizer.
Diego Novillo
dnovillo at google.com
Tue Apr 22 13:31:20 PDT 2014
Thanks, Nadav. Something like this?
On Tue, Apr 22, 2014 at 4:30 PM, Diego Novillo <dnovillo at google.com> wrote:
> - Add vectorization and interleave factor reporting.
>
> CHANGES SINCE LAST UPDATE
> http://reviews.llvm.org/D3456?vs=8738&id=8740
>
> BRANCH
> add-optimization-remarks
>
> http://reviews.llvm.org/D3456
>
> Files:
> include/llvm/Analysis/LoopInfo.h
> lib/Transforms/Utils/LoopUnroll.cpp
> lib/Transforms/Vectorize/LoopVectorize.cpp
>
> Index: include/llvm/Analysis/LoopInfo.h
> ===================================================================
> --- include/llvm/Analysis/LoopInfo.h
> +++ include/llvm/Analysis/LoopInfo.h
> @@ -453,6 +453,31 @@
>
> void dump() const;
>
> + /// \brief Return the debug location of the start of this loop.
> + /// This looks for the first instruction with a known debug location
> + /// by looking at the preheader and header blocks. If it cannot
> + /// find an instruction with location information, it returns an
> + /// unknown location.
> + DebugLoc getStartLoc() const {
> + DebugLoc StartLoc;
> + BasicBlock *HeadBB;
> +
> + // Try the pre-header first.
> + if ((HeadBB = getLoopPreheader()) != nullptr) {
> + StartLoc = HeadBB->getFirstNonPHIOrDbgOrLifetime()->getDebugLoc();
> + if (!StartLoc.isUnknown())
> + return StartLoc;
> + }
> +
> + // If we have no pre-header or there are no instructions with debug
> + // info in it, try the header.
> + HeadBB = getHeader();
> + if (HeadBB)
> + StartLoc = HeadBB->getFirstNonPHIOrDbgOrLifetime()->getDebugLoc();
> +
> + return StartLoc;
> + }
> +
> private:
> friend class LoopInfoBase<BasicBlock, Loop>;
> explicit Loop(BasicBlock *BB) : LoopBase<BasicBlock, Loop>(BB) {}
> Index: lib/Transforms/Utils/LoopUnroll.cpp
> ===================================================================
> --- lib/Transforms/Utils/LoopUnroll.cpp
> +++ lib/Transforms/Utils/LoopUnroll.cpp
> @@ -24,6 +24,7 @@
> #include "llvm/Analysis/ScalarEvolution.h"
> #include "llvm/IR/BasicBlock.h"
> #include "llvm/IR/Dominators.h"
> +#include "llvm/IR/LLVMContext.h"
> #include "llvm/Support/Debug.h"
> #include "llvm/Support/raw_ostream.h"
> #include "llvm/Transforms/Utils/BasicBlockUtils.h"
> @@ -228,20 +229,33 @@
> (unsigned)GreatestCommonDivisor64(Count, TripMultiple);
> }
>
> + // Report the unrolling decision.
> + DebugLoc LoopLoc = L->getStartLoc();
> + Function *F = Header->getParent();
> + LLVMContext &Ctx = F->getContext();
> +
> if (CompletelyUnroll) {
> DEBUG(dbgs() << "COMPLETELY UNROLLING loop %" << Header->getName()
> << " with trip count " << TripCount << "!\n");
> + Ctx.emitOptimizationRemark(DEBUG_TYPE, *F, LoopLoc,
> + Twine("completely unrolled loop ") +
> + Twine(TripCount) + " times");
> } else {
> DEBUG(dbgs() << "UNROLLING loop %" << Header->getName()
> << " by " << Count);
> + Twine DiagMsg("unrolled loop " + Twine(Count) + " times ");
> if (TripMultiple == 0 || BreakoutTrip != TripMultiple) {
> DEBUG(dbgs() << " with a breakout at trip " << BreakoutTrip);
> + DiagMsg.concat(" with a breakout at trip " + Twine(BreakoutTrip));
> } else if (TripMultiple != 1) {
> DEBUG(dbgs() << " with " << TripMultiple << " trips per branch");
> + DiagMsg.concat(" with " + Twine(TripMultiple) + " trips per
> branch");
> } else if (RuntimeTripCount) {
> DEBUG(dbgs() << " with run-time trip count");
> + DiagMsg.concat(" with run-time trip count");
> }
> DEBUG(dbgs() << "!\n");
> + Ctx.emitOptimizationRemark(DEBUG_TYPE, *F, LoopLoc, DiagMsg);
> }
>
> bool ContinueOnTrue = L->contains(BI->getSuccessor(0));
> Index: lib/Transforms/Vectorize/LoopVectorize.cpp
> ===================================================================
> --- lib/Transforms/Vectorize/LoopVectorize.cpp
> +++ lib/Transforms/Vectorize/LoopVectorize.cpp
> @@ -1187,6 +1187,12 @@
> // Mark the loop as already vectorized to avoid vectorizing again.
> Hints.setAlreadyVectorized(L);
>
> + // Report the vectorization decision.
> + F->getContext().emitOptimizationRemark(
> + DEBUG_TYPE, *F, L->getStartLoc(),
> + Twine("vectorized loop. Vectorization factor: ") +
> Twine(VF.Width) +
> + ". Unroll factor: " + Twine(UF));
> +
> DEBUG(verifyFunction(*L->getHeader()->getParent()));
> return true;
> }
>
> REPLY HANDLER ACTIONS
> Reply to comment, or !reject, !abandon, !reclaim, !resign, !rethink,
> !unsubscribe.
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20140422/f4755e98/attachment.html>
More information about the llvm-commits
mailing list