temporarily revert Devang's most recent patch, which caused a large

compile-time regression in LLC.

llvm-svn: 34385
This commit is contained in:
Chris Lattner 2007-02-17 23:14:24 +00:00
parent 3390126870
commit dee1492159
2 changed files with 4 additions and 21 deletions

View File

@ -120,10 +120,6 @@ public:
/// Collect passes whose last user is P
void collectLastUses(std::vector<Pass *> &LastUses, Pass *P);
// Walk LastUser map and create inverted map. This should be done
// after all passes are added and before running first pass.
void collectInvertedLU();
/// Find the pass that implements Analysis AID. Search immutable
/// passes and all pass managers. If desired pass is not found
/// then return NULL.
@ -175,7 +171,6 @@ private:
// Map to keep track of last user of the analysis pass.
// LastUser->second is the last user of Lastuser->first.
std::map<Pass *, Pass *> LastUser;
std::map<Pass *, std::vector <Pass *> > InvertedLU;
/// Immutable passes are managed by top level manager.
std::vector<ImmutablePass *> ImmutablePasses;

View File

@ -362,19 +362,13 @@ void PMTopLevelManager::setLastUser(std::vector<Pass *> &AnalysisPasses,
}
}
// Walk LastUser map and create inverted map. This should be done
// after all passes are added and before running first pass.
void PMTopLevelManager::collectInvertedLU() {
for (std::map<Pass *, Pass *>::iterator LUI = LastUser.begin(),
LUE = LastUser.end(); LUI != LUE; ++LUI)
InvertedLU[LUI->second].push_back(LUI->first);
}
/// Collect passes whose last user is P
void PMTopLevelManager::collectLastUses(std::vector<Pass *> &LastUses,
Pass *P) {
std::vector<Pass *>&LU = InvertedLU[P];
LastUses.insert(LastUses.end(), LU.begin(), LU.end());
for (std::map<Pass *, Pass *>::iterator LUI = LastUser.begin(),
LUE = LastUser.end(); LUI != LUE; ++LUI)
if (LUI->second == P)
LastUses.push_back(LUI->first);
}
/// Schedule pass P for execution. Make sure that passes required by
@ -944,9 +938,6 @@ bool FunctionPassManagerImpl::run(Function &F) {
dumpArguments();
dumpPasses();
// Collect inverted map of LastUsers. This improves speed of
// collectLastUses().
TPM->collectInvertedLU();
initializeAllAnalysisInfo();
for (unsigned Index = 0; Index < getNumContainedManagers(); ++Index) {
FPPassManager *FP = getContainedManager(Index);
@ -1095,9 +1086,6 @@ bool PassManagerImpl::run(Module &M) {
dumpArguments();
dumpPasses();
// Collect inverted map of LastUsers. This improves speed of
// collectLastUses().
TPM->collectInvertedLU();
initializeAllAnalysisInfo();
for (unsigned Index = 0; Index < getNumContainedManagers(); ++Index) {
MPPassManager *MP = getContainedManager(Index);