From: Nadav Rotem Date: Wed, 26 Jun 2013 23:44:45 +0000 (+0000) Subject: SLP: When searching for vectorization opportunities scan the blocks in post-order... X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=70d695801a2bd5eed4bd6ea05d40516e6e6fa276;p=oota-llvm.git SLP: When searching for vectorization opportunities scan the blocks in post-order because we grow chains upwards. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@185041 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Vectorize/SLPVectorizer.cpp b/lib/Transforms/Vectorize/SLPVectorizer.cpp index 3c1dc78bc40..6ffd34bbf5a 100644 --- a/lib/Transforms/Vectorize/SLPVectorizer.cpp +++ b/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 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);