forked from OSchip/llvm-project
- Replace use of std::map<std::string, ..> with StringMap. Replace use of std::map with DenseMap, std::set with SmallPtrSet. This results in minor speed up.
- Some code clean up. llvm-svn: 53379
This commit is contained in:
parent
be2e9a4447
commit
0e6973442d
|
@ -15,8 +15,7 @@
|
|||
#define LLVM_SUPPORT_MANGLER_H
|
||||
|
||||
#include "llvm/ADT/DenseMap.h"
|
||||
#include <map>
|
||||
#include <set>
|
||||
#include "llvm/ADT/SmallPtrSet.h"
|
||||
#include <string>
|
||||
|
||||
namespace llvm {
|
||||
|
@ -49,13 +48,13 @@ class Mangler {
|
|||
|
||||
/// TypeMap - If the client wants us to unique types, this keeps track of the
|
||||
/// current assignments and TypeCounter keeps track of the next id to assign.
|
||||
std::map<const Type*, unsigned> TypeMap;
|
||||
DenseMap<const Type*, unsigned> TypeMap;
|
||||
unsigned TypeCounter;
|
||||
|
||||
/// This keeps track of which global values have had their names
|
||||
/// mangled in the current module.
|
||||
///
|
||||
std::set<const GlobalValue*> MangledGlobals;
|
||||
SmallPtrSet<const GlobalValue*, 16> MangledGlobals;
|
||||
|
||||
/// AcceptableChars - This bitfield contains a one for each character that is
|
||||
/// allowed to be part of an unmangled name.
|
||||
|
@ -87,10 +86,6 @@ public:
|
|||
return (AcceptableChars[X/32] & (1 << (X&31))) != 0;
|
||||
}
|
||||
|
||||
/// getTypeID - Return a unique ID for the specified LLVM type.
|
||||
///
|
||||
unsigned getTypeID(const Type *Ty);
|
||||
|
||||
/// getValueName - Returns the mangled name of V, an LLVM Value,
|
||||
/// in the current module.
|
||||
///
|
||||
|
@ -105,9 +100,11 @@ public:
|
|||
/// from getValueName.
|
||||
///
|
||||
std::string makeNameProper(const std::string &x, const char *Prefix = "");
|
||||
|
||||
|
||||
private:
|
||||
void InsertName(GlobalValue *GV, std::map<std::string, GlobalValue*> &Names);
|
||||
/// getTypeID - Return a unique ID for the specified LLVM type.
|
||||
///
|
||||
unsigned getTypeID(const Type *Ty);
|
||||
};
|
||||
|
||||
} // End llvm namespace
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
#include "llvm/Module.h"
|
||||
#include "llvm/ADT/STLExtras.h"
|
||||
#include "llvm/ADT/StringExtras.h"
|
||||
#include "llvm/ADT/StringMap.h"
|
||||
using namespace llvm;
|
||||
|
||||
static char HexDigit(int V) {
|
||||
|
@ -138,7 +139,7 @@ std::string Mangler::getValueName(const GlobalValue *GV, const char * Suffix) {
|
|||
// - If V is an intrinsic function, do not change name at all
|
||||
// - Otherwise, mangling occurs if global collides with existing name.
|
||||
if (isa<Function>(GV) && cast<Function>(GV)->isIntrinsic()) {
|
||||
Name = GV->getName(); // Is an intrinsic function
|
||||
Name = GV->getNameStart(); // Is an intrinsic function
|
||||
} else if (!GV->hasName()) {
|
||||
// Must mangle the global into a unique ID.
|
||||
unsigned TypeUniqueID = getTypeID(GV->getType());
|
||||
|
@ -154,34 +155,35 @@ std::string Mangler::getValueName(const GlobalValue *GV, const char * Suffix) {
|
|||
return Name;
|
||||
}
|
||||
|
||||
void Mangler::InsertName(GlobalValue *GV,
|
||||
std::map<std::string, GlobalValue*> &Names) {
|
||||
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->getName()];
|
||||
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 {
|
||||
// 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);
|
||||
}
|
||||
// Otherwise, mangle GV
|
||||
MangledGlobals.insert(GV);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -206,11 +208,10 @@ Mangler::Mangler(Module &M, const char *prefix)
|
|||
|
||||
// Calculate which global values have names that will collide when we throw
|
||||
// away type information.
|
||||
std::map<std::string, GlobalValue*> Names;
|
||||
StringMap<GlobalValue*> Names;
|
||||
for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I)
|
||||
InsertName(I, Names);
|
||||
InsertName(I, Names, MangledGlobals);
|
||||
for (Module::global_iterator I = M.global_begin(), E = M.global_end();
|
||||
I != E;
|
||||
++I)
|
||||
InsertName(I, Names);
|
||||
I != E; ++I)
|
||||
InsertName(I, Names, MangledGlobals);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue