LLVM 22.0.0git
llvm::RegionPass Class Referenceabstract

A pass that runs on each Region in a function. More...

#include "llvm/Analysis/RegionPass.h"

Inheritance diagram for llvm::RegionPass:
[legend]

Public Member Functions

 RegionPass (char &pid)
To be implemented by every RegionPass
virtual bool runOnRegion (Region *R, RGPassManager &RGM)=0
 Run the pass on a specific Region.
PasscreatePrinterPass (raw_ostream &O, const std::string &Banner) const override
 Get a pass to print the LLVM IR in the region.
virtual bool doInitialization (Region *R, RGPassManager &RGM)
virtual bool doFinalization ()
virtual bool doInitialization (Module &)
 doInitialization - Virtual method overridden by subclasses to do any necessary initialization before any pass is run.
virtual bool doFinalization (Module &)
 doFinalization - Virtual method overriden by subclasses to do any necessary clean up after all passes have run.
Public Member Functions inherited from llvm::Pass
 Pass (PassKind K, char &pid)
 Pass (const Pass &)=delete
Passoperator= (const Pass &)=delete
virtual ~Pass ()
PassKind getPassKind () const
virtual StringRef getPassName () const
 getPassName - Return a nice clean name for a pass.
StringRef getPassArgument () const
 Return a nice clean name for a pass corresponding to that used to enable the pass in opt.
AnalysisID getPassID () const
 getPassID - Return the PassID number that corresponds to this pass.
virtual void print (raw_ostream &OS, const Module *M) const
 print - Print out the internal state of the pass.
void dump () const
void setResolver (AnalysisResolver *AR)
AnalysisResolvergetResolver () const
virtual void getAnalysisUsage (AnalysisUsage &) const
 getAnalysisUsage - This function should be overriden by passes that need analysis information to do their job.
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.
virtual ImmutablePassgetAsImmutablePass ()
virtual PMDataManagergetAsPMDataManager ()
virtual void verifyAnalysis () const
 verifyAnalysis() - This member can be implemented by a analysis pass to check state of analysis information.
virtual void dumpPassStructure (unsigned Offset=0)
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.
bool mustPreserveAnalysisID (char &AID) const
 mustPreserveAnalysisID - This method serves the same function as getAnalysisIfAvailable, but works if you just have an AnalysisID.
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.
template<typename AnalysisType>
AnalysisType & getAnalysis (Function &F, bool *Changed=nullptr)
 getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information that they claim to use by overriding the getAnalysisUsage function.
template<typename AnalysisType>
AnalysisType & getAnalysisID (AnalysisID PI) const
template<typename AnalysisType>
AnalysisType & getAnalysisID (AnalysisID PI, Function &F, bool *Changed=nullptr)

PassManager API

void preparePassManager (PMStack &PMS) override
 Check if available pass managers are suitable for this pass or not.
void assignPassManager (PMStack &PMS, PassManagerType PMT=PMT_RegionPassManager) override
 Assign pass manager to manage this pass.
PassManagerType getPotentialPassManagerType () const override
 Return what kind of Pass Manager can manage this pass.
bool skipRegion (Region &R) const
 Optional passes call this function to check whether the pass should be skipped.

Additional Inherited Members

Static Public Member Functions inherited from llvm::Pass
static const PassInfolookupPassInfo (const void *TI)
static const PassInfolookupPassInfo (StringRef Arg)
static PasscreatePass (AnalysisID ID)

Detailed Description

A pass that runs on each Region in a function.

RegionPass is managed by RGPassManager.

Definition at line 33 of file RegionPass.h.

Constructor & Destructor Documentation

◆ RegionPass()

llvm::RegionPass::RegionPass ( char & pid)
inlineexplicit

Definition at line 35 of file RegionPass.h.

References llvm::Pass::Pass(), and llvm::PT_Region.

Member Function Documentation

◆ assignPassManager()

◆ createPrinterPass()

Pass * RegionPass::createPrinterPass ( raw_ostream & O,
const std::string & Banner ) const
overridevirtual

Get a pass to print the LLVM IR in the region.

Get the printer pass.

Parameters
OThe output stream to print the Region.
BannerThe banner to separate different printed passes.
Returns
The pass to print the LLVM IR in the region.

Implements llvm::Pass.

Definition at line 274 of file RegionPass.cpp.

References llvm::Pass::Pass().

Referenced by runOnRegion().

◆ doFinalization() [1/2]

virtual bool llvm::RegionPass::doFinalization ( )
inlinevirtual

Definition at line 64 of file RegionPass.h.

◆ doFinalization() [2/2]

virtual bool llvm::Pass::doFinalization ( Module & )
inlinevirtual

doFinalization - Virtual method overriden by subclasses to do any necessary clean up after all passes have run.

Reimplemented from llvm::Pass.

Definition at line 132 of file Pass.h.

◆ doInitialization() [1/2]

virtual bool llvm::Pass::doInitialization ( Module & )
inlinevirtual

doInitialization - Virtual method overridden by subclasses to do any necessary initialization before any pass is run.

Reimplemented from llvm::Pass.

Definition at line 128 of file Pass.h.

◆ doInitialization() [2/2]

virtual bool llvm::RegionPass::doInitialization ( Region * R,
RGPassManager & RGM )
inlinevirtual

Definition at line 63 of file RegionPass.h.

◆ getPotentialPassManagerType()

PassManagerType llvm::RegionPass::getPotentialPassManagerType ( ) const
inlineoverridevirtual

Return what kind of Pass Manager can manage this pass.

Reimplemented from llvm::Pass.

Definition at line 76 of file RegionPass.h.

References llvm::PMT_RegionPassManager.

◆ preparePassManager()

void RegionPass::preparePassManager ( PMStack & )
overridevirtual

Check if available pass managers are suitable for this pass or not.

Reimplemented from llvm::Pass.

Definition at line 220 of file RegionPass.cpp.

References llvm::PMStack::empty(), llvm::PMDataManager::getPassManagerType(), llvm::PMT_RegionPassManager, llvm::PMStack::pop(), llvm::PMDataManager::preserveHigherLevelAnalysis(), and llvm::PMStack::top().

◆ runOnRegion()

virtual bool llvm::RegionPass::runOnRegion ( Region * R,
RGPassManager & RGM )
pure virtual

Run the pass on a specific Region.

Accessing regions not contained in the current region is not allowed.

Parameters
RThe region this pass is run on.
RGMThe RegionPassManager that manages this Pass.
Returns
True if the pass modifies this Region.

References createPrinterPass(), llvm::Pass::doFinalization(), llvm::Pass::doInitialization(), and llvm::Pass::Pass().

◆ skipRegion()

bool RegionPass::skipRegion ( Region & R) const
protected

Optional passes call this function to check whether the pass should be skipped.

This is the case when optimization bisect is over the limit.

Definition at line 283 of file RegionPass.cpp.

References llvm::dbgs(), F, getDescription(), llvm::Pass::getPassName(), llvm::OptPassGate::isEnabled(), LLVM_DEBUG, and llvm::OptPassGate::shouldRunPass().


The documentation for this class was generated from the following files: