diff options
| author | Chris Lattner <sabre@nondot.org> | 2007-02-03 00:08:31 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2007-02-03 00:08:31 +0000 |
| commit | 1bfc7ab6a770babdcb3c83e4a8762a1b380a3bd4 (patch) | |
| tree | 2ae599c50e4c47ce2b5d1f1d68069bad9cff546c /llvm/lib/Transforms/Scalar | |
| parent | b739f7d3376ea343b80c936e50e9dd54f1ce264a (diff) | |
| download | bcm5719-llvm-1bfc7ab6a770babdcb3c83e4a8762a1b380a3bd4.tar.gz bcm5719-llvm-1bfc7ab6a770babdcb3c83e4a8762a1b380a3bd4.zip | |
Switch inliner over to use DenseMap instead of std::map for ValueMap. This
speeds up the inliner 16%.
llvm-svn: 33801
Diffstat (limited to 'llvm/lib/Transforms/Scalar')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LoopUnroll.cpp | 16 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LoopUnswitch.cpp | 10 |
2 files changed, 13 insertions, 13 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoopUnroll.cpp b/llvm/lib/Transforms/Scalar/LoopUnroll.cpp index 655ddc41792..c6d88538310 100644 --- a/llvm/lib/Transforms/Scalar/LoopUnroll.cpp +++ b/llvm/lib/Transforms/Scalar/LoopUnroll.cpp @@ -31,9 +31,9 @@ #include "llvm/Support/Debug.h" #include "llvm/ADT/Statistic.h" #include "llvm/ADT/STLExtras.h" +#include "llvm/ADT/SmallPtrSet.h" #include "llvm/IntrinsicInst.h" #include <cstdio> -#include <set> #include <algorithm> using namespace llvm; @@ -111,10 +111,10 @@ static unsigned ApproximateLoopSize(const Loop *L) { // current values into those specified by ValueMap. // static inline void RemapInstruction(Instruction *I, - std::map<const Value *, Value*> &ValueMap) { + DenseMap<const Value *, Value*> &ValueMap) { for (unsigned op = 0, E = I->getNumOperands(); op != E; ++op) { Value *Op = I->getOperand(op); - std::map<const Value *, Value*>::iterator It = ValueMap.find(Op); + DenseMap<const Value *, Value*>::iterator It = ValueMap.find(Op); if (It != ValueMap.end()) Op = It->second; I->setOperand(op, Op); } @@ -212,7 +212,7 @@ bool LoopUnroll::visitLoop(Loop *L) { // For the first iteration of the loop, we should use the precloned values for // PHI nodes. Insert associations now. - std::map<const Value*, Value*> LastValueMap; + DenseMap<const Value*, Value*> LastValueMap; std::vector<PHINode*> OrigPHINode; for (BasicBlock::iterator I = Header->begin(); isa<PHINode>(I); ++I) { PHINode *PN = cast<PHINode>(I); @@ -240,7 +240,7 @@ bool LoopUnroll::visitLoop(Loop *L) { for (std::vector<BasicBlock*>::iterator BB = LoopBlocks.begin(), E = LoopBlocks.end(); BB != E; ++BB) { - std::map<const Value*, Value*> ValueMap; + DenseMap<const Value*, Value*> ValueMap; BasicBlock *New = CloneBasicBlock(*BB, ValueMap, SuffixBuffer); Header->getParent()->getBasicBlockList().push_back(New); @@ -259,7 +259,7 @@ bool LoopUnroll::visitLoop(Loop *L) { // Update our running map of newest clones LastValueMap[*BB] = New; - for (std::map<const Value*, Value*>::iterator VI = ValueMap.begin(), + for (DenseMap<const Value*, Value*>::iterator VI = ValueMap.begin(), VE = ValueMap.end(); VI != VE; ++VI) LastValueMap[VI->first] = VI->second; @@ -303,13 +303,13 @@ bool LoopUnroll::visitLoop(Loop *L) { // Update PHI nodes that reference the final latch block if (TripCount > 1) { - std::set<PHINode*> Users; + SmallPtrSet<PHINode*, 8> Users; for (Value::use_iterator UI = LatchBlock->use_begin(), UE = LatchBlock->use_end(); UI != UE; ++UI) if (PHINode* phi = dyn_cast<PHINode>(*UI)) Users.insert(phi); - for (std::set<PHINode*>::iterator SI = Users.begin(), SE = Users.end(); + for (SmallPtrSet<PHINode*,8>::iterator SI = Users.begin(), SE = Users.end(); SI != SE; ++SI) { Value* InVal = (*SI)->getIncomingValueForBlock(LatchBlock); if (isa<Instruction>(InVal)) diff --git a/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp b/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp index 00979a67403..9492cefb6a1 100644 --- a/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp +++ b/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp @@ -445,10 +445,10 @@ BasicBlock *LoopUnswitch::SplitEdge(BasicBlock *BB, BasicBlock *Succ) { // current values into those specified by ValueMap. // static inline void RemapInstruction(Instruction *I, - std::map<const Value *, Value*> &ValueMap) { + DenseMap<const Value *, Value*> &ValueMap) { for (unsigned op = 0, E = I->getNumOperands(); op != E; ++op) { Value *Op = I->getOperand(op); - std::map<const Value *, Value*>::iterator It = ValueMap.find(Op); + DenseMap<const Value *, Value*>::iterator It = ValueMap.find(Op); if (It != ValueMap.end()) Op = It->second; I->setOperand(op, Op); } @@ -456,7 +456,7 @@ static inline void RemapInstruction(Instruction *I, /// CloneLoop - Recursively clone the specified loop and all of its children, /// mapping the blocks with the specified map. -static Loop *CloneLoop(Loop *L, Loop *PL, std::map<const Value*, Value*> &VM, +static Loop *CloneLoop(Loop *L, Loop *PL, DenseMap<const Value*, Value*> &VM, LoopInfo *LI) { Loop *New = new Loop(); @@ -632,7 +632,7 @@ void LoopUnswitch::UnswitchNontrivialCondition(Value *LIC, Constant *Val, // the instructions and blocks. std::vector<BasicBlock*> NewBlocks; NewBlocks.reserve(LoopBlocks.size()); - std::map<const Value*, Value*> ValueMap; + DenseMap<const Value*, Value*> ValueMap; for (unsigned i = 0, e = LoopBlocks.size(); i != e; ++i) { BasicBlock *New = CloneBasicBlock(LoopBlocks[i], ValueMap, ".us", F); NewBlocks.push_back(New); @@ -669,7 +669,7 @@ void LoopUnswitch::UnswitchNontrivialCondition(Value *LIC, Constant *Val, for (BasicBlock::iterator I = ExitSucc->begin(); (PN = dyn_cast<PHINode>(I)); ++I) { Value *V = PN->getIncomingValueForBlock(ExitBlocks[i]); - std::map<const Value *, Value*>::iterator It = ValueMap.find(V); + DenseMap<const Value *, Value*>::iterator It = ValueMap.find(V); if (It != ValueMap.end()) V = It->second; PN->addIncoming(V, NewExit); } |

