summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorNadav Rotem <nrotem@apple.com>2013-07-16 15:25:17 +0000
committerNadav Rotem <nrotem@apple.com>2013-07-16 15:25:17 +0000
commit26bf9a0c75beda69ad123bee0702af32e9ca13cb (patch)
tree57e86dc69934ba67bada87020cf103c0f1e293d9 /llvm
parent63cc9467af2bf66768221e1b4ab427b671983632 (diff)
downloadbcm5719-llvm-26bf9a0c75beda69ad123bee0702af32e9ca13cb.tar.gz
bcm5719-llvm-26bf9a0c75beda69ad123bee0702af32e9ca13cb.zip
SLPVectorizer: Reduce the compile time of the consecutive store lookup.
Process groups of stores in chunks of 16. llvm-svn: 186420
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp18
1 files changed, 13 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
index 3090aa81f1e..50ca69776e8 100644
--- a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
+++ b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
@@ -1645,7 +1645,7 @@ bool SLPVectorizer::vectorizeStoreChain(ArrayRef<Value *> Chain,
}
bool SLPVectorizer::vectorizeStores(ArrayRef<StoreInst *> Stores,
- int costThreshold, BoUpSLP &R) {
+ int costThreshold, BoUpSLP &R) {
SetVector<Value *> Heads, Tails;
SmallDenseMap<Value *, Value *> ConsecutiveChain;
@@ -1656,9 +1656,11 @@ bool SLPVectorizer::vectorizeStores(ArrayRef<StoreInst *> Stores,
// Do a quadratic search on all of the given stores and find
// all of the pairs of stores that follow each other.
- for (unsigned i = 0, e = Stores.size(); i < e; ++i)
+ for (unsigned i = 0, e = Stores.size(); i < e; ++i) {
+ if (Heads.count(Stores[i]))
+ continue;
for (unsigned j = 0; j < e; ++j) {
- if (i == j)
+ if (i == j || Tails.count(Stores[j]))
continue;
if (R.isConsecutiveAccess(Stores[i], Stores[j])) {
@@ -1667,6 +1669,7 @@ bool SLPVectorizer::vectorizeStores(ArrayRef<StoreInst *> Stores,
ConsecutiveChain[Stores[i]] = Stores[j];
}
}
+ }
// For stores that start but don't end a link in the chain:
for (SetVector<Value *>::iterator it = Heads.begin(), e = Heads.end();
@@ -1879,9 +1882,14 @@ bool SLPVectorizer::vectorizeStoreChains(BoUpSLP &R) {
continue;
DEBUG(dbgs() << "SLP: Analyzing a store chain of length "
- << it->second.size() << ".\n");
+ << it->second.size() << ".\n");
- Changed |= vectorizeStores(it->second, -SLPCostThreshold, R);
+ // Process the stores in chunks of 16.
+ for (unsigned CI = 0, CE = it->second.size(); CI < CE; CI+=16) {
+ unsigned Len = std::min<unsigned>(CE - CI, 16);
+ ArrayRef<StoreInst *> Chunk(&it->second[CI], Len);
+ Changed |= vectorizeStores(Chunk, -SLPCostThreshold, R);
+ }
}
return Changed;
}
OpenPOWER on IntegriCloud