summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2011-03-21 14:54:40 +0000
committerAnders Carlsson <andersca@mac.com>2011-03-21 14:54:40 +0000
commit4dd420f19371715c1efb39b3a11853ccc07293cd (patch)
tree6067f89cc0dce1c9720e55320e2979feee877754 /llvm/lib/Transforms
parentfcc3ec90a51c34e039727569a7fb4b3ecdf6dc30 (diff)
downloadbcm5719-llvm-4dd420f19371715c1efb39b3a11853ccc07293cd.tar.gz
bcm5719-llvm-4dd420f19371715c1efb39b3a11853ccc07293cd.zip
More cleanups to the OptimizeEmptyGlobalCXXDtors GlobalOpt function.
llvm-svn: 127997
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/IPO/GlobalOpt.cpp24
1 files changed, 9 insertions, 15 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp
index d8212e8894f..7f69aeb0d02 100644
--- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp
+++ b/llvm/lib/Transforms/IPO/GlobalOpt.cpp
@@ -2737,18 +2737,15 @@ static bool cxxDtorIsEmpty(const Function &Fn,
for (BasicBlock::const_iterator I = EntryBlock.begin(), E = EntryBlock.end();
I != E; ++I) {
if (const CallInst *CI = dyn_cast<CallInst>(I)) {
+ // Ignore debug intrinsics.
+ if (isa<DbgInfoIntrinsic>(CI))
+ continue;
+
const Function *CalledFn = CI->getCalledFunction();
if (!CalledFn)
return false;
- if (unsigned IntrinsicID = CalledFn->getIntrinsicID()) {
- // Ignore debug intrinsics.
- if (IntrinsicID == llvm::Intrinsic::dbg_declare ||
- IntrinsicID == llvm::Intrinsic::dbg_value)
- continue;
- }
-
// Don't treat recursive functions as empty.
if (!CalledFunctions.insert(CalledFn))
return false;
@@ -2783,18 +2780,15 @@ bool GlobalOpt::OptimizeEmptyGlobalCXXDtors(Function *CXAAtExitFn) {
for (Function::use_iterator I = CXAAtExitFn->use_begin(),
E = CXAAtExitFn->use_end(); I != E;) {
- CallSite CS(*I++);
- if (!CS)
- continue;
-
// We're only interested in calls. Theoretically, we could handle invoke
// instructions as well, but neither llvm-gcc nor clang generate invokes
// to __cxa_atexit.
- if (!CS.isCall())
+ CallInst *CI = dyn_cast<CallInst>(*I++);
+ if (!CI)
continue;
Function *DtorFn =
- dyn_cast<Function>(CS.getArgument(0)->stripPointerCasts());
+ dyn_cast<Function>(CI->getArgOperand(0)->stripPointerCasts());
if (!DtorFn)
continue;
@@ -2803,8 +2797,8 @@ bool GlobalOpt::OptimizeEmptyGlobalCXXDtors(Function *CXAAtExitFn) {
continue;
// Just remove the call.
- CS->replaceAllUsesWith(Constant::getNullValue(CS.getType()));
- CS->eraseFromParent();
+ CI->replaceAllUsesWith(Constant::getNullValue(CI->getType()));
+ CI->eraseFromParent();
++NumCXXDtorsRemoved;
OpenPOWER on IntegriCloud