mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-25 00:33:15 +00:00
5f4ddf517f
s/ModulePassManager/MPPassManager/g s/FunctionPassManagerImpl_New/FunctionPassManagerImpl/g s/PassManagerImpl_New/PassManagerImpl/g Introduce FPPassManager to manage function passes and BBPassManagers. Now FunctionPassManagerImpl is an implementation class used by externally visible FunctionPassManager to manage FPPassManagers. Module pass manager (MPPassManager) now manages FPPassManagers and ModulePasses. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32679 91177308-0d34-0410-b5e6-96231b3b80d8
163 lines
4.7 KiB
C++
163 lines
4.7 KiB
C++
//===- llvm/PassManager.h - Container for Passes ----------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file was developed by the LLVM research group and is distributed under
|
|
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines the PassManager class. This class is used to hold,
|
|
// maintain, and optimize execution of Passes. The PassManager class ensures
|
|
// that analysis results are available before a pass runs, and that Pass's are
|
|
// destroyed when the PassManager is destroyed.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_PASSMANAGER_H
|
|
#define LLVM_PASSMANAGER_H
|
|
|
|
#include "llvm/Pass.h"
|
|
|
|
namespace llvm {
|
|
|
|
class Pass;
|
|
class ModulePass;
|
|
class Module;
|
|
class ModuleProvider;
|
|
|
|
#ifdef USE_OLD_PASSMANAGER
|
|
|
|
class ModulePassManager;
|
|
class FunctionPassManagerT;
|
|
class BasicBlockPassManager;
|
|
|
|
class PassManager {
|
|
ModulePassManager *PM; // This is a straightforward Pimpl class
|
|
public:
|
|
PassManager();
|
|
~PassManager();
|
|
|
|
/// add - Add a pass to the queue of passes to run. This passes ownership of
|
|
/// the Pass 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(Pass *P);
|
|
|
|
/// run - Execute all of the passes scheduled for execution. Keep track of
|
|
/// whether any of the passes modifies the module, and if so, return true.
|
|
///
|
|
bool run(Module &M);
|
|
};
|
|
|
|
class FunctionPass;
|
|
class ImmutablePass;
|
|
class Function;
|
|
|
|
class FunctionPassManager {
|
|
FunctionPassManagerT *PM; // This is a straightforward Pimpl class
|
|
ModuleProvider *MP;
|
|
public:
|
|
FunctionPassManager(ModuleProvider *P);
|
|
~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);
|
|
|
|
/// add - ImmutablePasses are not FunctionPasses, so we have a
|
|
/// special hack to get them into a FunctionPassManager.
|
|
///
|
|
void add(ImmutablePass *IP);
|
|
|
|
/// doInitialization - Run all of the initializers for the function passes.
|
|
///
|
|
bool doInitialization();
|
|
|
|
/// 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 &F);
|
|
|
|
/// doFinalization - Run all of the initializers for the function passes.
|
|
///
|
|
bool doFinalization();
|
|
};
|
|
|
|
#else
|
|
|
|
class ModulePassManager;
|
|
class PassManagerImpl;
|
|
class FunctionPassManagerImpl;
|
|
|
|
/// PassManager manages ModulePassManagers
|
|
class PassManager {
|
|
|
|
public:
|
|
|
|
PassManager();
|
|
~PassManager();
|
|
|
|
/// add - Add a pass to the queue of passes to run. This passes ownership of
|
|
/// the Pass 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(Pass *P);
|
|
|
|
/// run - Execute all of the passes scheduled for execution. Keep track of
|
|
/// whether any of the passes modifies the module, and if so, return true.
|
|
bool run(Module &M);
|
|
|
|
private:
|
|
|
|
/// PassManagerImpl_New is the actual class. PassManager is just the
|
|
/// wraper to publish simple pass manager interface
|
|
PassManagerImpl *PM;
|
|
|
|
};
|
|
|
|
/// FunctionPassManager manages FunctionPasses and BasicBlockPassManagers.
|
|
class FunctionPassManager {
|
|
public:
|
|
FunctionPassManager(ModuleProvider *P);
|
|
FunctionPassManager();
|
|
~FunctionPassManager();
|
|
|
|
/// add - Add a pass to the queue of passes to run. This passes
|
|
/// ownership of the Pass to the PassManager. When the
|
|
/// PassManager_X is destroyed, the pass will be destroyed as well, so
|
|
/// there is no need to delete the pass. (TODO delete passes.)
|
|
/// This implies that all passes MUST be allocated with 'new'.
|
|
void add(Pass *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 &F);
|
|
|
|
/// doInitialization - Run all of the initializers for the function passes.
|
|
///
|
|
bool doInitialization();
|
|
|
|
/// doFinalization - Run all of the initializers for the function passes.
|
|
///
|
|
bool doFinalization();
|
|
private:
|
|
|
|
FunctionPassManagerImpl *FPM;
|
|
ModuleProvider *MP;
|
|
};
|
|
|
|
#endif
|
|
|
|
} // End llvm namespace
|
|
|
|
#endif
|