Fix PR4948 (and a leak): by not destroying the DwarfException
[llvm/avr.git] / tools / bugpoint / TestPasses.cpp
blob900bf632a83bb1552d527469c1b3cb27bf8d6d39
1 //===- TestPasses.cpp - "buggy" passes used to test bugpoint --------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file contains "buggy" passes that are used to test bugpoint, to check
11 // that it is narrowing down testcases correctly.
13 //===----------------------------------------------------------------------===//
15 #include "llvm/BasicBlock.h"
16 #include "llvm/Constant.h"
17 #include "llvm/Instructions.h"
18 #include "llvm/Pass.h"
19 #include "llvm/Type.h"
20 #include "llvm/Support/InstVisitor.h"
22 using namespace llvm;
24 namespace {
25 /// CrashOnCalls - This pass is used to test bugpoint. It intentionally
26 /// crashes on any call instructions.
27 class CrashOnCalls : public BasicBlockPass {
28 public:
29 static char ID; // Pass ID, replacement for typeid
30 CrashOnCalls() : BasicBlockPass(&ID) {}
31 private:
32 virtual void getAnalysisUsage(AnalysisUsage &AU) const {
33 AU.setPreservesAll();
36 bool runOnBasicBlock(BasicBlock &BB) {
37 for (BasicBlock::iterator I = BB.begin(), E = BB.end(); I != E; ++I)
38 if (isa<CallInst>(*I))
39 abort();
41 return false;
45 char CrashOnCalls::ID = 0;
46 RegisterPass<CrashOnCalls>
47 X("bugpoint-crashcalls",
48 "BugPoint Test Pass - Intentionally crash on CallInsts");
51 namespace {
52 /// DeleteCalls - This pass is used to test bugpoint. It intentionally
53 /// deletes some call instructions, "misoptimizing" the program.
54 class DeleteCalls : public BasicBlockPass {
55 public:
56 static char ID; // Pass ID, replacement for typeid
57 DeleteCalls() : BasicBlockPass(&ID) {}
58 private:
59 bool runOnBasicBlock(BasicBlock &BB) {
60 for (BasicBlock::iterator I = BB.begin(), E = BB.end(); I != E; ++I)
61 if (CallInst *CI = dyn_cast<CallInst>(I)) {
62 if (!CI->use_empty())
63 CI->replaceAllUsesWith(Constant::getNullValue(CI->getType()));
64 CI->getParent()->getInstList().erase(CI);
65 break;
67 return false;
71 char DeleteCalls::ID = 0;
72 RegisterPass<DeleteCalls>
73 Y("bugpoint-deletecalls",
74 "BugPoint Test Pass - Intentionally 'misoptimize' CallInsts");