mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
Add helper pass to remove llvm.dbg.declare intrinsics.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66454 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f7912df4cb
commit
23e528be80
@ -35,11 +35,16 @@ ModulePass *createStripSymbolsPass(bool OnlyDebugInfo = false);
|
|||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
//
|
//
|
||||||
// These functions removes symbols from functions and modules.
|
// These functions strips symbols from functions and modules.
|
||||||
// Only debugging information is not removed.
|
// Only debugging information is not stripped.
|
||||||
//
|
//
|
||||||
ModulePass *createStripNonDebugSymbolsPass();
|
ModulePass *createStripNonDebugSymbolsPass();
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// These pass removes llvm.dbg.declare intrinsics.
|
||||||
|
ModulePass *createStripDebugDeclarePass();
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
/// createLowerSetJmpPass - This function lowers the setjmp/longjmp intrinsics
|
/// createLowerSetJmpPass - This function lowers the setjmp/longjmp intrinsics
|
||||||
/// to invoke/unwind instructions. This should really be part of the C/C++
|
/// to invoke/unwind instructions. This should really be part of the C/C++
|
||||||
|
@ -60,6 +60,19 @@ namespace {
|
|||||||
AU.setPreservesAll();
|
AU.setPreservesAll();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class VISIBILITY_HIDDEN StripDebugDeclare : public ModulePass {
|
||||||
|
public:
|
||||||
|
static char ID; // Pass identification, replacement for typeid
|
||||||
|
explicit StripDebugDeclare()
|
||||||
|
: ModulePass(&ID) {}
|
||||||
|
|
||||||
|
virtual bool runOnModule(Module &M);
|
||||||
|
|
||||||
|
virtual void getAnalysisUsage(AnalysisUsage &AU) const {
|
||||||
|
AU.setPreservesAll();
|
||||||
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
char StripSymbols::ID = 0;
|
char StripSymbols::ID = 0;
|
||||||
@ -78,6 +91,14 @@ ModulePass *llvm::createStripNonDebugSymbolsPass() {
|
|||||||
return new StripNonDebugSymbols();
|
return new StripNonDebugSymbols();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char StripDebugDeclare::ID = 0;
|
||||||
|
static RegisterPass<StripDebugDeclare>
|
||||||
|
Z("strip-debug-declare", "Strip all llvm.dbg.declare intrinsics");
|
||||||
|
|
||||||
|
ModulePass *llvm::createStripDebugDeclarePass() {
|
||||||
|
return new StripDebugDeclare();
|
||||||
|
}
|
||||||
|
|
||||||
/// OnlyUsedBy - Return true if V is only used by Usr.
|
/// OnlyUsedBy - Return true if V is only used by Usr.
|
||||||
static bool OnlyUsedBy(Value *V, Value *Usr) {
|
static bool OnlyUsedBy(Value *V, Value *Usr) {
|
||||||
for(Value::use_iterator I = V->use_begin(), E = V->use_end(); I != E; ++I) {
|
for(Value::use_iterator I = V->use_begin(), E = V->use_end(); I != E; ++I) {
|
||||||
@ -343,3 +364,44 @@ bool StripSymbols::runOnModule(Module &M) {
|
|||||||
bool StripNonDebugSymbols::runOnModule(Module &M) {
|
bool StripNonDebugSymbols::runOnModule(Module &M) {
|
||||||
return StripSymbolNames(M, true);
|
return StripSymbolNames(M, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool StripDebugDeclare::runOnModule(Module &M) {
|
||||||
|
|
||||||
|
Function *Declare = M.getFunction("llvm.dbg.declare");
|
||||||
|
|
||||||
|
if (!Declare)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
std::vector<Constant*> DeadConstants;
|
||||||
|
|
||||||
|
while (!Declare->use_empty()) {
|
||||||
|
CallInst *CI = cast<CallInst>(Declare->use_back());
|
||||||
|
Value *Arg1 = CI->getOperand(1);
|
||||||
|
Value *Arg2 = CI->getOperand(2);
|
||||||
|
assert(CI->use_empty() && "llvm.dbg intrinsic should have void result");
|
||||||
|
CI->eraseFromParent();
|
||||||
|
if (Arg1->use_empty()) {
|
||||||
|
if (Constant *C = dyn_cast<Constant>(Arg1))
|
||||||
|
DeadConstants.push_back(C);
|
||||||
|
else
|
||||||
|
RecursivelyDeleteTriviallyDeadInstructions(Arg1, NULL);
|
||||||
|
}
|
||||||
|
if (Arg2->use_empty())
|
||||||
|
if (Constant *C = dyn_cast<Constant>(Arg2))
|
||||||
|
DeadConstants.push_back(C);
|
||||||
|
}
|
||||||
|
Declare->eraseFromParent();
|
||||||
|
|
||||||
|
while (!DeadConstants.empty()) {
|
||||||
|
Constant *C = DeadConstants.back();
|
||||||
|
DeadConstants.pop_back();
|
||||||
|
if (GlobalVariable *GV = dyn_cast<GlobalVariable>(C)) {
|
||||||
|
if (GV->hasLocalLinkage())
|
||||||
|
RemoveDeadConstant(GV);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
RemoveDeadConstant(C);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user