2003-06-22 20:10:28 +00:00
|
|
|
//===- TailDuplication.cpp - Simplify CFG through tail duplication --------===//
|
2003-10-20 19:43:21 +00:00
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2003-06-22 20:10:28 +00:00
|
|
|
//
|
|
|
|
// This pass performs a limited form of tail duplication, intended to simplify
|
|
|
|
// CFGs by removing some unconditional branches. This pass is necessary to
|
|
|
|
// straighten out loops created by the C front-end, but also is capable of
|
|
|
|
// making other code nicer. After this pass is run, the CFG simplify pass
|
|
|
|
// should be run to clean up the mess.
|
|
|
|
//
|
|
|
|
// This pass could be enhanced in the future to use profile information to be
|
|
|
|
// more aggressive.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "llvm/Transforms/Scalar.h"
|
2003-08-31 21:17:44 +00:00
|
|
|
#include "llvm/Constant.h"
|
2003-06-22 20:10:28 +00:00
|
|
|
#include "llvm/Function.h"
|
2004-07-29 17:05:13 +00:00
|
|
|
#include "llvm/Instructions.h"
|
2003-06-22 20:10:28 +00:00
|
|
|
#include "llvm/Pass.h"
|
|
|
|
#include "llvm/Type.h"
|
|
|
|
#include "llvm/Support/CFG.h"
|
|
|
|
#include "llvm/Transforms/Utils/Local.h"
|
2004-04-18 00:52:43 +00:00
|
|
|
#include "Support/CommandLine.h"
|
2003-08-01 22:15:03 +00:00
|
|
|
#include "Support/Debug.h"
|
2003-06-22 20:10:28 +00:00
|
|
|
#include "Support/Statistic.h"
|
2004-01-09 06:02:20 +00:00
|
|
|
using namespace llvm;
|
2003-11-11 22:41:34 +00:00
|
|
|
|
2003-06-22 20:10:28 +00:00
|
|
|
namespace {
|
2004-04-18 00:52:43 +00:00
|
|
|
cl::opt<unsigned>
|
|
|
|
Threshold("taildup-threshold", cl::desc("Max block size to tail duplicate"),
|
|
|
|
cl::init(6), cl::Hidden);
|
2003-06-22 20:10:28 +00:00
|
|
|
Statistic<> NumEliminated("tailduplicate",
|
|
|
|
"Number of unconditional branches eliminated");
|
|
|
|
Statistic<> NumPHINodes("tailduplicate", "Number of phi nodes inserted");
|
|
|
|
|
|
|
|
class TailDup : public FunctionPass {
|
|
|
|
bool runOnFunction(Function &F);
|
|
|
|
private:
|
|
|
|
inline bool shouldEliminateUnconditionalBranch(TerminatorInst *TI);
|
|
|
|
inline void eliminateUnconditionalBranch(BranchInst *BI);
|
|
|
|
};
|
|
|
|
RegisterOpt<TailDup> X("tailduplicate", "Tail Duplication");
|
|
|
|
}
|
|
|
|
|
2003-11-11 22:41:34 +00:00
|
|
|
// Public interface to the Tail Duplication pass
|
2004-01-09 06:02:20 +00:00
|
|
|
Pass *llvm::createTailDuplicationPass() { return new TailDup(); }
|
2003-06-22 20:10:28 +00:00
|
|
|
|
|
|
|
/// runOnFunction - Top level algorithm - Loop over each unconditional branch in
|
|
|
|
/// the function, eliminating it if it looks attractive enough.
|
|
|
|
///
|
|
|
|
bool TailDup::runOnFunction(Function &F) {
|
|
|
|
bool Changed = false;
|
|
|
|
for (Function::iterator I = F.begin(), E = F.end(); I != E; )
|
Okay, so there is no reasonable way for tail duplication to update SSA form,
as it is making effectively arbitrary modifications to the CFG and we don't
have a domset/domfrontier implementations that can handle the dynamic updates.
Instead of having a bunch of code that doesn't actually work in practice,
just demote any potentially tricky values to the stack (causing the problem
to go away entirely). Later invocations of mem2reg will rebuild SSA for us.
This fixes all of the major performance regressions with tail duplication
from LLVM 1.1. For example, this loop:
---
int popcount(int x) {
int result = 0;
while (x != 0) {
result = result + (x & 0x1);
x = x >> 1;
}
return result;
}
---
Used to be compiled into:
int %popcount(int %X) {
entry:
br label %loopentry
loopentry: ; preds = %entry, %no_exit
%x.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=3]
%result.1.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=2]
%tmp.1 = seteq int %x.0, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
no_exit: ; preds = %loopentry
%tmp.4 = and int %x.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0 ; <int> [#uses=1]
%tmp.9 = shr int %x.0, ubyte 1 ; <int> [#uses=1]
br label %loopentry
loopexit: ; preds = %loopentry
ret int %result.1.0
}
And is now compiled into:
int %popcount(int %X) {
entry:
br label %no_exit
no_exit: ; preds = %entry, %no_exit
%x.0.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=2]
%result.1.0.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=1]
%tmp.4 = and int %x.0.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0.0 ; <int> [#uses=2]
%tmp.9 = shr int %x.0.0, ubyte 1 ; <int> [#uses=2]
%tmp.1 = seteq int %tmp.9, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
loopexit: ; preds = %no_exit
ret int %tmp.6
}
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12457 91177308-0d34-0410-b5e6-96231b3b80d8
2004-03-16 23:29:09 +00:00
|
|
|
if (shouldEliminateUnconditionalBranch(I->getTerminator())) {
|
2003-06-22 20:10:28 +00:00
|
|
|
eliminateUnconditionalBranch(cast<BranchInst>(I->getTerminator()));
|
|
|
|
Changed = true;
|
|
|
|
} else {
|
|
|
|
++I;
|
|
|
|
}
|
|
|
|
return Changed;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// shouldEliminateUnconditionalBranch - Return true if this branch looks
|
|
|
|
/// attractive to eliminate. We eliminate the branch if the destination basic
|
|
|
|
/// block has <= 5 instructions in it, not counting PHI nodes. In practice,
|
|
|
|
/// since one of these is a terminator instruction, this means that we will add
|
|
|
|
/// up to 4 instructions to the new block.
|
|
|
|
///
|
|
|
|
/// We don't count PHI nodes in the count since they will be removed when the
|
|
|
|
/// contents of the block are copied over.
|
|
|
|
///
|
|
|
|
bool TailDup::shouldEliminateUnconditionalBranch(TerminatorInst *TI) {
|
|
|
|
BranchInst *BI = dyn_cast<BranchInst>(TI);
|
|
|
|
if (!BI || !BI->isUnconditional()) return false; // Not an uncond branch!
|
|
|
|
|
|
|
|
BasicBlock *Dest = BI->getSuccessor(0);
|
|
|
|
if (Dest == BI->getParent()) return false; // Do not loop infinitely!
|
|
|
|
|
2003-07-23 03:32:41 +00:00
|
|
|
// Do not inline a block if we will just get another branch to the same block!
|
2004-03-16 19:45:22 +00:00
|
|
|
TerminatorInst *DTI = Dest->getTerminator();
|
|
|
|
if (BranchInst *DBI = dyn_cast<BranchInst>(DTI))
|
2003-07-23 03:32:41 +00:00
|
|
|
if (DBI->isUnconditional() && DBI->getSuccessor(0) == Dest)
|
|
|
|
return false; // Do not loop infinitely!
|
|
|
|
|
Okay, so there is no reasonable way for tail duplication to update SSA form,
as it is making effectively arbitrary modifications to the CFG and we don't
have a domset/domfrontier implementations that can handle the dynamic updates.
Instead of having a bunch of code that doesn't actually work in practice,
just demote any potentially tricky values to the stack (causing the problem
to go away entirely). Later invocations of mem2reg will rebuild SSA for us.
This fixes all of the major performance regressions with tail duplication
from LLVM 1.1. For example, this loop:
---
int popcount(int x) {
int result = 0;
while (x != 0) {
result = result + (x & 0x1);
x = x >> 1;
}
return result;
}
---
Used to be compiled into:
int %popcount(int %X) {
entry:
br label %loopentry
loopentry: ; preds = %entry, %no_exit
%x.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=3]
%result.1.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=2]
%tmp.1 = seteq int %x.0, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
no_exit: ; preds = %loopentry
%tmp.4 = and int %x.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0 ; <int> [#uses=1]
%tmp.9 = shr int %x.0, ubyte 1 ; <int> [#uses=1]
br label %loopentry
loopexit: ; preds = %loopentry
ret int %result.1.0
}
And is now compiled into:
int %popcount(int %X) {
entry:
br label %no_exit
no_exit: ; preds = %entry, %no_exit
%x.0.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=2]
%result.1.0.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=1]
%tmp.4 = and int %x.0.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0.0 ; <int> [#uses=2]
%tmp.9 = shr int %x.0.0, ubyte 1 ; <int> [#uses=2]
%tmp.1 = seteq int %tmp.9, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
loopexit: ; preds = %no_exit
ret int %tmp.6
}
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12457 91177308-0d34-0410-b5e6-96231b3b80d8
2004-03-16 23:29:09 +00:00
|
|
|
// FIXME: DemoteRegToStack cannot yet demote invoke instructions to the stack,
|
|
|
|
// because doing so would require breaking critical edges. This should be
|
|
|
|
// fixed eventually.
|
|
|
|
if (!DTI->use_empty())
|
|
|
|
return false;
|
|
|
|
|
2003-06-22 20:10:28 +00:00
|
|
|
// Do not bother working on dead blocks...
|
|
|
|
pred_iterator PI = pred_begin(Dest), PE = pred_end(Dest);
|
|
|
|
if (PI == PE && Dest != Dest->getParent()->begin())
|
|
|
|
return false; // It's just a dead block, ignore it...
|
|
|
|
|
|
|
|
// Also, do not bother with blocks with only a single predecessor: simplify
|
|
|
|
// CFG will fold these two blocks together!
|
|
|
|
++PI;
|
|
|
|
if (PI == PE) return false; // Exactly one predecessor!
|
|
|
|
|
|
|
|
BasicBlock::iterator I = Dest->begin();
|
|
|
|
while (isa<PHINode>(*I)) ++I;
|
|
|
|
|
|
|
|
for (unsigned Size = 0; I != Dest->end(); ++Size, ++I)
|
2004-04-18 00:52:43 +00:00
|
|
|
if (Size == Threshold) return false; // The block is too large...
|
2004-03-16 19:45:22 +00:00
|
|
|
|
|
|
|
// Do not tail duplicate a block that has thousands of successors into a block
|
|
|
|
// with a single successor if the block has many other predecessors. This can
|
|
|
|
// cause an N^2 explosion in CFG edges (and PHI node entries), as seen in
|
|
|
|
// cases that have a large number of indirect gotos.
|
|
|
|
if (DTI->getNumSuccessors() > 8)
|
|
|
|
if (std::distance(PI, PE) * DTI->getNumSuccessors() > 128)
|
|
|
|
return false;
|
|
|
|
|
2003-06-22 20:10:28 +00:00
|
|
|
return true;
|
|
|
|
}
|
2004-02-01 06:32:28 +00:00
|
|
|
|
2003-06-22 20:10:28 +00:00
|
|
|
|
|
|
|
/// eliminateUnconditionalBranch - Clone the instructions from the destination
|
|
|
|
/// block into the source block, eliminating the specified unconditional branch.
|
|
|
|
/// If the destination block defines values used by successors of the dest
|
|
|
|
/// block, we may need to insert PHI nodes.
|
|
|
|
///
|
|
|
|
void TailDup::eliminateUnconditionalBranch(BranchInst *Branch) {
|
|
|
|
BasicBlock *SourceBlock = Branch->getParent();
|
|
|
|
BasicBlock *DestBlock = Branch->getSuccessor(0);
|
|
|
|
assert(SourceBlock != DestBlock && "Our predicate is broken!");
|
|
|
|
|
|
|
|
DEBUG(std::cerr << "TailDuplication[" << SourceBlock->getParent()->getName()
|
|
|
|
<< "]: Eliminating branch: " << *Branch);
|
|
|
|
|
Okay, so there is no reasonable way for tail duplication to update SSA form,
as it is making effectively arbitrary modifications to the CFG and we don't
have a domset/domfrontier implementations that can handle the dynamic updates.
Instead of having a bunch of code that doesn't actually work in practice,
just demote any potentially tricky values to the stack (causing the problem
to go away entirely). Later invocations of mem2reg will rebuild SSA for us.
This fixes all of the major performance regressions with tail duplication
from LLVM 1.1. For example, this loop:
---
int popcount(int x) {
int result = 0;
while (x != 0) {
result = result + (x & 0x1);
x = x >> 1;
}
return result;
}
---
Used to be compiled into:
int %popcount(int %X) {
entry:
br label %loopentry
loopentry: ; preds = %entry, %no_exit
%x.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=3]
%result.1.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=2]
%tmp.1 = seteq int %x.0, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
no_exit: ; preds = %loopentry
%tmp.4 = and int %x.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0 ; <int> [#uses=1]
%tmp.9 = shr int %x.0, ubyte 1 ; <int> [#uses=1]
br label %loopentry
loopexit: ; preds = %loopentry
ret int %result.1.0
}
And is now compiled into:
int %popcount(int %X) {
entry:
br label %no_exit
no_exit: ; preds = %entry, %no_exit
%x.0.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=2]
%result.1.0.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=1]
%tmp.4 = and int %x.0.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0.0 ; <int> [#uses=2]
%tmp.9 = shr int %x.0.0, ubyte 1 ; <int> [#uses=2]
%tmp.1 = seteq int %tmp.9, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
loopexit: ; preds = %no_exit
ret int %tmp.6
}
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12457 91177308-0d34-0410-b5e6-96231b3b80d8
2004-03-16 23:29:09 +00:00
|
|
|
// Tail duplication can not update SSA properties correctly if the values
|
|
|
|
// defined in the duplicated tail are used outside of the tail itself. For
|
|
|
|
// this reason, we spill all values that are used outside of the tail to the
|
|
|
|
// stack.
|
|
|
|
for (BasicBlock::iterator I = DestBlock->begin(); I != DestBlock->end(); ++I)
|
|
|
|
for (Value::use_iterator UI = I->use_begin(), E = I->use_end(); UI != E;
|
|
|
|
++UI) {
|
|
|
|
bool ShouldDemote = false;
|
|
|
|
if (cast<Instruction>(*UI)->getParent() != DestBlock) {
|
|
|
|
// We must allow our successors to use tail values in their PHI nodes
|
|
|
|
// (if the incoming value corresponds to the tail block).
|
|
|
|
if (PHINode *PN = dyn_cast<PHINode>(*UI)) {
|
|
|
|
for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i)
|
|
|
|
if (PN->getIncomingValue(i) == I &&
|
|
|
|
PN->getIncomingBlock(i) != DestBlock) {
|
|
|
|
ShouldDemote = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
ShouldDemote = true;
|
|
|
|
}
|
|
|
|
} else if (PHINode *PN = dyn_cast<PHINode>(cast<Instruction>(*UI))) {
|
|
|
|
// If the user of this instruction is a PHI node in the current block,
|
2004-03-16 23:36:49 +00:00
|
|
|
// which has an entry from another block using the value, spill it.
|
|
|
|
for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i)
|
|
|
|
if (PN->getIncomingValue(i) == I &&
|
|
|
|
PN->getIncomingBlock(i) != DestBlock) {
|
|
|
|
ShouldDemote = true;
|
|
|
|
break;
|
|
|
|
}
|
Okay, so there is no reasonable way for tail duplication to update SSA form,
as it is making effectively arbitrary modifications to the CFG and we don't
have a domset/domfrontier implementations that can handle the dynamic updates.
Instead of having a bunch of code that doesn't actually work in practice,
just demote any potentially tricky values to the stack (causing the problem
to go away entirely). Later invocations of mem2reg will rebuild SSA for us.
This fixes all of the major performance regressions with tail duplication
from LLVM 1.1. For example, this loop:
---
int popcount(int x) {
int result = 0;
while (x != 0) {
result = result + (x & 0x1);
x = x >> 1;
}
return result;
}
---
Used to be compiled into:
int %popcount(int %X) {
entry:
br label %loopentry
loopentry: ; preds = %entry, %no_exit
%x.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=3]
%result.1.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=2]
%tmp.1 = seteq int %x.0, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
no_exit: ; preds = %loopentry
%tmp.4 = and int %x.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0 ; <int> [#uses=1]
%tmp.9 = shr int %x.0, ubyte 1 ; <int> [#uses=1]
br label %loopentry
loopexit: ; preds = %loopentry
ret int %result.1.0
}
And is now compiled into:
int %popcount(int %X) {
entry:
br label %no_exit
no_exit: ; preds = %entry, %no_exit
%x.0.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=2]
%result.1.0.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=1]
%tmp.4 = and int %x.0.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0.0 ; <int> [#uses=2]
%tmp.9 = shr int %x.0.0, ubyte 1 ; <int> [#uses=2]
%tmp.1 = seteq int %tmp.9, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
loopexit: ; preds = %no_exit
ret int %tmp.6
}
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12457 91177308-0d34-0410-b5e6-96231b3b80d8
2004-03-16 23:29:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (ShouldDemote) {
|
|
|
|
// We found a use outside of the tail. Create a new stack slot to
|
|
|
|
// break this inter-block usage pattern.
|
|
|
|
DemoteRegToStack(*I);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-06-22 20:10:28 +00:00
|
|
|
// We are going to have to map operands from the original block B to the new
|
|
|
|
// copy of the block B'. If there are PHI nodes in the DestBlock, these PHI
|
|
|
|
// nodes also define part of this mapping. Loop over these PHI nodes, adding
|
|
|
|
// them to our mapping.
|
2003-06-22 20:25:27 +00:00
|
|
|
//
|
2003-06-22 20:10:28 +00:00
|
|
|
std::map<Value*, Value*> ValueMapping;
|
|
|
|
|
|
|
|
BasicBlock::iterator BI = DestBlock->begin();
|
|
|
|
bool HadPHINodes = isa<PHINode>(BI);
|
|
|
|
for (; PHINode *PN = dyn_cast<PHINode>(BI); ++BI)
|
|
|
|
ValueMapping[PN] = PN->getIncomingValueForBlock(SourceBlock);
|
|
|
|
|
|
|
|
// Clone the non-phi instructions of the dest block into the source block,
|
|
|
|
// keeping track of the mapping...
|
|
|
|
//
|
|
|
|
for (; BI != DestBlock->end(); ++BI) {
|
|
|
|
Instruction *New = BI->clone();
|
|
|
|
New->setName(BI->getName());
|
|
|
|
SourceBlock->getInstList().push_back(New);
|
|
|
|
ValueMapping[BI] = New;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Now that we have built the mapping information and cloned all of the
|
|
|
|
// instructions (giving us a new terminator, among other things), walk the new
|
|
|
|
// instructions, rewriting references of old instructions to use new
|
|
|
|
// instructions.
|
|
|
|
//
|
|
|
|
BI = Branch; ++BI; // Get an iterator to the first new instruction
|
|
|
|
for (; BI != SourceBlock->end(); ++BI)
|
|
|
|
for (unsigned i = 0, e = BI->getNumOperands(); i != e; ++i)
|
|
|
|
if (Value *Remapped = ValueMapping[BI->getOperand(i)])
|
|
|
|
BI->setOperand(i, Remapped);
|
|
|
|
|
|
|
|
// Next we check to see if any of the successors of DestBlock had PHI nodes.
|
|
|
|
// If so, we need to add entries to the PHI nodes for SourceBlock now.
|
|
|
|
for (succ_iterator SI = succ_begin(DestBlock), SE = succ_end(DestBlock);
|
|
|
|
SI != SE; ++SI) {
|
|
|
|
BasicBlock *Succ = *SI;
|
|
|
|
for (BasicBlock::iterator PNI = Succ->begin();
|
|
|
|
PHINode *PN = dyn_cast<PHINode>(PNI); ++PNI) {
|
|
|
|
// Ok, we have a PHI node. Figure out what the incoming value was for the
|
|
|
|
// DestBlock.
|
|
|
|
Value *IV = PN->getIncomingValueForBlock(DestBlock);
|
|
|
|
|
|
|
|
// Remap the value if necessary...
|
|
|
|
if (Value *MappedIV = ValueMapping[IV])
|
|
|
|
IV = MappedIV;
|
|
|
|
PN->addIncoming(IV, SourceBlock);
|
|
|
|
}
|
|
|
|
}
|
Okay, so there is no reasonable way for tail duplication to update SSA form,
as it is making effectively arbitrary modifications to the CFG and we don't
have a domset/domfrontier implementations that can handle the dynamic updates.
Instead of having a bunch of code that doesn't actually work in practice,
just demote any potentially tricky values to the stack (causing the problem
to go away entirely). Later invocations of mem2reg will rebuild SSA for us.
This fixes all of the major performance regressions with tail duplication
from LLVM 1.1. For example, this loop:
---
int popcount(int x) {
int result = 0;
while (x != 0) {
result = result + (x & 0x1);
x = x >> 1;
}
return result;
}
---
Used to be compiled into:
int %popcount(int %X) {
entry:
br label %loopentry
loopentry: ; preds = %entry, %no_exit
%x.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=3]
%result.1.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=2]
%tmp.1 = seteq int %x.0, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
no_exit: ; preds = %loopentry
%tmp.4 = and int %x.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0 ; <int> [#uses=1]
%tmp.9 = shr int %x.0, ubyte 1 ; <int> [#uses=1]
br label %loopentry
loopexit: ; preds = %loopentry
ret int %result.1.0
}
And is now compiled into:
int %popcount(int %X) {
entry:
br label %no_exit
no_exit: ; preds = %entry, %no_exit
%x.0.0 = phi int [ %X, %entry ], [ %tmp.9, %no_exit ] ; <int> [#uses=2]
%result.1.0.0 = phi int [ 0, %entry ], [ %tmp.6, %no_exit ] ; <int> [#uses=1]
%tmp.4 = and int %x.0.0, 1 ; <int> [#uses=1]
%tmp.6 = add int %tmp.4, %result.1.0.0 ; <int> [#uses=2]
%tmp.9 = shr int %x.0.0, ubyte 1 ; <int> [#uses=2]
%tmp.1 = seteq int %tmp.9, 0 ; <bool> [#uses=1]
br bool %tmp.1, label %loopexit, label %no_exit
loopexit: ; preds = %no_exit
ret int %tmp.6
}
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12457 91177308-0d34-0410-b5e6-96231b3b80d8
2004-03-16 23:29:09 +00:00
|
|
|
|
|
|
|
// Next, remove the old branch instruction, and any PHI node entries that we
|
|
|
|
// had.
|
|
|
|
BI = Branch; ++BI; // Get an iterator to the first new instruction
|
|
|
|
DestBlock->removePredecessor(SourceBlock); // Remove entries in PHI nodes...
|
|
|
|
SourceBlock->getInstList().erase(Branch); // Destroy the uncond branch...
|
2003-06-22 20:10:28 +00:00
|
|
|
|
|
|
|
// Final step: now that we have finished everything up, walk the cloned
|
|
|
|
// instructions one last time, constant propagating and DCE'ing them, because
|
|
|
|
// they may not be needed anymore.
|
|
|
|
//
|
|
|
|
if (HadPHINodes)
|
|
|
|
while (BI != SourceBlock->end())
|
|
|
|
if (!dceInstruction(BI) && !doConstantPropagation(BI))
|
|
|
|
++BI;
|
|
|
|
|
|
|
|
++NumEliminated; // We just killed a branch!
|
|
|
|
}
|