mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-04 17:56:53 +00:00
Tighten up verifier checks. The result of an invoke instruction only
dominates the normal destination, not the exceptional dest (ie, the result of a call is undefined on an exception) llvm-svn: 10841
This commit is contained in:
parent
9ec6983d9e
commit
e12d9fd9a7
@ -506,18 +506,24 @@ void Verifier::visitInstruction(Instruction &I) {
|
||||
"Cannot take the address of an intrinsic!", &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)) {
|
||||
// Definition must dominate use unless use is unreachable!
|
||||
Assert2(DS->dominates(Op->getParent(), BB) ||
|
||||
Assert2(DS->dominates(OpBlock, BB) ||
|
||||
!DS->dominates(&BB->getParent()->getEntryBlock(), BB),
|
||||
"Instruction does not dominate all uses!", Op, &I);
|
||||
} else {
|
||||
// PHI nodes are more difficult than other nodes because they actually
|
||||
// "use" the value in the predecessor basic blocks they correspond to.
|
||||
BasicBlock *PredBB = cast<BasicBlock>(I.getOperand(i+1));
|
||||
Assert2(DS->dominates(Op->getParent(), PredBB) ||
|
||||
Assert2(DS->dominates(OpBlock, PredBB) ||
|
||||
!DS->dominates(&BB->getParent()->getEntryBlock(), PredBB),
|
||||
"Instruction does not dominate all uses!", Op, &I);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user