Fix GLIBCXX_DEBUG error triggered by incrementing erased iterator.
authorDavid Greene <greened@obbligato.org>
Tue, 7 Aug 2007 16:44:38 +0000 (16:44 +0000)
committerDavid Greene <greened@obbligato.org>
Tue, 7 Aug 2007 16:44:38 +0000 (16:44 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40897 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/LoopUnswitch.cpp

index 130db9fe4199e76529d9a9882fd1afd68bb7d19d..f0c09e6d7d7c2eef7216cc3c1a677ac829a649ae 100644 (file)
@@ -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);
         }