aboutsummaryrefslogtreecommitdiff
path: root/lib/Transforms/IPO/FunctionResolution.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Transforms/IPO/FunctionResolution.cpp')
-rw-r--r--lib/Transforms/IPO/FunctionResolution.cpp13
1 files changed, 7 insertions, 6 deletions
diff --git a/lib/Transforms/IPO/FunctionResolution.cpp b/lib/Transforms/IPO/FunctionResolution.cpp
index 844bc0027d..b8af50269d 100644
--- a/lib/Transforms/IPO/FunctionResolution.cpp
+++ b/lib/Transforms/IPO/FunctionResolution.cpp
@@ -245,24 +245,25 @@ bool FunctionResolvingPass::run(Module &M) {
// algorithm here to avoid problems with iterators getting invalidated if we
// did a one pass scheme.
//
+ bool Changed = false;
for (Module::iterator I = M.begin(), E = M.end(); I != E; ) {
Function *F = I++;
- if (F->use_empty() && F->isExternal())
+ if (F->use_empty() && F->isExternal()) {
M.getFunctionList().erase(F);
- else if (!F->hasInternalLinkage() && !F->getName().empty())
+ Changed = true;
+ } else if (!F->hasInternalLinkage() && !F->getName().empty())
Globals[F->getName()].push_back(F);
}
for (Module::giterator I = M.gbegin(), E = M.gend(); I != E; ) {
GlobalVariable *GV = I++;
- if (GV->use_empty() && GV->isExternal())
+ if (GV->use_empty() && GV->isExternal()) {
M.getGlobalList().erase(GV);
- else if (!GV->hasInternalLinkage() && !GV->getName().empty())
+ Changed = true;
+ } else if (!GV->hasInternalLinkage() && !GV->getName().empty())
Globals[GV->getName()].push_back(GV);
}
- bool Changed = false;
-
TargetData &TD = getAnalysis<TargetData>();
// Now we have a list of all functions with a particular name. If there is