From eadcdc564daff05889a0ab21c7b80b2c49ae0567 Mon Sep 17 00:00:00 2001 From: Andreas Neustifter Date: Wed, 9 Sep 2009 18:19:35 +0000 Subject: [PATCH] Reverted r81358. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81364 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Analysis/ProfileInfoLoaderPass.cpp | 49 ++++++++++++++------------ 1 file changed, 27 insertions(+), 22 deletions(-) diff --git a/lib/Analysis/ProfileInfoLoaderPass.cpp b/lib/Analysis/ProfileInfoLoaderPass.cpp index 6b33ef8f32c..e79dd8c0c22 100644 --- a/lib/Analysis/ProfileInfoLoaderPass.cpp +++ b/lib/Analysis/ProfileInfoLoaderPass.cpp @@ -61,8 +61,8 @@ namespace { // blocks as possbile. virtual void recurseBasicBlock(const BasicBlock *BB); virtual void readEdgeOrRemember(Edge, Edge&, unsigned &, unsigned &); - virtual unsigned readEdge(ProfileInfo::Edge, std::vector, - unsigned, Function*); + virtual void readOrRememberEdge(ProfileInfo::Edge, unsigned, + unsigned, Function*); /// run - Load the profile information from the specified file. virtual bool runOnModule(Module &M); @@ -156,21 +156,15 @@ void LoaderPass::recurseBasicBlock(const BasicBlock *BB) { } } -unsigned LoaderPass::readEdge(ProfileInfo::Edge e, std::vector ECs, - unsigned ei, Function *F) { - if (ei < ECs.size()) { - double weight = ECs[ei]; - if (weight != ~0U) { - EdgeInformation[F][e] += weight; - DEBUG(errs()<<"--Read Edge Counter for " << e - <<" (# "<isDeclaration()) continue; - DEBUG(errs()<<"Working on "<getNameStr()<<"\n"); - ei = readEdge(getEdge(0,&F->getEntryBlock()), ECs, ei, F); + if (ei < ECs.size()) + EdgeInformation[F][ProfileInfo::getEdge(0, &F->getEntryBlock())] += + ECs[ei++]; for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) { // Okay, we have to add a counter of each outgoing edge. If the // outgoing edge is not critical don't split it, just insert the counter // in the source or destination of the edge. TerminatorInst *TI = BB->getTerminator(); for (unsigned s = 0, e = TI->getNumSuccessors(); s != e; ++s) { - ei = readEdge(getEdge(BB,TI->getSuccessor(s)), ECs, ei, F); + if (ei < ECs.size()) + EdgeInformation[F][ProfileInfo::getEdge(BB, TI->getSuccessor(s))] += + ECs[ei++]; } } } @@ -208,14 +205,22 @@ bool LoaderPass::runOnModule(Module &M) { for (Module::iterator F = M.begin(), E = M.end(); F != E; ++F) { if (F->isDeclaration()) continue; DEBUG(errs()<<"Working on "<getNameStr()<<"\n"); - ei = readEdge(getEdge(0,&F->getEntryBlock()), ECs, ei, F); + if (ei < ECs.size()) { + readOrRememberEdge(getEdge(0,&F->getEntryBlock()), ECs[ei], ei, F); + ei++; + } for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) { TerminatorInst *TI = BB->getTerminator(); if (TI->getNumSuccessors() == 0) { - ei = readEdge(getEdge(BB,0), ECs, ei, F); + if (ei < ECs.size()) { + readOrRememberEdge(getEdge(BB,0), ECs[ei], ei, F); ei++; + } } for (unsigned s = 0, e = TI->getNumSuccessors(); s != e; ++s) { - ei = readEdge(getEdge(BB,TI->getSuccessor(s)), ECs, ei, F); + if (ei < ECs.size()) { + readOrRememberEdge(getEdge(BB,TI->getSuccessor(s)), ECs[ei], ei, F); + ei++; + } } } while (SpanningTree.size() > 0) {