LLVM
8.0.1
|
FPPassManager manages BBPassManagers and FunctionPasses. More...
#include "llvm/IR/LegacyPassManagers.h"
Public Member Functions | |
FPPassManager () | |
bool | runOnFunction (Function &F) |
run - Execute all of the passes scheduled for execution. More... | |
bool | runOnModule (Module &M) override |
runOnModule - Virtual method overriden by subclasses to process the module being operated on. More... | |
void | cleanup () |
cleanup - After running all passes, clean up pass manager cache. More... | |
bool | doInitialization (Module &M) override |
doInitialization - Run all of the initializers for the function passes. More... | |
bool | doFinalization (Module &M) override |
doFinalization - Run all of the finalizers for the function passes. More... | |
PMDataManager * | getAsPMDataManager () override |
Pass * | getAsPass () override |
void | getAnalysisUsage (AnalysisUsage &Info) const override |
Pass Manager itself does not invalidate any analysis info. More... | |
void | dumpPassStructure (unsigned Offset) override |
Print passes managed by this manager. More... | |
StringRef | getPassName () const override |
getPassName - Return a nice clean name for a pass. More... | |
FunctionPass * | getContainedPass (unsigned N) |
PassManagerType | getPassManagerType () const override |
Public Member Functions inherited from llvm::ModulePass | |
ModulePass (char &pid) | |
~ModulePass () override | |
Pass * | createPrinterPass (raw_ostream &OS, const std::string &Banner) const override |
createPrinterPass - Get a module printer pass. More... | |
void | assignPassManager (PMStack &PMS, PassManagerType T) override |
Find appropriate Module Pass Manager in the PM Stack and add self into that manager. More... | |
PassManagerType | getPotentialPassManagerType () const override |
Return what kind of Pass Manager can manage this pass. More... | |
Public Member Functions inherited from llvm::Pass | |
Pass (PassKind K, char &pid) | |
Pass (const Pass &)=delete | |
Pass & | operator= (const Pass &)=delete |
virtual | ~Pass () |
PassKind | getPassKind () const |
AnalysisID | getPassID () const |
getPassID - Return the PassID number that corresponds to this pass. More... | |
virtual void | print (raw_ostream &OS, const Module *M) const |
print - Print out the internal state of the pass. More... | |
void | dump () const |
virtual void | preparePassManager (PMStack &) |
Check if available pass managers are suitable for this pass or not. More... | |
void | setResolver (AnalysisResolver *AR) |
AnalysisResolver * | getResolver () const |
virtual void | releaseMemory () |
releaseMemory() - This member can be implemented by a pass if it wants to be able to release its memory when it is no longer needed. More... | |
virtual void * | getAdjustedAnalysisPointer (AnalysisID ID) |
getAdjustedAnalysisPointer - This method is used when a pass implements an analysis interface through multiple inheritance. More... | |
virtual ImmutablePass * | getAsImmutablePass () |
virtual void | verifyAnalysis () const |
verifyAnalysis() - This member can be implemented by a analysis pass to check state of analysis information. More... | |
template<typename AnalysisType > | |
AnalysisType * | getAnalysisIfAvailable () const |
getAnalysisIfAvailable<AnalysisType>() - Subclasses use this function to get analysis information that might be around, for example to update it. More... | |
bool | mustPreserveAnalysisID (char &AID) const |
mustPreserveAnalysisID - This method serves the same function as getAnalysisIfAvailable, but works if you just have an AnalysisID. More... | |
template<typename AnalysisType > | |
AnalysisType & | getAnalysis () const |
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information that they claim to use by overriding the getAnalysisUsage function. More... | |
template<typename AnalysisType > | |
AnalysisType & | getAnalysis (Function &F) |
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information that they claim to use by overriding the getAnalysisUsage function. More... | |
template<typename AnalysisType > | |
AnalysisType & | getAnalysisID (AnalysisID PI) const |
template<typename AnalysisType > | |
AnalysisType & | getAnalysisID (AnalysisID PI, Function &F) |
Public Member Functions inherited from llvm::PMDataManager | |
PMDataManager () | |
virtual | ~PMDataManager () |
void | recordAvailableAnalysis (Pass *P) |
Augment AvailableAnalysis by adding analysis made available by pass P. More... | |
void | verifyPreservedAnalysis (Pass *P) |
verifyPreservedAnalysis – Verify analysis presreved by pass P. More... | |
void | removeNotPreservedAnalysis (Pass *P) |
Remove Analysis that is not preserved by the pass. More... | |
void | removeDeadPasses (Pass *P, StringRef Msg, enum PassDebuggingString) |
Remove dead passes used by P. More... | |
void | freePass (Pass *P, StringRef Msg, enum PassDebuggingString) |
Remove P. More... | |
void | add (Pass *P, bool ProcessAnalysis=true) |
Add pass P into the PassVector. More... | |
virtual void | addLowerLevelRequiredPass (Pass *P, Pass *RequiredPass) |
Add RequiredPass into list of lower level passes required by pass P. More... | |
virtual Pass * | getOnTheFlyPass (Pass *P, AnalysisID PI, Function &F) |
void | initializeAnalysisInfo () |
Initialize available analysis information. More... | |
bool | preserveHigherLevelAnalysis (Pass *P) |
void | collectRequiredAndUsedAnalyses (SmallVectorImpl< Pass *> &UsedPasses, SmallVectorImpl< AnalysisID > &ReqPassNotAvailable, Pass *P) |
Populate UsedPasses with analysis pass that are used or required by pass P and are available. More... | |
void | initializeAnalysisImpl (Pass *P) |
All Required analyses should be available to the pass as it runs! Here we fill in the AnalysisImpls member of the pass so that it can successfully use the getAnalysis() method to retrieve the implementations it needs. More... | |
Pass * | findAnalysisPass (AnalysisID AID, bool Direction) |
Find the pass that implements Analysis AID. More... | |
PMTopLevelManager * | getTopLevelManager () |
void | setTopLevelManager (PMTopLevelManager *T) |
unsigned | getDepth () const |
void | setDepth (unsigned newDepth) |
void | dumpLastUses (Pass *P, unsigned Offset) const |
void | dumpPassArguments () const |
void | dumpPassInfo (Pass *P, enum PassDebuggingString S1, enum PassDebuggingString S2, StringRef Msg) |
void | dumpRequiredSet (const Pass *P) const |
void | dumpPreservedSet (const Pass *P) const |
void | dumpUsedSet (const Pass *P) const |
unsigned | getNumContainedPasses () const |
DenseMap< AnalysisID, Pass * > * | getAvailableAnalysis () |
void | populateInheritedAnalysis (PMStack &PMS) |
unsigned | initSizeRemarkInfo (Module &M, StringMap< std::pair< unsigned, unsigned >> &FunctionToInstrCount) |
Set the initial size of the module if the user has specified that they want remarks for size. More... | |
void | emitInstrCountChangedRemark (Pass *P, Module &M, int64_t Delta, unsigned CountBefore, StringMap< std::pair< unsigned, unsigned >> &FunctionToInstrCount, Function *F=nullptr) |
Emit a remark signifying that the number of IR instructions in the module changed. More... | |
Static Public Attributes | |
static char | ID = 0 |
Additional Inherited Members | |
Static Public Member Functions inherited from llvm::Pass | |
static const PassInfo * | lookupPassInfo (const void *TI) |
static const PassInfo * | lookupPassInfo (StringRef Arg) |
static Pass * | createPass (AnalysisID ID) |
Protected Member Functions inherited from llvm::ModulePass | |
bool | skipModule (Module &M) const |
Optional passes call this function to check whether the pass should be skipped. More... | |
Protected Member Functions inherited from llvm::PMDataManager | |
bool | isPassDebuggingExecutionsOrMore () const |
isPassDebuggingExecutionsOrMore - Return true if -debug-pass=Executions or higher is specified. More... | |
Protected Attributes inherited from llvm::PMDataManager | |
PMTopLevelManager * | TPM |
SmallVector< Pass *, 16 > | PassVector |
DenseMap< AnalysisID, Pass * > * | InheritedAnalysis [PMT_Last] |
FPPassManager manages BBPassManagers and FunctionPasses.
It batches all function passes and basic block pass managers together and sequence them to process one function at a time before processing next function.
Definition at line 467 of file LegacyPassManagers.h.
|
inlineexplicit |
Definition at line 470 of file LegacyPassManagers.h.
References cleanup(), llvm::Pass::doFinalization(), llvm::Pass::doInitialization(), F(), and runOnFunction().
void FPPassManager::cleanup | ( | ) |
cleanup - After running all passes, clean up pass manager cache.
Definition at line 1557 of file LegacyPassManager.cpp.
References assert(), llvm::AnalysisResolver::clearAnalysisImpls(), and llvm::Pass::getResolver().
doFinalization - Run all of the finalizers for the function passes.
Reimplemented from llvm::Pass.
Definition at line 1693 of file LegacyPassManager.cpp.
References llvm::legacy::FunctionPassManagerImpl::add(), assert(), llvm::legacy::FunctionPassManagerImpl::doFinalization(), llvm::legacy::FunctionPassManagerImpl::doInitialization(), llvm::EXECUTION_MSG, llvm::Module::getInstructionCount(), llvm::Module::getModuleIdentifier(), llvm::Pass::getPassID(), llvm::getPassTimer(), llvm::Pass::getPotentialPassManagerType(), InstrCount, llvm::PassInfo::isAnalysis(), llvm::MODIFICATION_MSG, llvm::ON_MODULE_MSG, P, llvm::PMT_ModulePassManager, llvm::SmallVectorTemplateBase< T >::push_back(), llvm::legacy::FunctionPassManagerImpl::releaseMemoryOnTheFly(), llvm::legacy::FunctionPassManagerImpl::run(), llvm::ModulePass::runOnModule(), llvm::PMTopLevelManager::setLastUser(), llvm::PMDataManager::setTopLevelManager(), llvm::Module::shouldEmitInstrCountChangedRemark(), and X.
doInitialization - Run all of the initializers for the function passes.
Reimplemented from llvm::Pass.
Definition at line 1684 of file LegacyPassManager.cpp.
|
overridevirtual |
Print passes managed by this manager.
Reimplemented from llvm::Pass.
Definition at line 1601 of file LegacyPassManager.cpp.
References llvm::dbgs(), llvm::Pass::dumpPassStructure(), and llvm::raw_ostream::indent().
|
inlineoverridevirtual |
Pass Manager itself does not invalidate any analysis info.
Reimplemented from llvm::Pass.
Definition at line 503 of file LegacyPassManagers.h.
References llvm::AnalysisUsage::setPreservesAll().
|
inlineoverridevirtual |
Implements llvm::PMDataManager.
Definition at line 500 of file LegacyPassManagers.h.
|
inlineoverridevirtual |
Reimplemented from llvm::Pass.
Definition at line 499 of file LegacyPassManagers.h.
|
inline |
Definition at line 512 of file LegacyPassManagers.h.
Referenced by llvm::legacy::FunctionPassManagerImpl::releaseMemoryOnTheFly().
|
inlineoverridevirtual |
Reimplemented from llvm::PMDataManager.
Definition at line 518 of file LegacyPassManagers.h.
References llvm::PMT_FunctionPassManager.
|
inlineoverridevirtual |
getPassName - Return a nice clean name for a pass.
This usually implemented in terms of the name that is registered by one of the Registration templates, but can be overloaded directly.
Reimplemented from llvm::Pass.
Definition at line 510 of file LegacyPassManagers.h.
run - Execute all of the passes scheduled for execution.
Execute all of the passes scheduled for execution by invoking runOnFunction method.
Keep track of whether any of the passes modifies the module, and if so, return true.
Keep track of whether any of the passes modifies the function, and if so, return true.
Definition at line 1614 of file LegacyPassManager.cpp.
References llvm::EXECUTION_MSG, llvm::Function::getInstructionCount(), llvm::Value::getName(), llvm::GlobalValue::getParent(), llvm::getPassTimer(), InstrCount, llvm::GlobalValue::isDeclaration(), llvm::MODIFICATION_MSG, llvm::ON_FUNCTION_MSG, llvm::FunctionPass::runOnFunction(), llvm::Module::shouldEmitInstrCountChangedRemark(), and X.
runOnModule - Virtual method overriden by subclasses to process the module being operated on.
Implements llvm::ModulePass.
Definition at line 1675 of file LegacyPassManager.cpp.
References runOnFunction().
|
static |
Definition at line 469 of file LegacyPassManagers.h.
Referenced by llvm::legacy::FunctionPassManagerImpl::run().