diff options
Diffstat (limited to 'lib/MC')
| -rw-r--r-- | lib/MC/ELFObjectWriter.cpp | 10 | ||||
| -rw-r--r-- | lib/MC/MCAsmInfoDarwin.cpp | 17 | ||||
| -rw-r--r-- | lib/MC/MCAssembler.cpp | 16 | ||||
| -rw-r--r-- | lib/MC/MachObjectWriter.cpp | 41 | ||||
| -rw-r--r-- | lib/MC/WinCOFFObjectWriter.cpp | 12 | 
5 files changed, 46 insertions, 50 deletions
| diff --git a/lib/MC/ELFObjectWriter.cpp b/lib/MC/ELFObjectWriter.cpp index 4dcf910e01a72..e2439abaf001a 100644 --- a/lib/MC/ELFObjectWriter.cpp +++ b/lib/MC/ELFObjectWriter.cpp @@ -219,7 +219,7 @@ class ELFObjectWriter : public MCObjectWriter {                                    const MCSymbolData *SD, uint64_t C,                                    unsigned Type) const; -    void RecordRelocation(MCAssembler &Asm, const MCAsmLayout &Layout, +    void RecordRelocation(const MCAssembler &Asm, const MCAsmLayout &Layout,                            const MCFragment *Fragment, const MCFixup &Fixup,                            MCValue Target, bool &IsPCRel,                            uint64_t &FixedValue) override; @@ -789,11 +789,13 @@ static const MCSymbol *getWeakRef(const MCSymbolRefExpr &Ref) {    return nullptr;  } -void ELFObjectWriter::RecordRelocation(MCAssembler &Asm, +void ELFObjectWriter::RecordRelocation(const MCAssembler &Asm,                                         const MCAsmLayout &Layout,                                         const MCFragment *Fragment, -                                       const MCFixup &Fixup, MCValue Target, -                                       bool &IsPCRel, uint64_t &FixedValue) { +                                       const MCFixup &Fixup, +                                       MCValue Target, +                                       bool &IsPCRel, +                                       uint64_t &FixedValue) {    const MCSectionData *FixupSection = Fragment->getParent();    uint64_t C = Target.getConstant();    uint64_t FixupOffset = Layout.getFragmentOffset(Fragment) + Fixup.getOffset(); diff --git a/lib/MC/MCAsmInfoDarwin.cpp b/lib/MC/MCAsmInfoDarwin.cpp index f7054902f24c2..04cc0ff4a864c 100644 --- a/lib/MC/MCAsmInfoDarwin.cpp +++ b/lib/MC/MCAsmInfoDarwin.cpp @@ -27,7 +27,22 @@ bool MCAsmInfoDarwin::isSectionAtomizableBySymbols(    // contain.    // Sections holding 2 byte strings require symbols in order to be atomized.    // There is no dedicated section for 4 byte strings. -  if (SMO.getType() == MachO::S_CSTRING_LITERALS) +  if (SMO.getKind().isMergeable1ByteCString()) +    return false; + +  if (SMO.getSegmentName() == "__TEXT" && +      SMO.getSectionName() == "__objc_classname" && +      SMO.getType() == MachO::S_CSTRING_LITERALS) +    return false; + +  if (SMO.getSegmentName() == "__TEXT" && +      SMO.getSectionName() == "__objc_methname" && +      SMO.getType() == MachO::S_CSTRING_LITERALS) +    return false; + +  if (SMO.getSegmentName() == "__TEXT" && +      SMO.getSectionName() == "__objc_methtype" && +      SMO.getType() == MachO::S_CSTRING_LITERALS)      return false;    if (SMO.getSegmentName() == "__DATA" && SMO.getSectionName() == "__cfstring") diff --git a/lib/MC/MCAssembler.cpp b/lib/MC/MCAssembler.cpp index 45d49fae94bf3..e3c2443f4a215 100644 --- a/lib/MC/MCAssembler.cpp +++ b/lib/MC/MCAssembler.cpp @@ -425,16 +425,6 @@ bool MCAssembler::isThumbFunc(const MCSymbol *Symbol) const {    return true;  } -void MCAssembler::addLocalUsedInReloc(const MCSymbol &Sym) { -  assert(Sym.isTemporary()); -  LocalsUsedInReloc.insert(&Sym); -} - -bool MCAssembler::isLocalUsedInReloc(const MCSymbol &Sym) const { -  assert(Sym.isTemporary()); -  return LocalsUsedInReloc.count(&Sym); -} -  bool MCAssembler::isSymbolLinkerVisible(const MCSymbol &Symbol) const {    // Non-temporary labels should always be visible to the linker.    if (!Symbol.isTemporary()) @@ -444,10 +434,8 @@ bool MCAssembler::isSymbolLinkerVisible(const MCSymbol &Symbol) const {    if (!Symbol.isInSection())      return false; -  if (isLocalUsedInReloc(Symbol)) -    return true; - -  return false; +  // Otherwise, check if the section requires symbols even for temporary labels. +  return getBackend().doesSectionRequireSymbols(Symbol.getSection());  }  const MCSymbolData *MCAssembler::getAtom(const MCSymbolData *SD) const { diff --git a/lib/MC/MachObjectWriter.cpp b/lib/MC/MachObjectWriter.cpp index 588d424120c44..d3751bd9ba57b 100644 --- a/lib/MC/MachObjectWriter.cpp +++ b/lib/MC/MachObjectWriter.cpp @@ -448,11 +448,14 @@ void MachObjectWriter::WriteLinkerOptionsLoadCommand(    assert(OS.tell() - Start == Size);  } -void MachObjectWriter::RecordRelocation(MCAssembler &Asm, + +void MachObjectWriter::RecordRelocation(const MCAssembler &Asm,                                          const MCAsmLayout &Layout,                                          const MCFragment *Fragment, -                                        const MCFixup &Fixup, MCValue Target, -                                        bool &IsPCRel, uint64_t &FixedValue) { +                                        const MCFixup &Fixup, +                                        MCValue Target, +                                        bool &IsPCRel, +                                        uint64_t &FixedValue) {    TargetObjectWriter->RecordRelocation(this, Asm, Layout, Fragment, Fixup,                                         Target, FixedValue);  } @@ -613,22 +616,6 @@ void MachObjectWriter::ComputeSymbolTable(      ExternalSymbolData[i].SymbolData->setIndex(Index++);    for (unsigned i = 0, e = UndefinedSymbolData.size(); i != e; ++i)      UndefinedSymbolData[i].SymbolData->setIndex(Index++); - -  for (const MCSectionData &SD : Asm) { -    std::vector<RelAndSymbol> &Relocs = Relocations[&SD]; -    for (RelAndSymbol &Rel : Relocs) { -      if (!Rel.Sym) -        continue; - -      // Set the Index and the IsExtern bit. -      unsigned Index = Rel.Sym->getIndex(); -      assert(isInt<24>(Index)); -      if (IsLittleEndian) -        Rel.MRE.r_word1 = (Rel.MRE.r_word1 & (-1 << 24)) | Index | (1 << 27); -      else -        Rel.MRE.r_word1 = (Rel.MRE.r_word1 & 0xff) | Index << 8 | (1 << 4); -    } -  }  }  void MachObjectWriter::computeSectionAddresses(const MCAssembler &Asm, @@ -675,6 +662,10 @@ void MachObjectWriter::ExecutePostLayoutBinding(MCAssembler &Asm,    // Mark symbol difference expressions in variables (from .set or = directives)    // as absolute.    markAbsoluteVariableSymbols(Asm, Layout); + +  // Compute symbol table information and bind symbol indices. +  ComputeSymbolTable(Asm, LocalSymbolData, ExternalSymbolData, +                     UndefinedSymbolData);  }  bool MachObjectWriter:: @@ -758,10 +749,6 @@ IsSymbolRefDifferenceFullyResolvedImpl(const MCAssembler &Asm,  void MachObjectWriter::WriteObject(MCAssembler &Asm,                                     const MCAsmLayout &Layout) { -  // Compute symbol table information and bind symbol indices. -  ComputeSymbolTable(Asm, LocalSymbolData, ExternalSymbolData, -                     UndefinedSymbolData); -    unsigned NumSections = Asm.size();    const MCAssembler::VersionMinInfoType &VersionInfo =      Layout.getAssembler().getVersionMinInfo(); @@ -852,7 +839,7 @@ void MachObjectWriter::WriteObject(MCAssembler &Asm,    uint64_t RelocTableEnd = SectionDataStart + SectionDataFileSize;    for (MCAssembler::const_iterator it = Asm.begin(),           ie = Asm.end(); it != ie; ++it) { -    std::vector<RelAndSymbol> &Relocs = Relocations[it]; +    std::vector<MachO::any_relocation_info> &Relocs = Relocations[it];      unsigned NumRelocs = Relocs.size();      uint64_t SectionStart = SectionDataStart + getSectionAddress(it);      WriteSection(Asm, Layout, *it, SectionStart, RelocTableEnd, NumRelocs); @@ -946,10 +933,10 @@ void MachObjectWriter::WriteObject(MCAssembler &Asm,           ie = Asm.end(); it != ie; ++it) {      // Write the section relocation entries, in reverse order to match 'as'      // (approximately, the exact algorithm is more complicated than this). -    std::vector<RelAndSymbol> &Relocs = Relocations[it]; +    std::vector<MachO::any_relocation_info> &Relocs = Relocations[it];      for (unsigned i = 0, e = Relocs.size(); i != e; ++i) { -      Write32(Relocs[e - i - 1].MRE.r_word0); -      Write32(Relocs[e - i - 1].MRE.r_word1); +      Write32(Relocs[e - i - 1].r_word0); +      Write32(Relocs[e - i - 1].r_word1);      }    } diff --git a/lib/MC/WinCOFFObjectWriter.cpp b/lib/MC/WinCOFFObjectWriter.cpp index d8729bdbc4bbd..c17f99b9bd7b4 100644 --- a/lib/MC/WinCOFFObjectWriter.cpp +++ b/lib/MC/WinCOFFObjectWriter.cpp @@ -175,7 +175,7 @@ public:                                                const MCFragment &FB, bool InSet,                                                bool IsPCRel) const override; -  void RecordRelocation(MCAssembler &Asm, const MCAsmLayout &Layout, +  void RecordRelocation(const MCAssembler &Asm, const MCAsmLayout &Layout,                          const MCFragment *Fragment, const MCFixup &Fixup,                          MCValue Target, bool &IsPCRel,                          uint64_t &FixedValue) override; @@ -661,9 +661,13 @@ bool WinCOFFObjectWriter::IsSymbolRefDifferenceFullyResolvedImpl(                                                                  InSet, IsPCRel);  } -void WinCOFFObjectWriter::RecordRelocation( -    MCAssembler &Asm, const MCAsmLayout &Layout, const MCFragment *Fragment, -    const MCFixup &Fixup, MCValue Target, bool &IsPCRel, uint64_t &FixedValue) { +void WinCOFFObjectWriter::RecordRelocation(const MCAssembler &Asm, +                                           const MCAsmLayout &Layout, +                                           const MCFragment *Fragment, +                                           const MCFixup &Fixup, +                                           MCValue Target, +                                           bool &IsPCRel, +                                           uint64_t &FixedValue) {    assert(Target.getSymA() && "Relocation must reference a symbol!");    const MCSymbol &Symbol = Target.getSymA()->getSymbol(); | 
