diff options
author | Chris Lattner <sabre@nondot.org> | 2009-08-02 00:34:36 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-08-02 00:34:36 +0000 |
commit | 80ec2792b2b271eca55743a3cc4c8bca214fa705 (patch) | |
tree | 6315c4827b431ed704a0a998ebe2ebb076a45d94 /lib/Target/TargetLoweringObjectFile.cpp | |
parent | f9f1adbcbbf2420c7acf13946c1877473d650294 (diff) |
convert ctors/dtors section to be in TLOF instead of
TAI.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77842 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/TargetLoweringObjectFile.cpp')
-rw-r--r-- | lib/Target/TargetLoweringObjectFile.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/Target/TargetLoweringObjectFile.cpp b/lib/Target/TargetLoweringObjectFile.cpp index 7c5eaf9dbf..a86946da9f 100644 --- a/lib/Target/TargetLoweringObjectFile.cpp +++ b/lib/Target/TargetLoweringObjectFile.cpp @@ -34,6 +34,8 @@ TargetLoweringObjectFile::TargetLoweringObjectFile() : Ctx(0) { DataSection = 0; BSSSection = 0; ReadOnlySection = 0; + StaticCtorSection = 0; + StaticDtorSection = 0; } TargetLoweringObjectFile::~TargetLoweringObjectFile() { @@ -295,6 +297,11 @@ void TargetLoweringObjectFileELF::Initialize(MCContext &Ctx, SectionKind::getMergeableConst8()); MergeableConst16Section = getOrCreateSection(".rodata.cst16", false, SectionKind::getMergeableConst16()); + + StaticCtorSection = + getOrCreateSection(".ctors", false, SectionKind::getDataRel()); + StaticDtorSection = + getOrCreateSection(".dtors", false, SectionKind::getDataRel()); } @@ -517,6 +524,19 @@ void TargetLoweringObjectFileMachO::Initialize(MCContext &Ctx, DataCoalSection = getOrCreateSection("\t__DATA,__datacoal_nt,coalesced", false, SectionKind::getDataRel()); + + if (TM.getRelocationModel() == Reloc::Static) { + StaticCtorSection = + getOrCreateSection(".constructor", true, SectionKind::getDataRel()); + StaticDtorSection = + getOrCreateSection(".destructor", true, SectionKind::getDataRel()); + } else { + StaticCtorSection = + getOrCreateSection(".mod_init_func", true, SectionKind::getDataRel()); + StaticDtorSection = + getOrCreateSection(".mod_term_func", true, SectionKind::getDataRel()); + } + } const MCSection *TargetLoweringObjectFileMachO:: @@ -624,6 +644,10 @@ void TargetLoweringObjectFileCOFF::Initialize(MCContext &Ctx, SectionKind::getText()); DataSection = getOrCreateSection("\t.data", true, SectionKind::getDataRel()); + StaticCtorSection = + getOrCreateSection(".ctors", false, SectionKind::getDataRel()); + StaticDtorSection = + getOrCreateSection(".dtors", false, SectionKind::getDataRel()); } void TargetLoweringObjectFileCOFF:: |