diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2014-05-06 01:26:00 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2014-05-06 01:26:00 +0000 |
commit | 09bf11693964ed6ea6b010c4843b577dd4fbb96b (patch) | |
tree | fc86072482a6675fd49c003c98526307673ef669 /llvm/lib/Transforms/IPO | |
parent | 4a406d32e97b1748c4eed6674a2c1819b9cf98ea (diff) | |
download | bcm5719-llvm-09bf11693964ed6ea6b010c4843b577dd4fbb96b.tar.gz bcm5719-llvm-09bf11693964ed6ea6b010c4843b577dd4fbb96b.zip |
Revert r208025, which made buildbots unhappy for unknown reasons.
llvm-svn: 208030
Diffstat (limited to 'llvm/lib/Transforms/IPO')
-rw-r--r-- | llvm/lib/Transforms/IPO/GlobalDCE.cpp | 6 | ||||
-rw-r--r-- | llvm/lib/Transforms/IPO/GlobalOpt.cpp | 7 |
2 files changed, 7 insertions, 6 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalDCE.cpp b/llvm/lib/Transforms/IPO/GlobalDCE.cpp index 9decddcff80..03b17d52386 100644 --- a/llvm/lib/Transforms/IPO/GlobalDCE.cpp +++ b/llvm/lib/Transforms/IPO/GlobalDCE.cpp @@ -54,16 +54,16 @@ namespace { bool RemoveUnusedGlobalValue(GlobalValue &GV); }; -} /// Returns true if F contains only a single "ret" instruction. -static bool isEmptyFunction(Function *F) { +bool isEmptyFunction(void *Context, Function *F) { BasicBlock &Entry = F->getEntryBlock(); if (Entry.size() != 1 || !isa<ReturnInst>(Entry.front())) return false; ReturnInst &RI = cast<ReturnInst>(Entry.front()); return RI.getReturnValue() == NULL; } +} char GlobalDCE::ID = 0; INITIALIZE_PASS(GlobalDCE, "globaldce", @@ -75,7 +75,7 @@ bool GlobalDCE::runOnModule(Module &M) { bool Changed = false; // Remove empty functions from the global ctors list. - Changed |= optimizeGlobalCtorsList(M, isEmptyFunction); + Changed |= optimizeGlobalCtorsList(M, isEmptyFunction, nullptr); // Loop over the module, adding globals which are obviously necessary. for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I) { diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp index a8471bacb49..3db0abf89f5 100644 --- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp +++ b/llvm/lib/Transforms/IPO/GlobalOpt.cpp @@ -3022,9 +3022,10 @@ bool GlobalOpt::runOnModule(Module &M) { LocalChange |= OptimizeFunctions(M); // Optimize global_ctors list. - LocalChange |= optimizeGlobalCtorsList(M, [&](Function *F) { - return EvaluateStaticConstructor(F, DL, TLI); - }); + LocalChange |= optimizeGlobalCtorsList(M, [](void *C, Function *F) -> bool { + GlobalOpt *self = static_cast<GlobalOpt *>(C); + return EvaluateStaticConstructor(F, self->DL, self->TLI); + }, this); // Optimize non-address-taken globals. LocalChange |= OptimizeGlobalVars(M); |