diff --git a/lib/VMCore/Verifier.cpp b/lib/VMCore/Verifier.cpp index a9bcbd5f8f2..1a66a9f9656 100644 --- a/lib/VMCore/Verifier.cpp +++ b/lib/VMCore/Verifier.cpp @@ -507,14 +507,15 @@ void Verifier::visitInstruction(Instruction &I) { else if (Instruction *Op = dyn_cast(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(Op)) - OpBlock = II->getNormalDest(); // Check that a definition dominates all of its uses. // if (!isa(I)) { + // Invoke results are only usable in the normal destination, not in the + // exceptional destination. + if (InvokeInst *II = dyn_cast(Op)) + OpBlock = II->getNormalDest(); + // Definition must dominate use unless use is unreachable! Assert2(DS->dominates(OpBlock, BB) || !DS->dominates(&BB->getParent()->getEntryBlock(), BB),