1 //===- TestPasses.cpp - "buggy" passes used to test bugpoint --------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
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"
25 /// CrashOnCalls - This pass is used to test bugpoint. It intentionally
26 /// crashes on any call instructions.
27 class CrashOnCalls
: public BasicBlockPass
{
29 static char ID
; // Pass ID, replacement for typeid
30 CrashOnCalls() : BasicBlockPass(ID
) {}
32 virtual void getAnalysisUsage(AnalysisUsage
&AU
) const {
36 bool runOnBasicBlock(BasicBlock
&BB
) {
37 for (BasicBlock::iterator I
= BB
.begin(), E
= BB
.end(); I
!= E
; ++I
)
38 if (isa
<CallInst
>(*I
))
46 char CrashOnCalls::ID
= 0;
47 static RegisterPass
<CrashOnCalls
>
48 X("bugpoint-crashcalls",
49 "BugPoint Test Pass - Intentionally crash on CallInsts");
52 /// DeleteCalls - This pass is used to test bugpoint. It intentionally
53 /// deletes some call instructions, "misoptimizing" the program.
54 class DeleteCalls
: public BasicBlockPass
{
56 static char ID
; // Pass ID, replacement for typeid
57 DeleteCalls() : BasicBlockPass(ID
) {}
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
)) {
63 CI
->replaceAllUsesWith(Constant::getNullValue(CI
->getType()));
64 CI
->getParent()->getInstList().erase(CI
);
72 char DeleteCalls::ID
= 0;
73 static RegisterPass
<DeleteCalls
>
74 Y("bugpoint-deletecalls",
75 "BugPoint Test Pass - Intentionally 'misoptimize' CallInsts");