mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-30 23:20:54 +00:00
Add FunctionPassManager - it's like a PassManager, but it only deals in
FunctionPasses. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7778 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
20a3be3ba8
commit
8ab1ef265a
@ -28,9 +28,33 @@ public:
|
||||
void add(Pass *P);
|
||||
|
||||
/// run - Execute all of the passes scheduled for execution. Keep track of
|
||||
/// whether any of the functions modifies the program, and if so, return true.
|
||||
/// whether any of the passes modifies the module, and if so, return true.
|
||||
///
|
||||
bool run(Module &M);
|
||||
};
|
||||
|
||||
class FunctionPass;
|
||||
class Function;
|
||||
|
||||
class FunctionPassManager {
|
||||
PassManagerT<Function> *PM; // This is a straightforward Pimpl class
|
||||
public:
|
||||
FunctionPassManager();
|
||||
~FunctionPassManager();
|
||||
|
||||
/// add - Add a pass to the queue of passes to run. This passes
|
||||
/// ownership of the FunctionPass to the PassManager. When the
|
||||
/// PassManager is destroyed, the pass will be destroyed as well, so
|
||||
/// there is no need to delete the pass. This implies that all
|
||||
/// passes MUST be allocated with 'new'.
|
||||
///
|
||||
void add(FunctionPass *P);
|
||||
|
||||
/// run - Execute all of the passes scheduled for execution. Keep
|
||||
/// track of whether any of the passes modifies the function, and if
|
||||
/// so, return true.
|
||||
///
|
||||
bool run(Function &M);
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@ -70,6 +70,16 @@ PassManager::~PassManager() { delete PM; }
|
||||
void PassManager::add(Pass *P) { PM->add(P); }
|
||||
bool PassManager::run(Module &M) { return PM->run(M); }
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// FunctionPassManager implementation - The FunctionPassManager class
|
||||
// is a simple Pimpl class that wraps the PassManagerT template. It
|
||||
// is like PassManager, but only deals in FunctionPasses.
|
||||
//
|
||||
FunctionPassManager::FunctionPassManager() : PM(new PassManagerT<Function>()) {}
|
||||
FunctionPassManager::~FunctionPassManager() { delete PM; }
|
||||
void FunctionPassManager::add(FunctionPass *P) { PM->add(P); }
|
||||
bool FunctionPassManager::run(Function &F) { return PM->run(F); }
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// TimingInfo Class - This class is used to calculate information about the
|
||||
|
Loading…
Reference in New Issue
Block a user