mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Revert r225048: It broke ObjC on AArch64.
I've filed http://llvm.org/PR22100 to track this issue. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@225228 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -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); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user