Allow clients to specify the inline threshold when creating

the inliner pass.  Patch by Robert Zeh.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45903 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2008-01-12 06:49:13 +00:00
parent d3f6a8a8f0
commit 120d053e3b
4 changed files with 10 additions and 0 deletions

View File

@ -91,6 +91,7 @@ ModulePass *createFunctionExtractionPass(Function *F, bool deleteFn = false,
/// to inline direct function calls to small functions.
///
Pass *createFunctionInliningPass();
Pass *createFunctionInliningPass(int Threshold);
//===----------------------------------------------------------------------===//
/// createPruneEHPass - Return a new pass object which transforms invoke

View File

@ -27,6 +27,7 @@ namespace llvm {
///
struct Inliner : public CallGraphSCCPass {
explicit Inliner(const void *ID);
explicit Inliner(const void *ID, int Threshold);
/// getAnalysisUsage - For this class, we declare that we require and preserve
/// the call graph. If the derived class implements this method, it should

View File

@ -35,6 +35,7 @@ namespace {
InlineCostAnalyzer CA;
public:
SimpleInliner() : Inliner(&ID) {}
SimpleInliner(int Threshold) : Inliner(&ID, Threshold) {}
static char ID; // Pass identification, replacement for typeid
int getInlineCost(CallSite CS) {
return CA.getInlineCost(CS, NeverInline);
@ -47,6 +48,10 @@ namespace {
Pass *llvm::createFunctionInliningPass() { return new SimpleInliner(); }
Pass *llvm::createFunctionInliningPass(int Threshold) {
return new SimpleInliner(Threshold);
}
// doInitialization - Initializes the vector of functions that have been
// annotated with the noinline attribute.
bool SimpleInliner::doInitialization(CallGraph &CG) {

View File

@ -39,6 +39,9 @@ namespace {
Inliner::Inliner(const void *ID)
: CallGraphSCCPass((intptr_t)ID), InlineThreshold(InlineLimit) {}
Inliner::Inliner(const void *ID, int Threshold)
: CallGraphSCCPass((intptr_t)ID), InlineThreshold(Threshold) {}
/// getAnalysisUsage - For this class, we declare that we require and preserve
/// the call graph. If the derived class implements this method, it should
/// always explicitly call the implementation here.