class MCFragment;
class MCObjectWriter;
class MCSection;
-class MCSectionData;
class MCSubtargetInfo;
class MCValue;
class MCAsmBackend;
/// \name Backend Data Access
/// @{
- MCSectionData &getOrCreateSectionData(MCSection &Section,
- bool *Created = nullptr) {
- bool C = Sections.insert(&Section);
- if (Created)
- *Created = C;
- return Section.getSectionData();
- }
+ bool registerSection(MCSection &Section) { return Sections.insert(&Section); }
bool hasSymbolData(const MCSymbol &Symbol) const { return Symbol.hasData(); }
unsigned ByteAlignment = i->ByteAlignment;
MCSection &Section = Symbol.getSection();
- MCSectionData &SectData = getAssembler().getOrCreateSectionData(Section);
- new MCAlignFragment(ByteAlignment, 0, 1, ByteAlignment,
- &SectData.getSection());
+ getAssembler().registerSection(Section);
+ new MCAlignFragment(ByteAlignment, 0, 1, ByteAlignment, &Section);
- MCFragment *F = new MCFillFragment(0, 0, Size, &SectData.getSection());
+ MCFragment *F = new MCFillFragment(0, 0, Size, &Section);
Symbol.getData().setFragment(F);
// Update the maximum alignment of the section if necessary.
void MCMachOStreamer::EmitZerofill(MCSection *Section, MCSymbol *Symbol,
uint64_t Size, unsigned ByteAlignment) {
- MCSectionData &SectData = getAssembler().getOrCreateSectionData(*Section);
+ getAssembler().registerSection(*Section);
// The symbol may not be present, which only creates the section.
if (!Symbol)
// Emit an align fragment if necessary.
if (ByteAlignment != 1)
- new MCAlignFragment(ByteAlignment, 0, 0, ByteAlignment,
- &SectData.getSection());
+ new MCAlignFragment(ByteAlignment, 0, 0, ByteAlignment, Section);
- MCFragment *F = new MCFillFragment(0, 0, Size, &SectData.getSection());
+ MCFragment *F = new MCFillFragment(0, 0, Size, Section);
SD.setFragment(F);
AssignSection(Symbol, Section);
assert(Section && "Cannot switch to a null section!");
flushPendingLabels(nullptr);
- bool Created;
- getAssembler().getOrCreateSectionData(*Section, &Created);
+ bool Created = getAssembler().registerSection(*Section);
CurSectionData = Section;
int64_t IntSubsection = 0;
assert(!Symbol->isInSection() && "Symbol must not already have a section!");
MCSection *Section = getContext().getObjectFileInfo()->getBSSSection();
- MCSectionData &SectionData = getAssembler().getOrCreateSectionData(*Section);
+ getAssembler().registerSection(*Section);
if (Section->getAlignment() < ByteAlignment)
Section->setAlignment(ByteAlignment);
if (ByteAlignment != 1)
new MCAlignFragment(ByteAlignment, /*Value=*/0, /*ValueSize=*/0,
- ByteAlignment, &SectionData.getSection());
+ ByteAlignment, Section);
MCFillFragment *Fragment = new MCFillFragment(
- /*Value=*/0, /*ValueSize=*/0, Size, &SectionData.getSection());
+ /*Value=*/0, /*ValueSize=*/0, Size, Section);
SD.setFragment(Fragment);
}
MCSectionELF *Sec =
Context.getELFSection(".MIPS.options", ELF::SHT_MIPS_OPTIONS,
ELF::SHF_ALLOC | ELF::SHF_MIPS_NOSTRIP, 1, "");
- MCA.getOrCreateSectionData(*Sec);
+ MCA.registerSection(*Sec);
Sec->setAlignment(8);
Streamer->SwitchSection(Sec);
} else {
MCSectionELF *Sec = Context.getELFSection(".reginfo", ELF::SHT_MIPS_REGINFO,
ELF::SHF_ALLOC, 24, "");
- MCA.getOrCreateSectionData(*Sec);
+ MCA.registerSection(*Sec);
Sec->setAlignment(MTS->getABI().IsN32() ? 8 : 4);
Streamer->SwitchSection(Sec);
// .bss, .text and .data are always at least 16-byte aligned.
MCSection &TextSection = *OFI.getTextSection();
- MCA.getOrCreateSectionData(TextSection);
+ MCA.registerSection(TextSection);
MCSection &DataSection = *OFI.getDataSection();
- MCA.getOrCreateSectionData(DataSection);
+ MCA.registerSection(DataSection);
MCSection &BSSSection = *OFI.getBSSSection();
- MCA.getOrCreateSectionData(BSSSection);
+ MCA.registerSection(BSSSection);
TextSection.setAlignment(std::max(16u, TextSection.getAlignment()));
DataSection.setAlignment(std::max(16u, DataSection.getAlignment()));
const MCSymbolRefExpr *ExprRef =
MCSymbolRefExpr::Create(Name, MCSymbolRefExpr::VK_None, Context);
- MCA.getOrCreateSectionData(*Sec);
+ MCA.registerSection(*Sec);
Sec->setAlignment(4);
OS.PushSection();
MCStreamer &OS = getStreamer();
MCSectionELF *Sec = Context.getELFSection(
".MIPS.abiflags", ELF::SHT_MIPS_ABIFLAGS, ELF::SHF_ALLOC, 24, "");
- MCA.getOrCreateSectionData(*Sec);
+ MCA.registerSection(*Sec);
Sec->setAlignment(8);
OS.SwitchSection(Sec);