mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
Revert "RequiresUnique" patch. This should be handled at a lower level.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@115827 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5f0d700278
commit
933f9bdb00
@ -19,16 +19,18 @@
|
|||||||
#include "llvm/Linker.h"
|
#include "llvm/Linker.h"
|
||||||
#include "llvm/Constants.h"
|
#include "llvm/Constants.h"
|
||||||
#include "llvm/DerivedTypes.h"
|
#include "llvm/DerivedTypes.h"
|
||||||
#include "llvm/Instructions.h"
|
|
||||||
#include "llvm/LLVMContext.h"
|
#include "llvm/LLVMContext.h"
|
||||||
#include "llvm/Module.h"
|
#include "llvm/Module.h"
|
||||||
#include "llvm/TypeSymbolTable.h"
|
#include "llvm/TypeSymbolTable.h"
|
||||||
#include "llvm/ValueSymbolTable.h"
|
#include "llvm/ValueSymbolTable.h"
|
||||||
|
#include "llvm/Instructions.h"
|
||||||
|
#include "llvm/Assembly/Writer.h"
|
||||||
#include "llvm/Support/Debug.h"
|
#include "llvm/Support/Debug.h"
|
||||||
#include "llvm/Support/ErrorHandling.h"
|
#include "llvm/Support/ErrorHandling.h"
|
||||||
#include "llvm/Support/raw_ostream.h"
|
#include "llvm/Support/raw_ostream.h"
|
||||||
#include "llvm/System/Path.h"
|
#include "llvm/System/Path.h"
|
||||||
#include "llvm/Transforms/Utils/ValueMapper.h"
|
#include "llvm/Transforms/Utils/ValueMapper.h"
|
||||||
|
#include "llvm/ADT/DenseMap.h"
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
// Error - Simple wrapper function to conditionally assign to E and return true.
|
// Error - Simple wrapper function to conditionally assign to E and return true.
|
||||||
@ -454,24 +456,6 @@ static void LinkNamedMDNodes(Module *Dest, Module *Src,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// RequiresUnique - Returns true if the global variable needs to be
|
|
||||||
// unique. I.e., there shouldn't be a new global variable created in the
|
|
||||||
// destination Module, rather the source variable's initializer needs to be
|
|
||||||
// identical to the destination variable's initializer.
|
|
||||||
static bool RequiresUnique(const GlobalVariable *SGV,
|
|
||||||
const GlobalVariable *DGV) {
|
|
||||||
const StringRef SrcSec(SGV->getSection());
|
|
||||||
const StringRef DstSec(DGV->getSection());
|
|
||||||
|
|
||||||
// The Objective-C __image_info section should be unique.
|
|
||||||
if (SrcSec == DstSec &&
|
|
||||||
(SrcSec.find("__objc_imageinfo") != StringRef::npos ||
|
|
||||||
SrcSec.find("__image_info") != StringRef::npos))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// LinkGlobals - Loop through the global variables in the src module and merge
|
// LinkGlobals - Loop through the global variables in the src module and merge
|
||||||
// them into the dest module.
|
// them into the dest module.
|
||||||
static bool LinkGlobals(Module *Dest, const Module *Src,
|
static bool LinkGlobals(Module *Dest, const Module *Src,
|
||||||
@ -486,24 +470,10 @@ static bool LinkGlobals(Module *Dest, const Module *Src,
|
|||||||
const GlobalVariable *SGV = I;
|
const GlobalVariable *SGV = I;
|
||||||
GlobalValue *DGV = 0;
|
GlobalValue *DGV = 0;
|
||||||
|
|
||||||
GlobalValue *SymTabGV =
|
// Check to see if may have to link the global with the global, alias or
|
||||||
cast_or_null<GlobalValue>(DestSymTab.lookup(SGV->getName()));
|
|
||||||
|
|
||||||
// Check to see if the symbol exists in the destination module and needs to
|
|
||||||
// be merged instead of replaced.
|
|
||||||
if (SymTabGV) {
|
|
||||||
const GlobalVariable *GV = dyn_cast<GlobalVariable>(SymTabGV);
|
|
||||||
if (GV && RequiresUnique(SGV, GV)) {
|
|
||||||
// Make sure to remember this mapping.
|
|
||||||
ValueMap[SGV] = SymTabGV;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check to see if we may have to link the global with a global, alias, or
|
|
||||||
// function.
|
// function.
|
||||||
if (SGV->hasName() && !SGV->hasLocalLinkage())
|
if (SGV->hasName() && !SGV->hasLocalLinkage())
|
||||||
DGV = SymTabGV;
|
DGV = cast_or_null<GlobalValue>(DestSymTab.lookup(SGV->getName()));
|
||||||
|
|
||||||
// If we found a global with the same name in the dest module, but it has
|
// If we found a global with the same name in the dest module, but it has
|
||||||
// internal linkage, we are really not doing any linkage here.
|
// internal linkage, we are really not doing any linkage here.
|
||||||
@ -849,10 +819,10 @@ static bool LinkGlobalInits(Module *Dest, const Module *Src,
|
|||||||
// Grab destination global variable or alias.
|
// Grab destination global variable or alias.
|
||||||
GlobalValue *DGV = cast<GlobalValue>(ValueMap[SGV]->stripPointerCasts());
|
GlobalValue *DGV = cast<GlobalValue>(ValueMap[SGV]->stripPointerCasts());
|
||||||
|
|
||||||
// If dest is a global variable, check that initializers match.
|
// If dest if global variable, check that initializers match.
|
||||||
if (GlobalVariable *DGVar = dyn_cast<GlobalVariable>(DGV)) {
|
if (GlobalVariable *DGVar = dyn_cast<GlobalVariable>(DGV)) {
|
||||||
if (DGVar->hasInitializer()) {
|
if (DGVar->hasInitializer()) {
|
||||||
if (SGV->hasExternalLinkage() || RequiresUnique(SGV, DGVar)) {
|
if (SGV->hasExternalLinkage()) {
|
||||||
if (DGVar->getInitializer() != SInit)
|
if (DGVar->getInitializer() != SInit)
|
||||||
return Error(Err, "Global Variable Collision on '" +
|
return Error(Err, "Global Variable Collision on '" +
|
||||||
SGV->getName() +
|
SGV->getName() +
|
||||||
|
Loading…
Reference in New Issue
Block a user