diff options
author | David Greene <greened@obbligato.org> | 2007-08-07 16:44:38 +0000 |
---|---|---|
committer | David Greene <greened@obbligato.org> | 2007-08-07 16:44:38 +0000 |
commit | 816a190cdf1064d776666e9f21fdd2857ba74a69 (patch) | |
tree | 0d69c604b1d3a019d6cfae0a812480ae71999dbe | |
parent | 99905f16f8a2545a80d067a936be96d7544a7e4f (diff) | |
download | bcm5719-llvm-816a190cdf1064d776666e9f21fdd2857ba74a69.tar.gz bcm5719-llvm-816a190cdf1064d776666e9f21fdd2857ba74a69.zip |
Fix GLIBCXX_DEBUG error triggered by incrementing erased iterator.
llvm-svn: 40897
-rw-r--r-- | llvm/lib/Transforms/Scalar/LoopUnswitch.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp b/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp index 130db9fe419..f0c09e6d7d7 100644 --- a/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp +++ b/llvm/lib/Transforms/Scalar/LoopUnswitch.cpp @@ -777,8 +777,8 @@ void LoopUnswitch::UnswitchNontrivialCondition(Value *LIC, Constant *Val, if (LBBI != DF->end()) { DominanceFrontier::DomSetType &LBSet = LBBI->second; for (DominanceFrontier::DomSetType::iterator LI = LBSet.begin(), - LE = LBSet.end(); LI != LE; ++LI) { - BasicBlock *B = *LI; + LE = LBSet.end(); LI != LE; /* NULL */) { + BasicBlock *B = *LI++; if (OutSiders.count(B)) DF->removeFromFrontier(LBBI, B); } @@ -789,8 +789,8 @@ void LoopUnswitch::UnswitchNontrivialCondition(Value *LIC, Constant *Val, if (NBBI != DF->end()) { DominanceFrontier::DomSetType NBSet = NBBI->second; for (DominanceFrontier::DomSetType::iterator NI = NBSet.begin(), - NE = NBSet.end(); NI != NE; ++NI) { - BasicBlock *B = *NI; + NE = NBSet.end(); NI != NE; /* NULL */) { + BasicBlock *B = *NI++; if (OutSiders.count(B)) DF->removeFromFrontier(NBBI, B); } |