//===- lib/ReaderWriter/ELF/AArch64/AArch64ExecutableWriter.cpp -------------===// // // The LLVM Linker // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "AArch64LinkingContext.h" #include "AArch64ExecutableWriter.h" #include "AArch64TargetHandler.h" #include "AArch64SectionChunks.h" namespace lld { namespace elf { AArch64ExecutableWriter::AArch64ExecutableWriter(AArch64LinkingContext &ctx, AArch64TargetLayout &layout) : ExecutableWriter(ctx, layout), _targetLayout(layout) {} void AArch64ExecutableWriter::createImplicitFiles( std::vector> &result) { ExecutableWriter::createImplicitFiles(result); auto gotFile = llvm::make_unique("GOTFile"); gotFile->addAtom(*new (gotFile->allocator()) GlobalOffsetTableAtom(*gotFile)); if (this->_ctx.isDynamic()) gotFile->addAtom(*new (gotFile->allocator()) DynamicAtom(*gotFile)); result.push_back(std::move(gotFile)); } void AArch64ExecutableWriter::buildDynamicSymbolTable(const File &file) { for (auto sec : this->_layout.sections()) { if (auto section = dyn_cast>(sec)) { for (const auto &atom : section->atoms()) { // Add all globals GOT symbols (in both .got and .got.plt sections) // on dynamic symbol table. for (const auto §ion : _targetLayout.getGOTSections()) { if (section->hasGlobalGOTEntry(atom->_atom)) _dynamicSymbolTable->addSymbol(atom->_atom, section->ordinal(), atom->_virtualAddr, atom); } } } } ExecutableWriter::buildDynamicSymbolTable(file); } } // namespace elf } // namespace lld