diff options
author | Dale Johannesen <dalej@apple.com> | 2008-01-16 19:59:28 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2008-01-16 19:59:28 +0000 |
commit | 48ae02fe62cafd44c740e67cfae6e7277e61a973 (patch) | |
tree | b240336772d6ab2230dda08dbd41f10f05e77c96 /lib/CodeGen/MachineModuleInfo.cpp | |
parent | b8b92216f1552dce7533816d21fd3a6de4b03176 (diff) |
Do not mark EH tables no-dead-strip unless the
associated function is so marked.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@46088 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/MachineModuleInfo.cpp')
-rw-r--r-- | lib/CodeGen/MachineModuleInfo.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/lib/CodeGen/MachineModuleInfo.cpp b/lib/CodeGen/MachineModuleInfo.cpp index f8796acaef..5e6d4cb496 100644 --- a/lib/CodeGen/MachineModuleInfo.cpp +++ b/lib/CodeGen/MachineModuleInfo.cpp @@ -1552,6 +1552,21 @@ bool MachineModuleInfo::Verify(Value *V) { /// void MachineModuleInfo::AnalyzeModule(Module &M) { SetupCompileUnits(M); + + // Insert functions in the llvm.used array into UsedFunctions. + GlobalVariable *GV = M.getGlobalVariable("llvm.used"); + if (!GV || !GV->hasInitializer()) return; + + // Should be an array of 'i8*'. + ConstantArray *InitList = dyn_cast<ConstantArray>(GV->getInitializer()); + if (InitList == 0) return; + + for (unsigned i = 0, e = InitList->getNumOperands(); i != e; ++i) { + if (ConstantExpr *CE = dyn_cast<ConstantExpr>(InitList->getOperand(i))) + if (CE->getOpcode() == Instruction::BitCast) + if (Function *F = dyn_cast<Function>(CE->getOperand(0))) + UsedFunctions.insert(F); + } } /// needsFrameInfo - Returns true if we need to gather callee-saved register |