summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/LoopInfo.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-03-04 04:06:39 +0000
committerChris Lattner <sabre@nondot.org>2007-03-04 04:06:39 +0000
commit16cf9a7686c3bcbf55fd6a19281e293be1f7992a (patch)
tree062f68b9f3d3d8ac3e484d57f49b9a3ed0e542b0 /llvm/lib/Analysis/LoopInfo.cpp
parentf083768df35778979d42e1b89e190d2cbead7a5d (diff)
downloadbcm5719-llvm-16cf9a7686c3bcbf55fd6a19281e293be1f7992a.tar.gz
bcm5719-llvm-16cf9a7686c3bcbf55fd6a19281e293be1f7992a.zip
Speed up Loop::isLCSSAForm by using a hash table instead of a sorted vector.
llvm-svn: 34900
Diffstat (limited to 'llvm/lib/Analysis/LoopInfo.cpp')
-rw-r--r--llvm/lib/Analysis/LoopInfo.cpp16
1 files changed, 7 insertions, 9 deletions
diff --git a/llvm/lib/Analysis/LoopInfo.cpp b/llvm/lib/Analysis/LoopInfo.cpp
index 27f175058f2..ab71b883a11 100644
--- a/llvm/lib/Analysis/LoopInfo.cpp
+++ b/llvm/lib/Analysis/LoopInfo.cpp
@@ -22,6 +22,7 @@
#include "llvm/Support/CFG.h"
#include "llvm/Support/Streams.h"
#include "llvm/ADT/DepthFirstIterator.h"
+#include "llvm/ADT/SmallPtrSet.h"
#include <algorithm>
#include <ostream>
using namespace llvm;
@@ -565,25 +566,22 @@ Value *Loop::getTripCount() const {
bool Loop::isLCSSAForm() const {
// Sort the blocks vector so that we can use binary search to do quick
// lookups.
- std::vector<BasicBlock*> LoopBBs(block_begin(), block_end());
- std::sort(LoopBBs.begin(), LoopBBs.end());
+ SmallPtrSet<BasicBlock*, 16> LoopBBs(block_begin(), block_end());
- for (unsigned i = 0, e = LoopBBs.size(); i != e; ++i) {
- BasicBlock *BB = LoopBBs[i];
+ for (block_iterator BI = block_begin(), E = block_end(); BI != E; ++BI) {
+ BasicBlock *BB = *BI;
for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; ++I)
for (Value::use_iterator UI = I->use_begin(), E = I->use_end(); UI != E;
++UI) {
BasicBlock *UserBB = cast<Instruction>(*UI)->getParent();
- if (PHINode* p = dyn_cast<PHINode>(*UI)) {
+ if (PHINode *P = dyn_cast<PHINode>(*UI)) {
unsigned OperandNo = UI.getOperandNo();
- UserBB = p->getIncomingBlock(OperandNo/2);
+ UserBB = P->getIncomingBlock(OperandNo/2);
}
// Check the current block, as a fast-path. Most values are used in the
// same block they are defined in.
- if (UserBB != BB &&
- // Otherwise, binary search LoopBBs for this block.
- !std::binary_search(LoopBBs.begin(), LoopBBs.end(), UserBB))
+ if (UserBB != BB && !LoopBBs.count(UserBB))
return false;
}
}
OpenPOWER on IntegriCloud