mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Setup pass manager before scheduling required analysis.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33262 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4af33c2605
commit
531f01f878
@ -108,6 +108,8 @@ public:
|
|||||||
void dump() const; // dump - call print(std::cerr, 0);
|
void dump() const; // dump - call print(std::cerr, 0);
|
||||||
|
|
||||||
virtual void assignPassManager(PMStack &PMS) {}
|
virtual void assignPassManager(PMStack &PMS) {}
|
||||||
|
virtual void setupPassManager(PMStack &PMS) {}
|
||||||
|
|
||||||
// Access AnalysisResolver
|
// Access AnalysisResolver
|
||||||
inline void setResolver(AnalysisResolver *AR) { Resolver = AR; }
|
inline void setResolver(AnalysisResolver *AR) { Resolver = AR; }
|
||||||
inline AnalysisResolver *getResolver() { return Resolver; }
|
inline AnalysisResolver *getResolver() { return Resolver; }
|
||||||
@ -201,6 +203,7 @@ public:
|
|||||||
virtual bool runPass(BasicBlock&) { return false; }
|
virtual bool runPass(BasicBlock&) { return false; }
|
||||||
|
|
||||||
virtual void assignPassManager(PMStack &PMS);
|
virtual void assignPassManager(PMStack &PMS);
|
||||||
|
|
||||||
// Force out-of-line virtual method.
|
// Force out-of-line virtual method.
|
||||||
virtual ~ModulePass();
|
virtual ~ModulePass();
|
||||||
};
|
};
|
||||||
@ -267,6 +270,7 @@ public:
|
|||||||
bool run(Function &F);
|
bool run(Function &F);
|
||||||
|
|
||||||
virtual void assignPassManager(PMStack &PMS);
|
virtual void assignPassManager(PMStack &PMS);
|
||||||
|
virtual void setupPassManager(PMStack &PMS);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -321,6 +325,7 @@ public:
|
|||||||
virtual bool runPass(BasicBlock &BB);
|
virtual bool runPass(BasicBlock &BB);
|
||||||
|
|
||||||
virtual void assignPassManager(PMStack &PMS);
|
virtual void assignPassManager(PMStack &PMS);
|
||||||
|
virtual void setupPassManager(PMStack &PMS);
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Different types of internal pass managers. External pass managers
|
/// Different types of internal pass managers. External pass managers
|
||||||
@ -337,8 +342,10 @@ enum PassManagerType {
|
|||||||
|
|
||||||
/// PMStack
|
/// PMStack
|
||||||
/// Top level pass manager (see PasManager.cpp) maintains active Pass Managers
|
/// Top level pass manager (see PasManager.cpp) maintains active Pass Managers
|
||||||
/// using PMStack. Each Pass implements assignPassManager() to connect itself
|
/// using PMStack. Each Pass implements setupPassManager() and
|
||||||
/// with appropriate manager. assignPassManager() walks PMStack to find
|
/// assignPassManager() to connect itself with appropriate manager.
|
||||||
|
/// setupPassManager() creates new pass manager if required before adding
|
||||||
|
/// required analysis passes. assignPassManager() walks PMStack to find
|
||||||
/// suitable manager.
|
/// suitable manager.
|
||||||
///
|
///
|
||||||
/// PMStack is just a wrapper around standard deque that overrides pop() and
|
/// PMStack is just a wrapper around standard deque that overrides pop() and
|
||||||
|
@ -366,8 +366,7 @@ void PMTopLevelManager::collectLastUses(std::vector<Pass *> &LastUses,
|
|||||||
/// the manager. Remove dead passes. This is a recursive function.
|
/// the manager. Remove dead passes. This is a recursive function.
|
||||||
void PMTopLevelManager::schedulePass(Pass *P) {
|
void PMTopLevelManager::schedulePass(Pass *P) {
|
||||||
|
|
||||||
// TODO : Allocate function manager for this pass, other wise required set
|
P->setupPassManager(activeStack);
|
||||||
// may be inserted into previous function manager
|
|
||||||
|
|
||||||
AnalysisUsage AnUsage;
|
AnalysisUsage AnUsage;
|
||||||
P->getAnalysisUsage(AnUsage);
|
P->getAnalysisUsage(AnUsage);
|
||||||
@ -1218,47 +1217,55 @@ void ModulePass::assignPassManager(PMStack &PMS) {
|
|||||||
MPP->add(this);
|
MPP->add(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Find appropriate Function Pass Manager or Call Graph Pass Manager
|
/// Setup Pass Manager in advance before checking availability of
|
||||||
/// in the PM Stack and add self into that manager.
|
/// required analysis passes.
|
||||||
void FunctionPass::assignPassManager(PMStack &PMS) {
|
void FunctionPass::setupPassManager(PMStack &PMS) {
|
||||||
|
|
||||||
// Find Module Pass Manager (TODO : Or Call Graph Pass Manager)
|
// Find Module Pass Manager (TODO : Or Call Graph Pass Manager)
|
||||||
while(!PMS.empty()) {
|
while(!PMS.empty()) {
|
||||||
if (PMS.top()->getPassManagerType() > PMT_FunctionPassManager)
|
if (PMS.top()->getPassManagerType() > PMT_FunctionPassManager)
|
||||||
PMS.pop();
|
PMS.pop();
|
||||||
else
|
else
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
FPPassManager *FPP = dynamic_cast<FPPassManager *>(PMS.top());
|
|
||||||
|
|
||||||
// Create new Function Pass Manager
|
|
||||||
if (!FPP) {
|
|
||||||
assert(!PMS.empty() && "Unable to create Function Pass Manager");
|
|
||||||
PMDataManager *PMD = PMS.top();
|
|
||||||
|
|
||||||
// [1] Create new Function Pass Manager
|
|
||||||
FPP = new FPPassManager(PMD->getDepth() + 1);
|
|
||||||
|
|
||||||
// [2] Set up new manager's top level manager
|
|
||||||
PMTopLevelManager *TPM = PMD->getTopLevelManager();
|
|
||||||
TPM->addIndirectPassManager(FPP);
|
|
||||||
|
|
||||||
// [3] Assign manager to manage this new manager. This may create
|
|
||||||
// and push new managers into PMS
|
|
||||||
Pass *P = dynamic_cast<Pass *>(FPP);
|
|
||||||
P->assignPassManager(PMS);
|
|
||||||
|
|
||||||
// [4] Push new manager into PMS
|
|
||||||
PMS.push(FPP);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assign FPP as the manager of this pass.
|
assert(!PMS.empty() && "Unable to create Function Pass Manager");
|
||||||
FPP->add(this);
|
|
||||||
|
if (PMS.top()->getPassManagerType() == PMT_FunctionPassManager
|
||||||
|
|| PMS.top()->getPassManagerType() == PMT_CallGraphPassManager)
|
||||||
|
return;
|
||||||
|
|
||||||
|
PMDataManager *PMD = PMS.top();
|
||||||
|
|
||||||
|
// [1] Create new Function Pass Manager
|
||||||
|
FPPassManager *FPP = new FPPassManager(PMD->getDepth() + 1);
|
||||||
|
|
||||||
|
// [2] Set up new manager's top level manager
|
||||||
|
PMTopLevelManager *TPM = PMD->getTopLevelManager();
|
||||||
|
TPM->addIndirectPassManager(FPP);
|
||||||
|
|
||||||
|
// [3] Assign manager to manage this new manager. This may create
|
||||||
|
// and push new managers into PMS
|
||||||
|
Pass *P = dynamic_cast<Pass *>(FPP);
|
||||||
|
P->assignPassManager(PMS);
|
||||||
|
|
||||||
|
// [4] Push new manager into PMS
|
||||||
|
PMS.push(FPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Find appropriate Basic Pass Manager or Call Graph Pass Manager
|
/// Find appropriate Function Pass Manager or Call Graph Pass Manager
|
||||||
/// in the PM Stack and add self into that manager.
|
/// in the PM Stack and add self into that manager.
|
||||||
void BasicBlockPass::assignPassManager(PMStack &PMS) {
|
void FunctionPass::assignPassManager(PMStack &PMS) {
|
||||||
|
|
||||||
|
PMDataManager *PMD = dynamic_cast<PMDataManager *>(PMS.top());
|
||||||
|
assert(PMD && "Unable to assign Pass Manager");
|
||||||
|
|
||||||
|
PMD->add(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Setup Pass Manager in advance before checking availability of
|
||||||
|
/// required analysis passes.
|
||||||
|
void BasicBlockPass::setupPassManager(PMStack &PMS) {
|
||||||
|
|
||||||
BBPassManager *BBP = NULL;
|
BBPassManager *BBP = NULL;
|
||||||
|
|
||||||
@ -1268,32 +1275,37 @@ void BasicBlockPass::assignPassManager(PMStack &PMS) {
|
|||||||
BBP = dynamic_cast<BBPassManager *>(PMS.top());
|
BBP = dynamic_cast<BBPassManager *>(PMS.top());
|
||||||
}
|
}
|
||||||
|
|
||||||
// If leaf manager is not Basic Block Pass manager then create new
|
if (BBP)
|
||||||
// basic Block Pass manager.
|
return;
|
||||||
|
|
||||||
if (!BBP) {
|
|
||||||
assert(!PMS.empty() && "Unable to create BasicBlock Pass Manager");
|
|
||||||
PMDataManager *PMD = PMS.top();
|
|
||||||
|
|
||||||
// [1] Create new Basic Block Manager
|
|
||||||
BBP = new BBPassManager(PMD->getDepth() + 1);
|
|
||||||
|
|
||||||
// [2] Set up new manager's top level manager
|
|
||||||
// Basic Block Pass Manager does not live by itself
|
|
||||||
PMTopLevelManager *TPM = PMD->getTopLevelManager();
|
|
||||||
TPM->addIndirectPassManager(BBP);
|
|
||||||
|
|
||||||
|
assert(!PMS.empty() && "Unable to create BasicBlock Pass Manager");
|
||||||
|
PMDataManager *PMD = PMS.top();
|
||||||
|
|
||||||
|
// [1] Create new Basic Block Manager
|
||||||
|
BBP = new BBPassManager(PMD->getDepth() + 1);
|
||||||
|
|
||||||
|
// [2] Set up new manager's top level manager
|
||||||
|
// Basic Block Pass Manager does not live by itself
|
||||||
|
PMTopLevelManager *TPM = PMD->getTopLevelManager();
|
||||||
|
TPM->addIndirectPassManager(BBP);
|
||||||
|
|
||||||
// [3] Assign manager to manage this new manager. This may create
|
// [3] Assign manager to manage this new manager. This may create
|
||||||
// and push new managers into PMS
|
// and push new managers into PMS
|
||||||
Pass *P = dynamic_cast<Pass *>(BBP);
|
Pass *P = dynamic_cast<Pass *>(BBP);
|
||||||
P->assignPassManager(PMS);
|
P->assignPassManager(PMS);
|
||||||
|
|
||||||
|
// [4] Push new manager into PMS
|
||||||
|
PMS.push(BBP);
|
||||||
|
}
|
||||||
|
|
||||||
// [4] Push new manager into PMS
|
/// Find appropriate Basic Pass Manager or Call Graph Pass Manager
|
||||||
PMS.push(BBP);
|
/// in the PM Stack and add self into that manager.
|
||||||
}
|
void BasicBlockPass::assignPassManager(PMStack &PMS) {
|
||||||
|
|
||||||
// Assign BBP as the manager of this pass.
|
PMDataManager *PMD = dynamic_cast<PMDataManager *>(PMS.top());
|
||||||
BBP->add(this);
|
assert(PMD && "Unable to assign Pass Manager");
|
||||||
|
|
||||||
|
PMD->add(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user