From 8bcc2d9b3f21b3821259e4e58dea4ad8de3c51d0 Mon Sep 17 00:00:00 2001 From: Christian Kamm Date: Thu, 11 Jun 2009 21:48:10 +0200 Subject: [PATCH] Increment the iterator before deleting redundant functions or globals in the StripExternals pass. --- gen/passes/StripExternals.cpp | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/gen/passes/StripExternals.cpp b/gen/passes/StripExternals.cpp index 2ee2dde8..19303881 100644 --- a/gen/passes/StripExternals.cpp +++ b/gen/passes/StripExternals.cpp @@ -54,36 +54,44 @@ ModulePass *createStripExternalsPass() { return new StripExternals(); } bool StripExternals::runOnModule(Module &M) { bool Changed = false; - for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I) { + for (Module::iterator I = M.begin(); I != M.end(); ) { if (I->hasAvailableExternallyLinkage()) { assert(!I->isDeclaration()&&"Declarations can't be available_externally"); Changed = true; ++NumFunctions; if (I->use_empty()) { DOUT << "Deleting function: " << *I; - I->eraseFromParent(); + Module::iterator todelete = I; + ++I; + todelete->eraseFromParent(); + continue; } else { I->deleteBody(); DOUT << "Deleted function body: " << *I; } } + ++I; } - for (Module::global_iterator I = M.global_begin(), E = M.global_end(); - I != E; ++I) { + for (Module::global_iterator I = M.global_begin(); + I != M.global_end(); ) { if (I->hasAvailableExternallyLinkage()) { assert(!I->isDeclaration()&&"Declarations can't be available_externally"); Changed = true; ++NumVariables; if (I->use_empty()) { DOUT << "Deleting global: " << *I; - I->eraseFromParent(); + Module::global_iterator todelete = I; + ++I; + todelete->eraseFromParent(); + continue; } else { I->setInitializer(0); I->setLinkage(GlobalValue::ExternalLinkage); DOUT << "Deleted initializer: " << *I; } } + ++I; } return Changed;