Two changes:

1. Don't scan to the end of alloca instructions in the caller function to
     insert inlined allocas, just insert at the top.  This saves a lot of
     time inlining into functions with a lot of allocas.
  2. Use splice to move the alloca instructions over, instead of remove/insert.
     This allows us to transfer a block at a time, and eliminates a bunch of
     silly symbol table manipulations.

This speeds up the inliner on the testcase in PR209 from 1.73s -> 1.04s (67%)

llvm-svn: 11118
This commit is contained in:
Chris Lattner 2004-02-04 21:33:42 +00:00
parent dbf4b42fde
commit 6f8865bf9f
1 changed files with 12 additions and 5 deletions

View File

@ -84,14 +84,21 @@ bool llvm::InlineFunction(CallSite CS) {
// //
if (isa<AllocaInst>(FirstNewBlock->begin())) { if (isa<AllocaInst>(FirstNewBlock->begin())) {
BasicBlock::iterator InsertPoint = Caller->begin()->begin(); BasicBlock::iterator InsertPoint = Caller->begin()->begin();
while (isa<AllocaInst>(InsertPoint)) ++InsertPoint;
for (BasicBlock::iterator I = FirstNewBlock->begin(), for (BasicBlock::iterator I = FirstNewBlock->begin(),
E = FirstNewBlock->end(); I != E; ) E = FirstNewBlock->end(); I != E; )
if (AllocaInst *AI = dyn_cast<AllocaInst>(I++)) if (AllocaInst *AI = dyn_cast<AllocaInst>(I++))
if (isa<Constant>(AI->getArraySize())) { if (isa<Constant>(AI->getArraySize())) {
FirstNewBlock->getInstList().remove(AI); // Scan for the block of allocas that we can move over.
Caller->front().getInstList().insert(InsertPoint, AI); while (isa<AllocaInst>(I) &&
isa<Constant>(cast<AllocaInst>(I)->getArraySize()))
++I;
// Transfer all of the allocas over in a block. Using splice means
// that they instructions aren't removed from the symbol table, then
// reinserted.
Caller->front().getInstList().splice(InsertPoint,
FirstNewBlock->getInstList(),
AI, I);
} }
} }