class LazyBlockFrequencyInfoPass
Declaration
class LazyBlockFrequencyInfoPass : public FunctionPass { /* full declaration omitted */ };
Description
This is an alternative analysis pass to BlockFrequencyInfoWrapperPass. The difference is that with this pass the block frequencies are not computed when the analysis pass is executed but rather when the BFI result is explicitly requested by the analysis client. There are some additional requirements for any client pass that wants to use the analysis: 1. The pass needs to initialize dependent passes with: INITIALIZE_PASS_DEPENDENCY(LazyBFIPass) 2. Similarly, getAnalysisUsage should call: LazyBlockFrequencyInfoPass::getLazyBFIAnalysisUsage(AU) 3. The computed BFI should be requested with getAnalysis <LazyBlockFrequencyInfoPass >().getBFI() before either LoopInfo or BPI could be invalidated for example by changing the CFG. Note that it is expected that we wouldn't need this functionality for the new PM since with the new PM, analyses are executed on demand.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:100
Inherits from: FunctionPass
Member Variables
- public static char ID
Method Overview
- public LazyBlockFrequencyInfoPass()
- public void getAnalysisUsage(llvm::AnalysisUsage & AU) const
- public llvm::BlockFrequencyInfo & getBFI()
- public const llvm::BlockFrequencyInfo & getBFI() const
- public static void getLazyBFIAnalysisUsage(llvm::AnalysisUsage & AU)
- public void print(llvm::raw_ostream & OS, const llvm::Module * M) const
- public void releaseMemory()
- public bool runOnFunction(llvm::Function & F)
Inherited from FunctionPass:
- public assignPassManager
- public createPrinterPass
- public getPotentialPassManagerType
- public runOnFunction
- protected skipFunction
Inherited from Pass:
- public assignPassManager
- public createPass
- public createPrinterPass
- public doFinalization
- public doInitialization
- public dump
- public dumpPassStructure
- public getAdjustedAnalysisPointer
- public getAnalysis
- public getAnalysis
- public getAnalysisID
- public getAnalysisID
- public getAnalysisIfAvailable
- public getAnalysisUsage
- public getAsImmutablePass
- public getAsPMDataManager
- public getPassID
- public getPassKind
- public getPassName
- public getPotentialPassManagerType
- public getResolver
- public lookupPassInfo
- public lookupPassInfo
- public mustPreserveAnalysisID
- public preparePassManager
- public print
- public releaseMemory
- public setResolver
- public verifyAnalysis
Methods
¶LazyBlockFrequencyInfoPass()
LazyBlockFrequencyInfoPass()
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:109
¶void getAnalysisUsage(
llvm::AnalysisUsage& AU) const
void getAnalysisUsage(
llvm::AnalysisUsage& AU) const
Description
getAnalysisUsage - This function should be overriden by passes that need analysis information to do their job. If a pass specifies that it uses a particular analysis result to this function, it can then use the getAnalysis <AnalysisType >() function, below.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:117
Parameters
¶llvm::BlockFrequencyInfo& getBFI()
llvm::BlockFrequencyInfo& getBFI()
Description
Compute and return the block frequencies.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:112
¶const llvm::BlockFrequencyInfo& getBFI() const
const llvm::BlockFrequencyInfo& getBFI() const
Description
Compute and return the block frequencies.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:115
¶static void getLazyBFIAnalysisUsage(
llvm::AnalysisUsage& AU)
static void getLazyBFIAnalysisUsage(
llvm::AnalysisUsage& AU)
Description
Helper for client passes to set up the analysis usage on behalf of this pass.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:121
Parameters
¶void print(llvm::raw_ostream& OS,
const llvm::Module* M) const
void print(llvm::raw_ostream& OS,
const llvm::Module* M) const
Description
print - Print out the internal state of the pass. This is called by Analyze to print out the contents of an analysis. Otherwise it is not necessary to implement this method. Beware that the module pointer MAY be null. This automatically forwards to a virtual function that does not provide the Module* in case the analysis doesn't need it it can just be ignored.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:125
Parameters
- llvm::raw_ostream& OS
- const llvm::Module* M
¶void releaseMemory()
void releaseMemory()
Description
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. The default behavior of passes is to hold onto memory for the entire duration of their lifetime (which is the entire compile time). For pipelined passes, this is not a big deal because that memory gets recycled every time the pass is invoked on another program unit. For IP passes, it is more important to free memory when it is unused. Optionally implement this function to release pass memory when it is no longer used.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:124
¶bool runOnFunction(llvm::Function& F)
bool runOnFunction(llvm::Function& F)
Description
runOnFunction - Virtual method overriden by subclasses to do the per-function processing of the pass.
Declared at: llvm/include/llvm/Analysis/LazyBlockFrequencyInfo.h:123