diff options
author | Chris Lattner <sabre@nondot.org> | 2011-01-03 01:42:46 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2011-01-03 01:42:46 +0000 |
commit | d815f69b306ec0d769c3c48a66df0e75ca35f434 (patch) | |
tree | d8d2a0656b0f4510fbdb57faa4e8a48bf08dac80 /llvm/lib/Transforms/Scalar/EarlyCSE.cpp | |
parent | 2f1c34f15e9a332b59626f21533f149656adef6f (diff) | |
download | bcm5719-llvm-d815f69b306ec0d769c3c48a66df0e75ca35f434.tar.gz bcm5719-llvm-d815f69b306ec0d769c3c48a66df0e75ca35f434.zip |
Allocate nodes for the scoped hash table from a recyling bump pointer
allocator. This speeds up early cse by about 20%
llvm-svn: 122723
Diffstat (limited to 'llvm/lib/Transforms/Scalar/EarlyCSE.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/EarlyCSE.cpp | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Scalar/EarlyCSE.cpp b/llvm/lib/Transforms/Scalar/EarlyCSE.cpp index 4399e2ee1fd..99a09923f4a 100644 --- a/llvm/lib/Transforms/Scalar/EarlyCSE.cpp +++ b/llvm/lib/Transforms/Scalar/EarlyCSE.cpp @@ -21,6 +21,7 @@ #include "llvm/Target/TargetData.h" #include "llvm/Transforms/Utils/Local.h" #include "llvm/Support/Debug.h" +#include "llvm/Support/RecyclingAllocator.h" #include "llvm/ADT/ScopedHashTable.h" #include "llvm/ADT/Statistic.h" using namespace llvm; @@ -132,7 +133,11 @@ class EarlyCSE : public FunctionPass { public: const TargetData *TD; DominatorTree *DT; - ScopedHashTable<InstValue, Instruction*> *AvailableValues; + typedef RecyclingAllocator<BumpPtrAllocator, + ScopedHashTableVal<InstValue, Instruction*> > AllocatorTy; + typedef ScopedHashTable<InstValue, Instruction*, DenseMapInfo<InstValue>, + AllocatorTy> ScopedHTType; + ScopedHTType *AvailableValues; static char ID; explicit EarlyCSE() @@ -165,11 +170,10 @@ INITIALIZE_PASS_BEGIN(EarlyCSE, "early-cse", "Early CSE", false, false) INITIALIZE_PASS_DEPENDENCY(DominatorTree) INITIALIZE_PASS_END(EarlyCSE, "early-cse", "Early CSE", false, false) -// FIXME: Should bump pointer allocate entries in scoped hash table. - bool EarlyCSE::processNode(DomTreeNode *Node) { // Define a scope in the scoped hash table. - ScopedHashTableScope<InstValue, Instruction*> Scope(*AvailableValues); + ScopedHashTableScope<InstValue, Instruction*, DenseMapInfo<InstValue>, + AllocatorTy> Scope(*AvailableValues); BasicBlock *BB = Node->getBlock(); @@ -228,7 +232,7 @@ bool EarlyCSE::processNode(DomTreeNode *Node) { bool EarlyCSE::runOnFunction(Function &F) { TD = getAnalysisIfAvailable<TargetData>(); DT = &getAnalysis<DominatorTree>(); - ScopedHashTable<InstValue, Instruction*> AVTable; + ScopedHTType AVTable; AvailableValues = &AVTable; return processNode(DT->getRootNode()); } |