From 2c236f3e20a0fb84b5948efa6bb7bb60d759cb32 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 3 Nov 2001 05:18:24 +0000 Subject: Don't forget to link type names together too. Fix for Olden/mst benchmark git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1094 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Linker/LinkModules.cpp | 45 +++++++++++++++++++++++++++++++++++++++++ lib/Transforms/Utils/Linker.cpp | 45 +++++++++++++++++++++++++++++++++++++++++ lib/VMCore/Linker.cpp | 45 +++++++++++++++++++++++++++++++++++++++++ 3 files changed, 135 insertions(+) diff --git a/lib/Linker/LinkModules.cpp b/lib/Linker/LinkModules.cpp index a2399ed..d5df566 100644 --- a/lib/Linker/LinkModules.cpp +++ b/lib/Linker/LinkModules.cpp @@ -27,6 +27,44 @@ static inline bool Error(string *E, string Message) { #include "llvm/Assembly/Writer.h" // TODO: REMOVE + +// LinkTypes - Go through the symbol table of the Src module and see if any +// types are named in the src module that are not named in the Dst module. +// Make sure there are no type name conflicts. +// +static bool LinkTypes(Module *Dest, const Module *Src, string *Err = 0) { + // No symbol table? Can't have named types. + if (!Src->hasSymbolTable()) return false; + + SymbolTable *DestST = Dest->getSymbolTableSure(); + const SymbolTable *SrcST = Src->getSymbolTable(); + + // Look for a type plane for Type's... + SymbolTable::const_iterator PI = SrcST->find(Type::TypeTy); + if (PI == SrcST->end()) return false; // No named types, do nothing. + + const SymbolTable::VarMap &VM = PI->second; + for (SymbolTable::type_const_iterator I = VM.begin(), E = VM.end(); + I != E; ++I) { + const string &Name = I->first; + const Type *RHS = cast(I->second); + + // Check to see if this type name is already in the dest module... + const Type *Entry = cast_or_null(DestST->lookup(Type::TypeTy, Name)); + if (Entry) { // Yup, the value already exists... + if (Entry != RHS) // If it's the same, noop. Otherwise, error. + return Error(Err, "Type named '" + Name + + "' of different shape in modules.\n Src='" + + Entry->getDescription() + "'. Dest='" + + RHS->getDescription() + "'"); + } else { // Type not in dest module. Add it now. + // TODO: FIXME WHEN TYPES AREN'T CONST + DestST->insert(Name, const_cast(RHS)); + } + } + return false; +} + static void PrintMap(const map &M) { for (map::const_iterator I = M.begin(), E = M.end(); I != E; ++I) { @@ -339,6 +377,13 @@ static bool LinkMethodBodies(Module *Dest, const Module *Src, // shouldn't be relied on to be consistent. // bool LinkModules(Module *Dest, const Module *Src, string *ErrorMsg = 0) { + + // LinkTypes - Go through the symbol table of the Src module and see if any + // types are named in the src module that are not named in the Dst module. + // Make sure there are no type name conflicts. + // + if (LinkTypes(Dest, Src, ErrorMsg)) return true; + // ValueMap - Mapping of values from what they used to be in Src, to what they // are now in Dest. // diff --git a/lib/Transforms/Utils/Linker.cpp b/lib/Transforms/Utils/Linker.cpp index a2399ed..d5df566 100644 --- a/lib/Transforms/Utils/Linker.cpp +++ b/lib/Transforms/Utils/Linker.cpp @@ -27,6 +27,44 @@ static inline bool Error(string *E, string Message) { #include "llvm/Assembly/Writer.h" // TODO: REMOVE + +// LinkTypes - Go through the symbol table of the Src module and see if any +// types are named in the src module that are not named in the Dst module. +// Make sure there are no type name conflicts. +// +static bool LinkTypes(Module *Dest, const Module *Src, string *Err = 0) { + // No symbol table? Can't have named types. + if (!Src->hasSymbolTable()) return false; + + SymbolTable *DestST = Dest->getSymbolTableSure(); + const SymbolTable *SrcST = Src->getSymbolTable(); + + // Look for a type plane for Type's... + SymbolTable::const_iterator PI = SrcST->find(Type::TypeTy); + if (PI == SrcST->end()) return false; // No named types, do nothing. + + const SymbolTable::VarMap &VM = PI->second; + for (SymbolTable::type_const_iterator I = VM.begin(), E = VM.end(); + I != E; ++I) { + const string &Name = I->first; + const Type *RHS = cast(I->second); + + // Check to see if this type name is already in the dest module... + const Type *Entry = cast_or_null(DestST->lookup(Type::TypeTy, Name)); + if (Entry) { // Yup, the value already exists... + if (Entry != RHS) // If it's the same, noop. Otherwise, error. + return Error(Err, "Type named '" + Name + + "' of different shape in modules.\n Src='" + + Entry->getDescription() + "'. Dest='" + + RHS->getDescription() + "'"); + } else { // Type not in dest module. Add it now. + // TODO: FIXME WHEN TYPES AREN'T CONST + DestST->insert(Name, const_cast(RHS)); + } + } + return false; +} + static void PrintMap(const map &M) { for (map::const_iterator I = M.begin(), E = M.end(); I != E; ++I) { @@ -339,6 +377,13 @@ static bool LinkMethodBodies(Module *Dest, const Module *Src, // shouldn't be relied on to be consistent. // bool LinkModules(Module *Dest, const Module *Src, string *ErrorMsg = 0) { + + // LinkTypes - Go through the symbol table of the Src module and see if any + // types are named in the src module that are not named in the Dst module. + // Make sure there are no type name conflicts. + // + if (LinkTypes(Dest, Src, ErrorMsg)) return true; + // ValueMap - Mapping of values from what they used to be in Src, to what they // are now in Dest. // diff --git a/lib/VMCore/Linker.cpp b/lib/VMCore/Linker.cpp index a2399ed..d5df566 100644 --- a/lib/VMCore/Linker.cpp +++ b/lib/VMCore/Linker.cpp @@ -27,6 +27,44 @@ static inline bool Error(string *E, string Message) { #include "llvm/Assembly/Writer.h" // TODO: REMOVE + +// LinkTypes - Go through the symbol table of the Src module and see if any +// types are named in the src module that are not named in the Dst module. +// Make sure there are no type name conflicts. +// +static bool LinkTypes(Module *Dest, const Module *Src, string *Err = 0) { + // No symbol table? Can't have named types. + if (!Src->hasSymbolTable()) return false; + + SymbolTable *DestST = Dest->getSymbolTableSure(); + const SymbolTable *SrcST = Src->getSymbolTable(); + + // Look for a type plane for Type's... + SymbolTable::const_iterator PI = SrcST->find(Type::TypeTy); + if (PI == SrcST->end()) return false; // No named types, do nothing. + + const SymbolTable::VarMap &VM = PI->second; + for (SymbolTable::type_const_iterator I = VM.begin(), E = VM.end(); + I != E; ++I) { + const string &Name = I->first; + const Type *RHS = cast(I->second); + + // Check to see if this type name is already in the dest module... + const Type *Entry = cast_or_null(DestST->lookup(Type::TypeTy, Name)); + if (Entry) { // Yup, the value already exists... + if (Entry != RHS) // If it's the same, noop. Otherwise, error. + return Error(Err, "Type named '" + Name + + "' of different shape in modules.\n Src='" + + Entry->getDescription() + "'. Dest='" + + RHS->getDescription() + "'"); + } else { // Type not in dest module. Add it now. + // TODO: FIXME WHEN TYPES AREN'T CONST + DestST->insert(Name, const_cast(RHS)); + } + } + return false; +} + static void PrintMap(const map &M) { for (map::const_iterator I = M.begin(), E = M.end(); I != E; ++I) { @@ -339,6 +377,13 @@ static bool LinkMethodBodies(Module *Dest, const Module *Src, // shouldn't be relied on to be consistent. // bool LinkModules(Module *Dest, const Module *Src, string *ErrorMsg = 0) { + + // LinkTypes - Go through the symbol table of the Src module and see if any + // types are named in the src module that are not named in the Dst module. + // Make sure there are no type name conflicts. + // + if (LinkTypes(Dest, Src, ErrorMsg)) return true; + // ValueMap - Mapping of values from what they used to be in Src, to what they // are now in Dest. // -- cgit v1.1