diff options
author | Chris Lattner <sabre@nondot.org> | 2009-08-15 06:09:35 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-08-15 06:09:35 +0000 |
commit | 0ac068471ca2f48e640e877a6e31a226c2978120 (patch) | |
tree | 28a6b2e488da05c592837b1f962f1de80a474731 /lib/Target/XCore | |
parent | 0a9ec09601eac8953e257e6c1d1d70f58d2d1998 (diff) | |
download | external_llvm-0ac068471ca2f48e640e877a6e31a226c2978120.zip external_llvm-0ac068471ca2f48e640e877a6e31a226c2978120.tar.gz external_llvm-0ac068471ca2f48e640e877a6e31a226c2978120.tar.bz2 |
use XCore-specific section with xcore specific cp/dp flags to restore
support for globals going into the appropriate sections with the flags.
This hopefully finishes unbreaking the previous behavior that I broke before.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79079 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/XCore')
-rw-r--r-- | lib/Target/XCore/XCoreTargetObjectFile.cpp | 40 |
1 files changed, 26 insertions, 14 deletions
diff --git a/lib/Target/XCore/XCoreTargetObjectFile.cpp b/lib/Target/XCore/XCoreTargetObjectFile.cpp index 9415f51..7676112 100644 --- a/lib/Target/XCore/XCoreTargetObjectFile.cpp +++ b/lib/Target/XCore/XCoreTargetObjectFile.cpp @@ -9,7 +9,7 @@ #include "XCoreTargetObjectFile.h" #include "XCoreSubtarget.h" -#include "llvm/MC/MCSectionELF.h" +#include "MCSectionXCore.h" #include "llvm/Target/TargetMachine.h" using namespace llvm; @@ -17,12 +17,22 @@ using namespace llvm; void XCoreTargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &TM){ TargetLoweringObjectFileELF::Initialize(Ctx, TM); - DataSection = getELFSection(".dp.data", MCSectionELF::SHT_PROGBITS, - MCSectionELF::SHF_ALLOC | MCSectionELF::SHF_WRITE, - SectionKind::getDataRel()); - BSSSection = getELFSection(".dp.bss", MCSectionELF::SHT_NOBITS, - MCSectionELF::SHF_ALLOC | MCSectionELF::SHF_WRITE, - SectionKind::getBSS()); + DataSection = + MCSectionXCore::Create(".dp.data", MCSectionELF::SHT_PROGBITS, + MCSectionELF::SHF_ALLOC | MCSectionELF::SHF_WRITE | + MCSectionXCore::SHF_DP_SECTION, + SectionKind::getDataRel(), false, getContext()); + BSSSection = + MCSectionXCore::Create(".dp.bss", MCSectionELF::SHT_NOBITS, + MCSectionELF::SHF_ALLOC | MCSectionELF::SHF_WRITE | + MCSectionXCore::SHF_DP_SECTION, + SectionKind::getBSS(), false, getContext()); + + // For now, disable lowering of mergable sections, just drop everything into + // ReadOnly. + MergeableConst4Section = 0; + MergeableConst8Section = 0; + MergeableConst16Section = 0; // TLS globals are lowered in the backend to arrays indexed by the current // thread id. After lowering they require no special handling by the linker @@ -31,13 +41,15 @@ void XCoreTargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &TM){ TLSBSSSection = BSSSection; if (TM.getSubtarget<XCoreSubtarget>().isXS1A()) - // FIXME: Why is this writable ("datarel")??? - ReadOnlySection = - getELFSection(".dp.rodata", MCSectionELF::SHT_PROGBITS, - MCSectionELF::SHF_ALLOC | MCSectionELF::SHF_WRITE, - SectionKind::getDataRel()); + ReadOnlySection = // FIXME: Why is this a writable section for XS1A? + MCSectionXCore::Create(".dp.rodata", MCSectionELF::SHT_PROGBITS, + MCSectionELF::SHF_ALLOC | MCSectionELF::SHF_WRITE | + MCSectionXCore::SHF_DP_SECTION, + SectionKind::getDataRel(), false, getContext()); else ReadOnlySection = - getELFSection(".cp.rodata", MCSectionELF::SHT_PROGBITS, - MCSectionELF::SHF_ALLOC, SectionKind::getReadOnly()); + MCSectionXCore::Create(".cp.rodata", MCSectionELF::SHT_PROGBITS, + MCSectionELF::SHF_ALLOC | + MCSectionXCore::SHF_CP_SECTION, + SectionKind::getReadOnly(), false, getContext()); } |