diff options
author | Nadav Rotem <nrotem@apple.com> | 2013-06-26 23:44:45 +0000 |
---|---|---|
committer | Nadav Rotem <nrotem@apple.com> | 2013-06-26 23:44:45 +0000 |
commit | 93f880fb77b8c672a307bb4cb5542b2d4fb65ab3 (patch) | |
tree | 2553fdd7a19110dd0affca1f7e1c9c4a646a1569 /llvm/lib/Transforms | |
parent | 7f0d6d7975168955ec188a03c4a45a4f334a5098 (diff) | |
download | bcm5719-llvm-93f880fb77b8c672a307bb4cb5542b2d4fb65ab3.tar.gz bcm5719-llvm-93f880fb77b8c672a307bb4cb5542b2d4fb65ab3.zip |
SLP: When searching for vectorization opportunities scan the blocks in post-order because we grow chains upwards.
llvm-svn: 185041
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r-- | llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp index 3c1dc78bc40..6ffd34bbf5a 100644 --- a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp +++ b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp @@ -1377,8 +1377,10 @@ struct SLPVectorizer : public FunctionPass { // he store instructions. FuncSLP R(&F, SE, DL, TTI, AA, LI, DT); - for (Function::iterator it = F.begin(), e = F.end(); it != e; ++it) { - BasicBlock *BB = it; + // Scan the blocks in the function in post order. + for (po_iterator<BasicBlock*> it = po_begin(&F.getEntryBlock()), + e = po_end(&F.getEntryBlock()); it != e; ++it) { + BasicBlock *BB = *it; // Vectorize trees that end at reductions. Changed |= vectorizeChainsInBlock(BB, R); |