From 89b33b1999d4ebb03aa3af771827e5254d170625 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 29 Oct 2003 06:01:26 +0000 Subject: [PATCH] Fix bug: ConstantMerge/2003-10-28-MergeExternalConstants.ll & PR64 llvm-svn: 9579 --- lib/Transforms/IPO/ConstantMerge.cpp | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/lib/Transforms/IPO/ConstantMerge.cpp b/lib/Transforms/IPO/ConstantMerge.cpp index e353a455467..a4526820e61 100644 --- a/lib/Transforms/IPO/ConstantMerge.cpp +++ b/lib/Transforms/IPO/ConstantMerge.cpp @@ -52,14 +52,25 @@ bool ConstantMerge::run(Module &M) { if (I == CMap.end()) { // Nope, add it to the map CMap.insert(I, std::make_pair(Init, GV)); - } else { // Yup, this is a duplicate! + } else if (GV->hasInternalLinkage()) { // Yup, this is a duplicate! // Make all uses of the duplicate constant use the canonical version... GV->replaceAllUsesWith(I->second); - + // Delete the global value from the module... and back up iterator to // not skip the next global... GV = --M.getGlobalList().erase(GV); + ++NumMerged; + MadeChanges = true; + } else if (I->second->hasInternalLinkage()) { + // Make all uses of the duplicate constant use the canonical version... + I->second->replaceAllUsesWith(GV); + + // Delete the global value from the module... and back up iterator to + // not skip the next global... + M.getGlobalList().erase(I->second); + I->second = GV; + ++NumMerged; MadeChanges = true; }