aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-05-14 12:11:51 +0000
committerChris Lattner <sabre@nondot.org>2003-05-14 12:11:51 +0000
commitf41464618f41b92cf0a0bd14ccc57bce727fb33d (patch)
tree627f8f0778b9c9f1b18087a696d1890b129f6e7b /lib
parente0c60038ebf0d259b28954a380adcbed9b5a39ee (diff)
downloadexternal_llvm-f41464618f41b92cf0a0bd14ccc57bce727fb33d.zip
external_llvm-f41464618f41b92cf0a0bd14ccc57bce727fb33d.tar.gz
external_llvm-f41464618f41b92cf0a0bd14ccc57bce727fb33d.tar.bz2
Fix major problem with appending linkage changes
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6185 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Linker/LinkModules.cpp3
-rw-r--r--lib/Transforms/Utils/Linker.cpp3
-rw-r--r--lib/VMCore/Linker.cpp3
3 files changed, 6 insertions, 3 deletions
diff --git a/lib/Linker/LinkModules.cpp b/lib/Linker/LinkModules.cpp
index 13afe1f..c4d4fc6 100644
--- a/lib/Linker/LinkModules.cpp
+++ b/lib/Linker/LinkModules.cpp
@@ -597,7 +597,8 @@ bool LinkModules(Module *Dest, const Module *Src, std::string *ErrorMsg) {
// Add all of the appending globals already in the Dest module to
// AppendingVars.
for (Module::giterator I = Dest->gbegin(), E = Dest->gend(); I != E; ++I)
- AppendingVars.insert(std::make_pair(I->getName(), I));
+ if (I->hasAppendingLinkage())
+ AppendingVars.insert(std::make_pair(I->getName(), I));
// Insert all of the globals in src into the Dest module... without linking
// initializers (which could refer to functions not yet mapped over).
diff --git a/lib/Transforms/Utils/Linker.cpp b/lib/Transforms/Utils/Linker.cpp
index 13afe1f..c4d4fc6 100644
--- a/lib/Transforms/Utils/Linker.cpp
+++ b/lib/Transforms/Utils/Linker.cpp
@@ -597,7 +597,8 @@ bool LinkModules(Module *Dest, const Module *Src, std::string *ErrorMsg) {
// Add all of the appending globals already in the Dest module to
// AppendingVars.
for (Module::giterator I = Dest->gbegin(), E = Dest->gend(); I != E; ++I)
- AppendingVars.insert(std::make_pair(I->getName(), I));
+ if (I->hasAppendingLinkage())
+ AppendingVars.insert(std::make_pair(I->getName(), I));
// Insert all of the globals in src into the Dest module... without linking
// initializers (which could refer to functions not yet mapped over).
diff --git a/lib/VMCore/Linker.cpp b/lib/VMCore/Linker.cpp
index 13afe1f..c4d4fc6 100644
--- a/lib/VMCore/Linker.cpp
+++ b/lib/VMCore/Linker.cpp
@@ -597,7 +597,8 @@ bool LinkModules(Module *Dest, const Module *Src, std::string *ErrorMsg) {
// Add all of the appending globals already in the Dest module to
// AppendingVars.
for (Module::giterator I = Dest->gbegin(), E = Dest->gend(); I != E; ++I)
- AppendingVars.insert(std::make_pair(I->getName(), I));
+ if (I->hasAppendingLinkage())
+ AppendingVars.insert(std::make_pair(I->getName(), I));
// Insert all of the globals in src into the Dest module... without linking
// initializers (which could refer to functions not yet mapped over).