mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-26 07:34:06 +00:00
Extend the StartPassTimer and StopPassTimer functions so that the
code that stops the timer doesn't have to search to find the timer object before it stops the timer. This avoids a lock acquisition and a few other things done with the timer running. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@82949 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6a2fa325c1
commit
5c12adaa8b
@ -95,6 +95,7 @@ namespace llvm {
|
|||||||
class Pass;
|
class Pass;
|
||||||
class StringRef;
|
class StringRef;
|
||||||
class Value;
|
class Value;
|
||||||
|
class Timer;
|
||||||
|
|
||||||
/// FunctionPassManager and PassManager, two top level managers, serve
|
/// FunctionPassManager and PassManager, two top level managers, serve
|
||||||
/// as the public interface of pass manager infrastructure.
|
/// as the public interface of pass manager infrastructure.
|
||||||
@ -460,8 +461,8 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
extern void StartPassTimer(llvm::Pass *);
|
extern Timer *StartPassTimer(Pass *);
|
||||||
extern void StopPassTimer(llvm::Pass *);
|
extern void StopPassTimer(Pass *, Timer *);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,9 +96,9 @@ bool CGPassManager::RunPassOnSCC(Pass *P, std::vector<CallGraphNode*> &CurSCC,
|
|||||||
CallGraphUpToDate = true;
|
CallGraphUpToDate = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
StartPassTimer(CGSP);
|
Timer *T = StartPassTimer(CGSP);
|
||||||
Changed = CGSP->runOnSCC(CurSCC);
|
Changed = CGSP->runOnSCC(CurSCC);
|
||||||
StopPassTimer(CGSP);
|
StopPassTimer(CGSP, T);
|
||||||
|
|
||||||
// After the CGSCCPass is done, when assertions are enabled, use
|
// After the CGSCCPass is done, when assertions are enabled, use
|
||||||
// RefreshCallGraph to verify that the callgraph was correctly updated.
|
// RefreshCallGraph to verify that the callgraph was correctly updated.
|
||||||
@ -110,7 +110,6 @@ bool CGPassManager::RunPassOnSCC(Pass *P, std::vector<CallGraphNode*> &CurSCC,
|
|||||||
return Changed;
|
return Changed;
|
||||||
}
|
}
|
||||||
|
|
||||||
StartPassTimer(P);
|
|
||||||
FPPassManager *FPP = dynamic_cast<FPPassManager *>(P);
|
FPPassManager *FPP = dynamic_cast<FPPassManager *>(P);
|
||||||
assert(FPP && "Invalid CGPassManager member");
|
assert(FPP && "Invalid CGPassManager member");
|
||||||
|
|
||||||
@ -118,10 +117,11 @@ bool CGPassManager::RunPassOnSCC(Pass *P, std::vector<CallGraphNode*> &CurSCC,
|
|||||||
for (unsigned i = 0, e = CurSCC.size(); i != e; ++i) {
|
for (unsigned i = 0, e = CurSCC.size(); i != e; ++i) {
|
||||||
if (Function *F = CurSCC[i]->getFunction()) {
|
if (Function *F = CurSCC[i]->getFunction()) {
|
||||||
dumpPassInfo(P, EXECUTION_MSG, ON_FUNCTION_MSG, F->getName());
|
dumpPassInfo(P, EXECUTION_MSG, ON_FUNCTION_MSG, F->getName());
|
||||||
|
Timer *T = StartPassTimer(FPP);
|
||||||
Changed |= FPP->runOnFunction(*F);
|
Changed |= FPP->runOnFunction(*F);
|
||||||
|
StopPassTimer(FPP, T);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
StopPassTimer(P);
|
|
||||||
|
|
||||||
// The function pass(es) modified the IR, they may have clobbered the
|
// The function pass(es) modified the IR, they may have clobbered the
|
||||||
// callgraph.
|
// callgraph.
|
||||||
|
@ -232,10 +232,10 @@ bool LPPassManager::runOnFunction(Function &F) {
|
|||||||
LoopPass *LP = dynamic_cast<LoopPass *>(P);
|
LoopPass *LP = dynamic_cast<LoopPass *>(P);
|
||||||
{
|
{
|
||||||
PassManagerPrettyStackEntry X(LP, *CurrentLoop->getHeader());
|
PassManagerPrettyStackEntry X(LP, *CurrentLoop->getHeader());
|
||||||
StartPassTimer(P);
|
|
||||||
assert(LP && "Invalid LPPassManager member");
|
assert(LP && "Invalid LPPassManager member");
|
||||||
|
Timer *T = StartPassTimer(P);
|
||||||
Changed |= LP->runOnLoop(CurrentLoop, *this);
|
Changed |= LP->runOnLoop(CurrentLoop, *this);
|
||||||
StopPassTimer(P);
|
StopPassTimer(P, T);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Changed)
|
if (Changed)
|
||||||
|
@ -397,25 +397,19 @@ public:
|
|||||||
// null. It may be called multiple times.
|
// null. It may be called multiple times.
|
||||||
static void createTheTimeInfo();
|
static void createTheTimeInfo();
|
||||||
|
|
||||||
void passStarted(Pass *P) {
|
/// passStarted - This method creates a timer for the given pass if it doesn't
|
||||||
|
/// already have one, and starts the timer.
|
||||||
|
Timer *passStarted(Pass *P) {
|
||||||
if (dynamic_cast<PMDataManager *>(P))
|
if (dynamic_cast<PMDataManager *>(P))
|
||||||
return;
|
return 0;
|
||||||
|
|
||||||
sys::SmartScopedLock<true> Lock(*TimingInfoMutex);
|
sys::SmartScopedLock<true> Lock(*TimingInfoMutex);
|
||||||
std::map<Pass*, Timer>::iterator I = TimingData.find(P);
|
std::map<Pass*, Timer>::iterator I = TimingData.find(P);
|
||||||
if (I == TimingData.end())
|
if (I == TimingData.end())
|
||||||
I=TimingData.insert(std::make_pair(P, Timer(P->getPassName(), TG))).first;
|
I=TimingData.insert(std::make_pair(P, Timer(P->getPassName(), TG))).first;
|
||||||
I->second.startTimer();
|
Timer *T = &I->second;
|
||||||
}
|
T->startTimer();
|
||||||
|
return T;
|
||||||
void passEnded(Pass *P) {
|
|
||||||
if (dynamic_cast<PMDataManager *>(P))
|
|
||||||
return;
|
|
||||||
|
|
||||||
sys::SmartScopedLock<true> Lock(*TimingInfoMutex);
|
|
||||||
std::map<Pass*, Timer>::iterator I = TimingData.find(P);
|
|
||||||
assert(I != TimingData.end() && "passStarted/passEnded not nested right!");
|
|
||||||
I->second.stopTimer();
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -827,9 +821,9 @@ void PMDataManager::freePass(Pass *P, const StringRef &Msg,
|
|||||||
// If the pass crashes releasing memory, remember this.
|
// If the pass crashes releasing memory, remember this.
|
||||||
PassManagerPrettyStackEntry X(P);
|
PassManagerPrettyStackEntry X(P);
|
||||||
|
|
||||||
if (TheTimeInfo) TheTimeInfo->passStarted(P);
|
Timer *T = StartPassTimer(P);
|
||||||
P->releaseMemory();
|
P->releaseMemory();
|
||||||
if (TheTimeInfo) TheTimeInfo->passEnded(P);
|
StopPassTimer(P, T);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (const PassInfo *PI = P->getPassInfo()) {
|
if (const PassInfo *PI = P->getPassInfo()) {
|
||||||
@ -1162,9 +1156,9 @@ bool BBPassManager::runOnFunction(Function &F) {
|
|||||||
// If the pass crashes, remember this.
|
// If the pass crashes, remember this.
|
||||||
PassManagerPrettyStackEntry X(BP, *I);
|
PassManagerPrettyStackEntry X(BP, *I);
|
||||||
|
|
||||||
if (TheTimeInfo) TheTimeInfo->passStarted(BP);
|
Timer *T = StartPassTimer(BP);
|
||||||
Changed |= BP->runOnBasicBlock(*I);
|
Changed |= BP->runOnBasicBlock(*I);
|
||||||
if (TheTimeInfo) TheTimeInfo->passEnded(BP);
|
StopPassTimer(BP, T);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Changed)
|
if (Changed)
|
||||||
@ -1377,9 +1371,9 @@ bool FPPassManager::runOnFunction(Function &F) {
|
|||||||
{
|
{
|
||||||
PassManagerPrettyStackEntry X(FP, F);
|
PassManagerPrettyStackEntry X(FP, F);
|
||||||
|
|
||||||
if (TheTimeInfo) TheTimeInfo->passStarted(FP);
|
Timer *T = StartPassTimer(FP);
|
||||||
Changed |= FP->runOnFunction(F);
|
Changed |= FP->runOnFunction(F);
|
||||||
if (TheTimeInfo) TheTimeInfo->passEnded(FP);
|
StopPassTimer(FP, T);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Changed)
|
if (Changed)
|
||||||
@ -1453,9 +1447,9 @@ MPPassManager::runOnModule(Module &M) {
|
|||||||
|
|
||||||
{
|
{
|
||||||
PassManagerPrettyStackEntry X(MP, M);
|
PassManagerPrettyStackEntry X(MP, M);
|
||||||
if (TheTimeInfo) TheTimeInfo->passStarted(MP);
|
Timer *T = StartPassTimer(MP);
|
||||||
Changed |= MP->runOnModule(M);
|
Changed |= MP->runOnModule(M);
|
||||||
if (TheTimeInfo) TheTimeInfo->passEnded(MP);
|
StopPassTimer(MP, T);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Changed)
|
if (Changed)
|
||||||
@ -1591,15 +1585,15 @@ void TimingInfo::createTheTimeInfo() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// If TimingInfo is enabled then start pass timer.
|
/// If TimingInfo is enabled then start pass timer.
|
||||||
void llvm::StartPassTimer(Pass *P) {
|
Timer *llvm::StartPassTimer(Pass *P) {
|
||||||
if (TheTimeInfo)
|
if (TheTimeInfo)
|
||||||
TheTimeInfo->passStarted(P);
|
return TheTimeInfo->passStarted(P);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// If TimingInfo is enabled then stop pass timer.
|
/// If TimingInfo is enabled then stop pass timer.
|
||||||
void llvm::StopPassTimer(Pass *P) {
|
void llvm::StopPassTimer(Pass *P, Timer *T) {
|
||||||
if (TheTimeInfo)
|
if (T) T->stopTimer();
|
||||||
TheTimeInfo->passEnded(P);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
Loading…
x
Reference in New Issue
Block a user