mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-25 13:24:46 +00:00
Remove the isImplicitlyPrivate argument of getNameWithPrefix.
getSymbolWithGlobalValueBase use is to create a name of a new symbol based on the name of an existing GV. Assert that and then remove the last call to pass true to isImplicitlyPrivate. This gives the mangler API a 1:1 mapping from GV to names, which is what we need to drop the mangler dependency on the target (and use an extended datalayout instead). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@196472 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -51,8 +51,7 @@ public:
|
|||||||
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
||||||
/// and the specified global variable's name. If the global variable doesn't
|
/// and the specified global variable's name. If the global variable doesn't
|
||||||
/// have a name, this fills in a unique name for the global.
|
/// have a name, this fills in a unique name for the global.
|
||||||
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const GlobalValue *GV,
|
void getNameWithPrefix(SmallVectorImpl<char> &OutName, const GlobalValue *GV);
|
||||||
bool isImplicitlyPrivate);
|
|
||||||
|
|
||||||
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
/// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
|
||||||
/// and the specified name as the global variable name. GVName must not be
|
/// and the specified name as the global variable name. GVName must not be
|
||||||
|
@@ -325,7 +325,7 @@ void *MCJIT::getPointerToFunction(Function *F) {
|
|||||||
// load address of the symbol, not the local address.
|
// load address of the symbol, not the local address.
|
||||||
Mangler Mang(TM);
|
Mangler Mang(TM);
|
||||||
SmallString<128> Name;
|
SmallString<128> Name;
|
||||||
Mang.getNameWithPrefix(Name, F, false);
|
Mang.getNameWithPrefix(Name, F);
|
||||||
return (void*)Dyld.getSymbolLoadAddress(Name);
|
return (void*)Dyld.getSymbolLoadAddress(Name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -320,7 +320,7 @@ applyRestriction(GlobalValue &GV,
|
|||||||
SmallPtrSet<GlobalValue*, 8> &AsmUsed,
|
SmallPtrSet<GlobalValue*, 8> &AsmUsed,
|
||||||
Mangler &Mangler) {
|
Mangler &Mangler) {
|
||||||
SmallString<64> Buffer;
|
SmallString<64> Buffer;
|
||||||
Mangler.getNameWithPrefix(Buffer, &GV, false);
|
Mangler.getNameWithPrefix(Buffer, &GV);
|
||||||
|
|
||||||
if (GV.isDeclaration())
|
if (GV.isDeclaration())
|
||||||
return;
|
return;
|
||||||
|
@@ -360,7 +360,7 @@ void LTOModule::addDefinedSymbol(const GlobalValue *def, bool isFunction) {
|
|||||||
|
|
||||||
// string is owned by _defines
|
// string is owned by _defines
|
||||||
SmallString<64> Buffer;
|
SmallString<64> Buffer;
|
||||||
_mangler.getNameWithPrefix(Buffer, def, false);
|
_mangler.getNameWithPrefix(Buffer, def);
|
||||||
|
|
||||||
// set alignment part log2() can have rounding errors
|
// set alignment part log2() can have rounding errors
|
||||||
uint32_t align = def->getAlignment();
|
uint32_t align = def->getAlignment();
|
||||||
@@ -496,7 +496,7 @@ LTOModule::addPotentialUndefinedSymbol(const GlobalValue *decl, bool isFunc) {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
SmallString<64> name;
|
SmallString<64> name;
|
||||||
_mangler.getNameWithPrefix(name, decl, false);
|
_mangler.getNameWithPrefix(name, decl);
|
||||||
|
|
||||||
StringMap<NameAndAttributes>::value_type &entry =
|
StringMap<NameAndAttributes>::value_type &entry =
|
||||||
_undefines.GetOrCreateValue(name);
|
_undefines.GetOrCreateValue(name);
|
||||||
|
@@ -81,10 +81,9 @@ static void AddFastCallStdCallSuffix(SmallVectorImpl<char> &OutName,
|
|||||||
/// and the specified global variable's name. If the global variable doesn't
|
/// and the specified global variable's name. If the global variable doesn't
|
||||||
/// have a name, this fills in a unique name for the global.
|
/// have a name, this fills in a unique name for the global.
|
||||||
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
void Mangler::getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
||||||
const GlobalValue *GV,
|
const GlobalValue *GV) {
|
||||||
bool isImplicitlyPrivate) {
|
|
||||||
ManglerPrefixTy PrefixTy = Mangler::Default;
|
ManglerPrefixTy PrefixTy = Mangler::Default;
|
||||||
if (GV->hasPrivateLinkage() || isImplicitlyPrivate)
|
if (GV->hasPrivateLinkage())
|
||||||
PrefixTy = Mangler::Private;
|
PrefixTy = Mangler::Private;
|
||||||
else if (GV->hasLinkerPrivateLinkage() || GV->hasLinkerPrivateWeakLinkage())
|
else if (GV->hasLinkerPrivateLinkage() || GV->hasLinkerPrivateWeakLinkage())
|
||||||
PrefixTy = Mangler::LinkerPrivate;
|
PrefixTy = Mangler::LinkerPrivate;
|
||||||
|
@@ -51,7 +51,7 @@ static MCSymbol *GetSymbolFromOperand(const MachineOperand &MO, AsmPrinter &AP){
|
|||||||
AP.Mang->getNameWithPrefix(Name, MO.getSymbolName());
|
AP.Mang->getNameWithPrefix(Name, MO.getSymbolName());
|
||||||
} else {
|
} else {
|
||||||
const GlobalValue *GV = MO.getGlobal();
|
const GlobalValue *GV = MO.getGlobal();
|
||||||
AP.Mang->getNameWithPrefix(Name, GV, false);
|
AP.Mang->getNameWithPrefix(Name, GV);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned OrigLen = Name.size() - PrefixLen;
|
unsigned OrigLen = Name.size() - PrefixLen;
|
||||||
|
@@ -18,6 +18,7 @@
|
|||||||
#include "llvm/IR/DerivedTypes.h"
|
#include "llvm/IR/DerivedTypes.h"
|
||||||
#include "llvm/IR/Function.h"
|
#include "llvm/IR/Function.h"
|
||||||
#include "llvm/IR/GlobalVariable.h"
|
#include "llvm/IR/GlobalVariable.h"
|
||||||
|
#include "llvm/MC/MCAsmInfo.h"
|
||||||
#include "llvm/MC/MCContext.h"
|
#include "llvm/MC/MCContext.h"
|
||||||
#include "llvm/MC/MCExpr.h"
|
#include "llvm/MC/MCExpr.h"
|
||||||
#include "llvm/MC/MCStreamer.h"
|
#include "llvm/MC/MCStreamer.h"
|
||||||
@@ -102,14 +103,21 @@ static bool IsNullTerminatedString(const Constant *C) {
|
|||||||
MCSymbol *TargetLoweringObjectFile::getSymbol(Mangler &M,
|
MCSymbol *TargetLoweringObjectFile::getSymbol(Mangler &M,
|
||||||
const GlobalValue *GV) const {
|
const GlobalValue *GV) const {
|
||||||
SmallString<60> NameStr;
|
SmallString<60> NameStr;
|
||||||
M.getNameWithPrefix(NameStr, GV, false);
|
M.getNameWithPrefix(NameStr, GV);
|
||||||
return Ctx->GetOrCreateSymbol(NameStr.str());
|
return Ctx->GetOrCreateSymbol(NameStr.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
MCSymbol *TargetLoweringObjectFile::getSymbolWithGlobalValueBase(
|
MCSymbol *TargetLoweringObjectFile::getSymbolWithGlobalValueBase(
|
||||||
Mangler &M, const GlobalValue *GV, StringRef Suffix) const {
|
Mangler &M, const GlobalValue *GV, StringRef Suffix) const {
|
||||||
|
assert(!Suffix.empty());
|
||||||
|
assert(!GV->hasPrivateLinkage());
|
||||||
|
assert(!GV->hasLinkerPrivateLinkage());
|
||||||
|
assert(!GV->hasLinkerPrivateWeakLinkage());
|
||||||
|
|
||||||
|
const MCAsmInfo *MAI = Ctx->getAsmInfo();
|
||||||
SmallString<60> NameStr;
|
SmallString<60> NameStr;
|
||||||
M.getNameWithPrefix(NameStr, GV, true);
|
NameStr += MAI->getPrivateGlobalPrefix();
|
||||||
|
M.getNameWithPrefix(NameStr, GV);
|
||||||
NameStr.append(Suffix.begin(), Suffix.end());
|
NameStr.append(Suffix.begin(), Suffix.end());
|
||||||
return Ctx->GetOrCreateSymbol(NameStr.str());
|
return Ctx->GetOrCreateSymbol(NameStr.str());
|
||||||
}
|
}
|
||||||
|
@@ -97,7 +97,7 @@ GetSymbolFromOperand(const MachineOperand &MO) const {
|
|||||||
|
|
||||||
if (MO.isGlobal()) {
|
if (MO.isGlobal()) {
|
||||||
const GlobalValue *GV = MO.getGlobal();
|
const GlobalValue *GV = MO.getGlobal();
|
||||||
getMang()->getNameWithPrefix(Name, GV, false);
|
getMang()->getNameWithPrefix(Name, GV);
|
||||||
} else if (MO.isSymbol()) {
|
} else if (MO.isSymbol()) {
|
||||||
getMang()->getNameWithPrefix(Name, MO.getSymbolName());
|
getMang()->getNameWithPrefix(Name, MO.getSymbolName());
|
||||||
} else if (MO.isMBB()) {
|
} else if (MO.isMBB()) {
|
||||||
|
Reference in New Issue
Block a user