mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-13 15:11:39 +00:00
Remove some dead code from the days llvm had type planes.
There might be more dead code, but with llvm-gcc bootstrap broken on linux x86-64 it is had to test :-( llvm-svn: 62088
This commit is contained in:
parent
4479171ba3
commit
2fed481c49
@ -51,11 +51,6 @@ class Mangler {
|
|||||||
DenseMap<const Type*, unsigned> TypeMap;
|
DenseMap<const Type*, unsigned> TypeMap;
|
||||||
unsigned TypeCounter;
|
unsigned TypeCounter;
|
||||||
|
|
||||||
/// This keeps track of which global values have had their names
|
|
||||||
/// mangled in the current module.
|
|
||||||
///
|
|
||||||
SmallPtrSet<const GlobalValue*, 16> MangledGlobals;
|
|
||||||
|
|
||||||
/// AcceptableChars - This bitfield contains a one for each character that is
|
/// AcceptableChars - This bitfield contains a one for each character that is
|
||||||
/// allowed to be part of an unmangled name.
|
/// allowed to be part of an unmangled name.
|
||||||
unsigned AcceptableChars[256/32];
|
unsigned AcceptableChars[256/32];
|
||||||
|
@ -145,49 +145,13 @@ std::string Mangler::getValueName(const GlobalValue *GV, const char * Suffix) {
|
|||||||
unsigned TypeUniqueID = getTypeID(GV->getType());
|
unsigned TypeUniqueID = getTypeID(GV->getType());
|
||||||
static unsigned GlobalID = 0;
|
static unsigned GlobalID = 0;
|
||||||
Name = "__unnamed_" + utostr(TypeUniqueID) + "_" + utostr(GlobalID++);
|
Name = "__unnamed_" + utostr(TypeUniqueID) + "_" + utostr(GlobalID++);
|
||||||
} else if (!MangledGlobals.count(GV)) {
|
|
||||||
Name = makeNameProper(GV->getName() + Suffix, Prefix);
|
|
||||||
} else {
|
} else {
|
||||||
unsigned TypeUniqueID = getTypeID(GV->getType());
|
Name = makeNameProper(GV->getName() + Suffix, Prefix);
|
||||||
Name = "l" + utostr(TypeUniqueID) + "_" + makeNameProper(GV->getName());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return Name;
|
return Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void InsertName(GlobalValue *GV, StringMap<GlobalValue*> &Names,
|
|
||||||
SmallPtrSet<const GlobalValue*, 16> &MangledGlobals) {
|
|
||||||
if (!GV->hasName()) // We must mangle unnamed globals.
|
|
||||||
return;
|
|
||||||
|
|
||||||
// Figure out if this is already used.
|
|
||||||
GlobalValue *&ExistingValue = Names[GV->getNameStart()];
|
|
||||||
if (!ExistingValue) {
|
|
||||||
ExistingValue = GV;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If GV is external but the existing one is static, mangle the existing one
|
|
||||||
if ((GV->hasExternalLinkage() || GV->hasDLLImportLinkage()) &&
|
|
||||||
!(ExistingValue->hasExternalLinkage()
|
|
||||||
|| ExistingValue->hasDLLImportLinkage())) {
|
|
||||||
MangledGlobals.insert(ExistingValue);
|
|
||||||
ExistingValue = GV;
|
|
||||||
} else if ((GV->hasExternalLinkage() ||
|
|
||||||
GV->hasDLLImportLinkage()) &&
|
|
||||||
(ExistingValue->hasExternalLinkage() ||
|
|
||||||
ExistingValue->hasDLLImportLinkage()) &&
|
|
||||||
GV->isDeclaration() &&
|
|
||||||
ExistingValue->isDeclaration()) {
|
|
||||||
// If the two globals both have external inkage, and are both external,
|
|
||||||
// don't mangle either of them, we just have some silly type mismatch.
|
|
||||||
} else {
|
|
||||||
// Otherwise, mangle GV
|
|
||||||
MangledGlobals.insert(GV);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Mangler::Mangler(Module &M, const char *prefix)
|
Mangler::Mangler(Module &M, const char *prefix)
|
||||||
: Prefix(prefix), UseQuotes(false), PreserveAsmNames(false),
|
: Prefix(prefix), UseQuotes(false), PreserveAsmNames(false),
|
||||||
Count(0), TypeCounter(0) {
|
Count(0), TypeCounter(0) {
|
||||||
@ -205,13 +169,4 @@ Mangler::Mangler(Module &M, const char *prefix)
|
|||||||
markCharAcceptable('_');
|
markCharAcceptable('_');
|
||||||
markCharAcceptable('$');
|
markCharAcceptable('$');
|
||||||
markCharAcceptable('.');
|
markCharAcceptable('.');
|
||||||
|
|
||||||
// Calculate which global values have names that will collide when we throw
|
|
||||||
// away type information.
|
|
||||||
StringMap<GlobalValue*> Names;
|
|
||||||
for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I)
|
|
||||||
InsertName(I, Names, MangledGlobals);
|
|
||||||
for (Module::global_iterator I = M.global_begin(), E = M.global_end();
|
|
||||||
I != E; ++I)
|
|
||||||
InsertName(I, Names, MangledGlobals);
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user