Don't delete one more instruction than we're allowed to. This should fix the
authorNick Lewycky <nicholas@mxc.ca>
Tue, 24 Jul 2012 21:33:00 +0000 (21:33 +0000)
committerNick Lewycky <nicholas@mxc.ca>
Tue, 24 Jul 2012 21:33:00 +0000 (21:33 +0000)
Darwin bootstrap. Testcase exists but isn't fully reduced, I expect to commit
the testcase this evening.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@160693 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/IPO/GlobalOpt.cpp

index 60ce958de0d10f03ebb1e61423a3214d900b147a..72623a36e509b51600a91dbc0a226204250131f6 100644 (file)
@@ -442,12 +442,14 @@ static bool CleanupPointerRootUsers(GlobalVariable *GV) {
       Dead[i].second->eraseFromParent();
       Instruction *I = Dead[i].first;
       do {
+       if (isAllocationFn(I))
+         break;
         Instruction *J = dyn_cast<Instruction>(I->getOperand(0));
         if (!J)
           break;
         I->eraseFromParent();
         I = J;
-      } while (!isAllocationFn(I));
+      } while (1);
       I->eraseFromParent();
     }
   }