Fix check. PHI nodes must be handled specially, of course.
authorChris Lattner <sabre@nondot.org>
Wed, 14 Jan 2004 05:42:52 +0000 (05:42 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 14 Jan 2004 05:42:52 +0000 (05:42 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10842 91177308-0d34-0410-b5e6-96231b3b80d8

lib/VMCore/Verifier.cpp

index a9bcbd5f8f278186151d6c1360d9b73e28638ec1..1a66a9f9656da868bbd42a90bc0f2f984bc125aa 100644 (file)
@@ -507,14 +507,15 @@ void Verifier::visitInstruction(Instruction &I) {
 
     else if (Instruction *Op = dyn_cast<Instruction>(I.getOperand(i))) {
       BasicBlock *OpBlock = Op->getParent();
-      // Invoke results are only usable in the normal destination, not in the
-      // exceptional destination.
-      if (InvokeInst *II = dyn_cast<InvokeInst>(Op))
-        OpBlock = II->getNormalDest();
 
       // Check that a definition dominates all of its uses.
       //
       if (!isa<PHINode>(I)) {
+        // Invoke results are only usable in the normal destination, not in the
+        // exceptional destination.
+        if (InvokeInst *II = dyn_cast<InvokeInst>(Op))
+          OpBlock = II->getNormalDest();
+
         // Definition must dominate use unless use is unreachable!
         Assert2(DS->dominates(OpBlock, BB) ||
                 !DS->dominates(&BB->getParent()->getEntryBlock(), BB),