From: Chris Lattner Date: Sun, 29 Aug 2010 05:12:21 +0000 (+0000) Subject: use getUniqueExitBlocks instead of a manual set. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=63a75c13b110b89435ee5e30f1ce9ed57019ac5a;p=oota-llvm.git use getUniqueExitBlocks instead of a manual set. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@112412 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/LICM.cpp b/lib/Transforms/Scalar/LICM.cpp index 639e958f040..a1868af12fd 100644 --- a/lib/Transforms/Scalar/LICM.cpp +++ b/lib/Transforms/Scalar/LICM.cpp @@ -707,18 +707,10 @@ void LICM::PromoteValuesInLoop() { // Now that the body of the loop uses the allocas instead of the original // memory locations, insert code to copy the alloca value back into the - // original memory location on all exits from the loop. Note that we only - // want to insert one copy of the code in each exit block, though the loop may - // exit to the same block more than once. - // - SmallPtrSet ProcessedBlocks; - + // original memory location on all exits from the loop. SmallVector ExitBlocks; - CurLoop->getExitBlocks(ExitBlocks); + CurLoop->getUniqueExitBlocks(ExitBlocks); for (unsigned i = 0, e = ExitBlocks.size(); i != e; ++i) { - if (!ProcessedBlocks.insert(ExitBlocks[i])) - continue; - // Copy all of the allocas into their memory locations. BasicBlock::iterator BI = ExitBlocks[i]->getFirstNonPHI(); Instruction *InsertPos = BI;