diff options
author | Owen Anderson <resistor@mac.com> | 2007-10-31 21:04:18 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2007-10-31 21:04:18 +0000 |
commit | ca7187ac3e79baab0cdc3b00e08078afba02c177 (patch) | |
tree | 0524280d5a4672425be6f8a9a1bd7b45a3ef822c /lib/VMCore/Verifier.cpp | |
parent | 0fb10e46aa922d91dbcb3d35c4b798b86b76f207 (diff) | |
download | external_llvm-ca7187ac3e79baab0cdc3b00e08078afba02c177.zip external_llvm-ca7187ac3e79baab0cdc3b00e08078afba02c177.tar.gz external_llvm-ca7187ac3e79baab0cdc3b00e08078afba02c177.tar.bz2 |
Add a preverifier pass to check that every basic block ends in a terminator, so that we don't segfault when verifying invalid code.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43578 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/Verifier.cpp')
-rw-r--r-- | lib/VMCore/Verifier.cpp | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/lib/VMCore/Verifier.cpp b/lib/VMCore/Verifier.cpp index 68c30bb..afb90d4 100644 --- a/lib/VMCore/Verifier.cpp +++ b/lib/VMCore/Verifier.cpp @@ -71,7 +71,25 @@ namespace { // Anonymous namespace for class cl::opt<bool> Pedantic("verify-pedantic", cl::desc("Reject code with undefined behaviour")); - + + struct VISIBILITY_HIDDEN PreVerifier : public FunctionPass { + static char ID; // Pass ID, replacement for typeid + + PreVerifier() : FunctionPass((intptr_t)&ID) { } + + bool runOnFunction(Function &F) { + for (Function::iterator I = F.begin(), E = F.end(); I != E; ++I) + assert(I->back().isTerminator() + && "Block does not end with a terminator?"); + + return false; + } + }; + + char PreVerifier::ID = 0; + RegisterPass<PreVerifier> PreVer("preverify", "Preliminary module verification"); + const PassInfo *PreVerifyID = PreVer.getPassInfo(); + struct VISIBILITY_HIDDEN Verifier : public FunctionPass, InstVisitor<Verifier> { static char ID; // Pass ID, replacement for typeid @@ -161,6 +179,7 @@ namespace { // Anonymous namespace for class virtual void getAnalysisUsage(AnalysisUsage &AU) const { AU.setPreservesAll(); + AU.addRequiredID(PreVerifyID); if (RealPass) AU.addRequired<DominatorTree>(); } |