diff options
author | Chris Lattner <sabre@nondot.org> | 2009-08-08 23:39:42 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-08-08 23:39:42 +0000 |
commit | 93b6db3de934a3cfca5586df25184fef4a54c500 (patch) | |
tree | 3c32466a689b69726787f2b72bcdaf6a3879df50 /lib/MC/MCSection.cpp | |
parent | 8e9ece75db5045ec057efbbdba6550fa0d85e695 (diff) |
sink the 'name' and 'isdirective' state out of MCSection into its derived classes.
This totally optimizes PIC16 sections by not having an 'isdirective' bit anymore!! ;-)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78517 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/MC/MCSection.cpp')
-rw-r--r-- | lib/MC/MCSection.cpp | 27 |
1 files changed, 20 insertions, 7 deletions
diff --git a/lib/MC/MCSection.cpp b/lib/MC/MCSection.cpp index a1f5664859..80a80e7d8d 100644 --- a/lib/MC/MCSection.cpp +++ b/lib/MC/MCSection.cpp @@ -20,13 +20,6 @@ using namespace llvm; MCSection::~MCSection() { } -MCSection::MCSection(const StringRef &N, bool isDirective, SectionKind K, - MCContext &Ctx) - : Name(N), IsDirective(isDirective), Kind(K) { - MCSection *&Entry = Ctx.Sections[Name]; - assert(Entry == 0 && "Multiple sections with the same name created"); - Entry = this; -} //===----------------------------------------------------------------------===// // MCSectionELF @@ -37,6 +30,13 @@ Create(const StringRef &Name, bool IsDirective, SectionKind K, MCContext &Ctx) { return new (Ctx) MCSectionELF(Name, IsDirective, K, Ctx); } +MCSectionELF::MCSectionELF(const StringRef &name, bool isDirective, + SectionKind K, MCContext &Ctx) + : MCSection(K), Name(name), IsDirective(isDirective) { + Ctx.SetSection(Name, this); +} + + void MCSectionELF::PrintSwitchToSection(const TargetAsmInfo &TAI, raw_ostream &OS) const { if (isDirective()) { @@ -118,6 +118,12 @@ Create(const StringRef &Name, bool IsDirective, SectionKind K, MCContext &Ctx) { return new (Ctx) MCSectionMachO(Name, IsDirective, K, Ctx); } +MCSectionMachO::MCSectionMachO(const StringRef &name, bool isDirective, + SectionKind K, MCContext &Ctx) + : MCSection(K), Name(name), IsDirective(isDirective) { + Ctx.SetSection(Name, this); +} + void MCSectionMachO::PrintSwitchToSection(const TargetAsmInfo &TAI, raw_ostream &OS) const { if (!isDirective()) @@ -135,6 +141,13 @@ Create(const StringRef &Name, bool IsDirective, SectionKind K, MCContext &Ctx) { return new (Ctx) MCSectionCOFF(Name, IsDirective, K, Ctx); } +MCSectionCOFF::MCSectionCOFF(const StringRef &name, bool isDirective, + SectionKind K, MCContext &Ctx) + : MCSection(K), Name(name), IsDirective(isDirective) { + Ctx.SetSection(Name, this); +} + + void MCSectionCOFF::PrintSwitchToSection(const TargetAsmInfo &TAI, raw_ostream &OS) const { |