From: Chris Lattner Date: Sun, 24 Aug 2003 19:26:42 +0000 (+0000) Subject: Implement: Linker/2003-08-24-InheritPtrSize.ll X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=873c5e7859c1534bf92c9e2747f2b70685059598;p=oota-llvm.git Implement: Linker/2003-08-24-InheritPtrSize.ll git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8129 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Linker/LinkModules.cpp b/lib/Linker/LinkModules.cpp index 2bf095aa55f..c6adff25867 100644 --- a/lib/Linker/LinkModules.cpp +++ b/lib/Linker/LinkModules.cpp @@ -761,9 +761,16 @@ static bool LinkAppendingVars(Module *M, // shouldn't be relied on to be consistent. // bool LinkModules(Module *Dest, const Module *Src, std::string *ErrorMsg) { - if (Dest->getEndianness() != Src->getEndianness()) + if (Dest->getEndianness() == Module::AnyEndianness) + Dest->setEndianness(Src->getEndianness()); + if (Dest->getPointerSize() == Module::AnyPointerSize) + Dest->setPointerSize(Src->getPointerSize()); + + if (Src->getEndianness() != Module::AnyEndianness && + Dest->getEndianness() != Src->getEndianness()) std::cerr << "WARNING: Linking two modules of different endianness!\n"; - if (Dest->getPointerSize() != Src->getPointerSize()) + if (Src->getPointerSize() != Module::AnyPointerSize && + Dest->getPointerSize() != Src->getPointerSize()) std::cerr << "WARNING: Linking two modules of different pointer size!\n"; // LinkTypes - Go through the symbol table of the Src module and see if any diff --git a/lib/Transforms/Utils/Linker.cpp b/lib/Transforms/Utils/Linker.cpp index 2bf095aa55f..c6adff25867 100644 --- a/lib/Transforms/Utils/Linker.cpp +++ b/lib/Transforms/Utils/Linker.cpp @@ -761,9 +761,16 @@ static bool LinkAppendingVars(Module *M, // shouldn't be relied on to be consistent. // bool LinkModules(Module *Dest, const Module *Src, std::string *ErrorMsg) { - if (Dest->getEndianness() != Src->getEndianness()) + if (Dest->getEndianness() == Module::AnyEndianness) + Dest->setEndianness(Src->getEndianness()); + if (Dest->getPointerSize() == Module::AnyPointerSize) + Dest->setPointerSize(Src->getPointerSize()); + + if (Src->getEndianness() != Module::AnyEndianness && + Dest->getEndianness() != Src->getEndianness()) std::cerr << "WARNING: Linking two modules of different endianness!\n"; - if (Dest->getPointerSize() != Src->getPointerSize()) + if (Src->getPointerSize() != Module::AnyPointerSize && + Dest->getPointerSize() != Src->getPointerSize()) std::cerr << "WARNING: Linking two modules of different pointer size!\n"; // LinkTypes - Go through the symbol table of the Src module and see if any diff --git a/lib/VMCore/Linker.cpp b/lib/VMCore/Linker.cpp index 2bf095aa55f..c6adff25867 100644 --- a/lib/VMCore/Linker.cpp +++ b/lib/VMCore/Linker.cpp @@ -761,9 +761,16 @@ static bool LinkAppendingVars(Module *M, // shouldn't be relied on to be consistent. // bool LinkModules(Module *Dest, const Module *Src, std::string *ErrorMsg) { - if (Dest->getEndianness() != Src->getEndianness()) + if (Dest->getEndianness() == Module::AnyEndianness) + Dest->setEndianness(Src->getEndianness()); + if (Dest->getPointerSize() == Module::AnyPointerSize) + Dest->setPointerSize(Src->getPointerSize()); + + if (Src->getEndianness() != Module::AnyEndianness && + Dest->getEndianness() != Src->getEndianness()) std::cerr << "WARNING: Linking two modules of different endianness!\n"; - if (Dest->getPointerSize() != Src->getPointerSize()) + if (Src->getPointerSize() != Module::AnyPointerSize && + Dest->getPointerSize() != Src->getPointerSize()) std::cerr << "WARNING: Linking two modules of different pointer size!\n"; // LinkTypes - Go through the symbol table of the Src module and see if any