mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-27 14:34:58 +00:00
Add some section and constant support for darwin TLS.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103974 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
53c779bb3a
commit
423c9e3e58
@ -84,6 +84,19 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
class TargetLoweringObjectFileMachO : public TargetLoweringObjectFile {
|
class TargetLoweringObjectFileMachO : public TargetLoweringObjectFile {
|
||||||
|
/// TLSDataSection - Section directive for Thread Local data.
|
||||||
|
///
|
||||||
|
const MCSection *TLSDataSection; // Defaults to ".tdata".
|
||||||
|
|
||||||
|
/// TLSBSSSection - Section directive for Thread Local uninitialized data.
|
||||||
|
///
|
||||||
|
const MCSection *TLSBSSSection; // Defaults to ".tbss".
|
||||||
|
|
||||||
|
/// TLSTLVSection - Section directive for Thread Local structure infomation.
|
||||||
|
/// Contains the source code name of the variable, visibility and a pointer
|
||||||
|
/// to the initial value (.tdata or .tbss).
|
||||||
|
const MCSection *TLSTLVSection; // Defaults to ".tlv".
|
||||||
|
|
||||||
const MCSection *CStringSection;
|
const MCSection *CStringSection;
|
||||||
const MCSection *UStringSection;
|
const MCSection *UStringSection;
|
||||||
const MCSection *TextCoalSection;
|
const MCSection *TextCoalSection;
|
||||||
|
@ -87,8 +87,20 @@ public:
|
|||||||
/// S_LAZY_DYLIB_SYMBOL_POINTERS - Section with lazy symbol pointers to
|
/// S_LAZY_DYLIB_SYMBOL_POINTERS - Section with lazy symbol pointers to
|
||||||
/// lazy loaded dylibs.
|
/// lazy loaded dylibs.
|
||||||
S_LAZY_DYLIB_SYMBOL_POINTERS = 0x10U,
|
S_LAZY_DYLIB_SYMBOL_POINTERS = 0x10U,
|
||||||
|
/// S_THREAD_LOCAL_REGULAR - Section with ....
|
||||||
|
S_THREAD_LOCAL_REGULAR = 0x11U,
|
||||||
|
/// S_THREAD_LOCAL_ZEROFILL - Thread local zerofill section.
|
||||||
|
S_THREAD_LOCAL_ZEROFILL = 0x12U,
|
||||||
|
/// S_THREAD_LOCAL_VARIABLES - Section with thread local variable structure
|
||||||
|
/// data.
|
||||||
|
S_THREAD_LOCAL_VARIABLES = 0x13U,
|
||||||
|
/// S_THREAD_LOCAL_VARIABLE_POINTERS - Section with ....
|
||||||
|
S_THREAD_LOCAL_VARIABLE_POINTERS = 0x14U,
|
||||||
|
/// S_THREAD_LOCAL_INIT_FUNCTION_POINTERS - Section with thread local
|
||||||
|
/// variable initialization pointers to functions.
|
||||||
|
S_THREAD_LOCAL_INIT_FUNCTION_POINTERS = 0x15,
|
||||||
|
|
||||||
LAST_KNOWN_SECTION_TYPE = S_LAZY_DYLIB_SYMBOL_POINTERS,
|
LAST_KNOWN_SECTION_TYPE = S_THREAD_LOCAL_INIT_FUNCTION_POINTERS,
|
||||||
|
|
||||||
|
|
||||||
// Valid section attributes.
|
// Valid section attributes.
|
||||||
|
@ -461,6 +461,20 @@ void TargetLoweringObjectFileMachO::Initialize(MCContext &Ctx,
|
|||||||
= getContext().getMachOSection("__DATA", "__data", 0,
|
= getContext().getMachOSection("__DATA", "__data", 0,
|
||||||
SectionKind::getDataRel());
|
SectionKind::getDataRel());
|
||||||
|
|
||||||
|
TLSDataSection // .tdata
|
||||||
|
= getContext().getMachOSection("__DATA", "__thread_data",
|
||||||
|
MCSectionMachO::S_THREAD_LOCAL_REGULAR,
|
||||||
|
SectionKind::getDataRel());
|
||||||
|
TLSBSSSection // .tbss
|
||||||
|
= getContext().getMachOSection("__DATA", "__thread_bss",
|
||||||
|
MCSectionMachO::S_THREAD_LOCAL_ZEROFILL,
|
||||||
|
SectionKind::getThreadBSS());
|
||||||
|
|
||||||
|
// TODO: Verify datarel below.
|
||||||
|
TLSTLVSection // .tlv
|
||||||
|
= getContext().getMachOSection("__DATA", "__thread_vars",
|
||||||
|
MCSectionMachO::S_THREAD_LOCAL_VARIABLES,
|
||||||
|
SectionKind::getDataRel());
|
||||||
CStringSection // .cstring
|
CStringSection // .cstring
|
||||||
= getContext().getMachOSection("__TEXT", "__cstring",
|
= getContext().getMachOSection("__TEXT", "__cstring",
|
||||||
MCSectionMachO::S_CSTRING_LITERALS,
|
MCSectionMachO::S_CSTRING_LITERALS,
|
||||||
@ -646,7 +660,7 @@ getExplicitSectionGlobal(const GlobalValue *GV, SectionKind Kind,
|
|||||||
|
|
||||||
const MCSection *TargetLoweringObjectFileMachO::
|
const MCSection *TargetLoweringObjectFileMachO::
|
||||||
SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind,
|
SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind,
|
||||||
Mangler *Mang, const TargetMachine &TM) const {
|
Mangler *Mang, const TargetMachine &TM) const {
|
||||||
assert(!Kind.isThreadLocal() && "Darwin doesn't support TLS");
|
assert(!Kind.isThreadLocal() && "Darwin doesn't support TLS");
|
||||||
|
|
||||||
if (Kind.isText())
|
if (Kind.isText())
|
||||||
|
@ -34,7 +34,14 @@ static const struct {
|
|||||||
{ "interposing", "S_INTERPOSING" }, // 0x0D
|
{ "interposing", "S_INTERPOSING" }, // 0x0D
|
||||||
{ "16byte_literals", "S_16BYTE_LITERALS" }, // 0x0E
|
{ "16byte_literals", "S_16BYTE_LITERALS" }, // 0x0E
|
||||||
{ 0, /*FIXME??*/ "S_DTRACE_DOF" }, // 0x0F
|
{ 0, /*FIXME??*/ "S_DTRACE_DOF" }, // 0x0F
|
||||||
{ 0, /*FIXME??*/ "S_LAZY_DYLIB_SYMBOL_POINTERS" } // 0x10
|
{ 0, /*FIXME??*/ "S_LAZY_DYLIB_SYMBOL_POINTERS" }, // 0x10
|
||||||
|
{ "thread_local_regular", "S_THREAD_LOCAL_REGULAR" }, // 0x11
|
||||||
|
{ "thread_bss", "S_THREAD_LOCAL_ZEROFILL" }, // 0x12
|
||||||
|
{ "thread_local_variables", "S_THREAD_LOCAL_VARIABLES" }, // 0x13
|
||||||
|
{ "thread_local_variable_pointers",
|
||||||
|
"S_THREAD_LOCAL_VARIABLE_POINTERS" }, // 0x14
|
||||||
|
{ "thread_local_init_function_pointers",
|
||||||
|
"S_THREAD_LOCAL_INIT_FUNCTION_POINTERS"}, // 0x15
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -222,7 +222,8 @@ public:
|
|||||||
bool isVirtualSection(const MCSection &Section) const {
|
bool isVirtualSection(const MCSection &Section) const {
|
||||||
const MCSectionMachO &SMO = static_cast<const MCSectionMachO&>(Section);
|
const MCSectionMachO &SMO = static_cast<const MCSectionMachO&>(Section);
|
||||||
return (SMO.getType() == MCSectionMachO::S_ZEROFILL ||
|
return (SMO.getType() == MCSectionMachO::S_ZEROFILL ||
|
||||||
SMO.getType() == MCSectionMachO::S_GB_ZEROFILL);
|
SMO.getType() == MCSectionMachO::S_GB_ZEROFILL ||
|
||||||
|
SMO.getType() == MCSectionMachO::S_THREAD_LOCAL_ZEROFILL);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user