1 //===- Writer.cpp ---------------------------------------------------------===// 2 // 3 // The LLVM Linker 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 #include "Writer.h" 11 #include "Config.h" 12 #include "OutputSections.h" 13 #include "SymbolTable.h" 14 #include "Target.h" 15 16 #include "llvm/ADT/StringMap.h" 17 #include "llvm/ADT/StringSwitch.h" 18 #include "llvm/Support/FileOutputBuffer.h" 19 #include "llvm/Support/raw_ostream.h" 20 #include "llvm/Support/StringSaver.h" 21 22 using namespace llvm; 23 using namespace llvm::ELF; 24 using namespace llvm::object; 25 26 using namespace lld; 27 using namespace lld::elf2; 28 29 namespace { 30 // The writer writes a SymbolTable result to a file. 31 template <class ELFT> class Writer { 32 public: 33 typedef typename ELFFile<ELFT>::uintX_t uintX_t; 34 typedef typename ELFFile<ELFT>::Elf_Shdr Elf_Shdr; 35 typedef typename ELFFile<ELFT>::Elf_Ehdr Elf_Ehdr; 36 typedef typename ELFFile<ELFT>::Elf_Phdr Elf_Phdr; 37 typedef typename ELFFile<ELFT>::Elf_Sym Elf_Sym; 38 typedef typename ELFFile<ELFT>::Elf_Sym_Range Elf_Sym_Range; 39 typedef typename ELFFile<ELFT>::Elf_Rela Elf_Rela; 40 Writer(SymbolTable<ELFT> &S) : Symtab(S) {} 41 void run(); 42 43 private: 44 void copyLocalSymbols(); 45 void addReservedSymbols(); 46 void createSections(); 47 void addPredefinedSections(); 48 49 template <bool isRela> 50 void scanRelocs(InputSectionBase<ELFT> &C, 51 iterator_range<const Elf_Rel_Impl<ELFT, isRela> *> Rels); 52 53 void scanRelocs(InputSection<ELFT> &C); 54 void scanRelocs(InputSectionBase<ELFT> &S, const Elf_Shdr &RelSec); 55 void updateRelro(Elf_Phdr *Cur, Elf_Phdr *GnuRelroPhdr, uintX_t VA); 56 void assignAddresses(); 57 void buildSectionMap(); 58 void fixAbsoluteSymbols(); 59 void openFile(StringRef OutputPath); 60 void writeHeader(); 61 void writeSections(); 62 bool isDiscarded(InputSectionBase<ELFT> *IS) const; 63 StringRef getOutputSectionName(StringRef S) const; 64 bool needsInterpSection() const { 65 return !Symtab.getSharedFiles().empty() && !Config->DynamicLinker.empty(); 66 } 67 bool isOutputDynamic() const { 68 return !Symtab.getSharedFiles().empty() || Config->Shared; 69 } 70 int getPhdrsNum() const; 71 72 OutputSection<ELFT> *getBss(); 73 void addCommonSymbols(std::vector<DefinedCommon *> &Syms); 74 void addCopyRelSymbols(std::vector<SharedSymbol<ELFT> *> &Syms); 75 76 std::unique_ptr<llvm::FileOutputBuffer> Buffer; 77 78 BumpPtrAllocator Alloc; 79 std::vector<OutputSectionBase<ELFT> *> OutputSections; 80 std::vector<std::unique_ptr<OutputSectionBase<ELFT>>> OwningSections; 81 unsigned getNumSections() const { return OutputSections.size() + 1; } 82 83 void addRelIpltSymbols(); 84 void addStartEndSymbols(); 85 void addStartStopSymbols(OutputSectionBase<ELFT> *Sec); 86 void setPhdr(Elf_Phdr *PH, uint32_t Type, uint32_t Flags, uintX_t FileOff, 87 uintX_t VA, uintX_t Size, uintX_t Align); 88 void copyPhdr(Elf_Phdr *PH, OutputSectionBase<ELFT> *From); 89 90 bool HasRelro = false; 91 SymbolTable<ELFT> &Symtab; 92 std::vector<Elf_Phdr> Phdrs; 93 94 uintX_t FileSize; 95 uintX_t SectionHeaderOff; 96 97 llvm::StringMap<llvm::StringRef> InputToOutputSection; 98 99 // Flag to force GOT to be in output if we have relocations 100 // that relies on its address. 101 bool HasGotOffRel = false; 102 }; 103 } // anonymous namespace 104 105 template <class ELFT> static bool shouldUseRela() { return ELFT::Is64Bits; } 106 107 template <class ELFT> void elf2::writeResult(SymbolTable<ELFT> *Symtab) { 108 // Initialize output sections that are handled by Writer specially. 109 // Don't reorder because the order of initialization matters. 110 InterpSection<ELFT> Interp; 111 Out<ELFT>::Interp = &Interp; 112 StringTableSection<ELFT> ShStrTab(".shstrtab", false); 113 Out<ELFT>::ShStrTab = &ShStrTab; 114 StringTableSection<ELFT> StrTab(".strtab", false); 115 if (!Config->StripAll) 116 Out<ELFT>::StrTab = &StrTab; 117 StringTableSection<ELFT> DynStrTab(".dynstr", true); 118 Out<ELFT>::DynStrTab = &DynStrTab; 119 GotSection<ELFT> Got; 120 Out<ELFT>::Got = &Got; 121 GotPltSection<ELFT> GotPlt; 122 if (Target->supportsLazyRelocations()) 123 Out<ELFT>::GotPlt = &GotPlt; 124 PltSection<ELFT> Plt; 125 Out<ELFT>::Plt = &Plt; 126 std::unique_ptr<SymbolTableSection<ELFT>> SymTab; 127 if (!Config->StripAll) { 128 SymTab.reset(new SymbolTableSection<ELFT>(*Symtab, *Out<ELFT>::StrTab)); 129 Out<ELFT>::SymTab = SymTab.get(); 130 } 131 SymbolTableSection<ELFT> DynSymTab(*Symtab, *Out<ELFT>::DynStrTab); 132 Out<ELFT>::DynSymTab = &DynSymTab; 133 HashTableSection<ELFT> HashTab; 134 if (Config->SysvHash) 135 Out<ELFT>::HashTab = &HashTab; 136 GnuHashTableSection<ELFT> GnuHashTab; 137 if (Config->GnuHash) 138 Out<ELFT>::GnuHashTab = &GnuHashTab; 139 bool IsRela = shouldUseRela<ELFT>(); 140 RelocationSection<ELFT> RelaDyn(IsRela ? ".rela.dyn" : ".rel.dyn", IsRela); 141 Out<ELFT>::RelaDyn = &RelaDyn; 142 RelocationSection<ELFT> RelaPlt(IsRela ? ".rela.plt" : ".rel.plt", IsRela); 143 if (Target->supportsLazyRelocations()) 144 Out<ELFT>::RelaPlt = &RelaPlt; 145 DynamicSection<ELFT> Dynamic(*Symtab); 146 Out<ELFT>::Dynamic = &Dynamic; 147 EhFrameHeader<ELFT> EhFrameHdr; 148 Out<ELFT>::EhFrameHdr = &EhFrameHdr; 149 150 Writer<ELFT>(*Symtab).run(); 151 } 152 153 // The main function of the writer. 154 template <class ELFT> void Writer<ELFT>::run() { 155 buildSectionMap(); 156 if (!Config->DiscardAll) 157 copyLocalSymbols(); 158 addReservedSymbols(); 159 createSections(); 160 assignAddresses(); 161 fixAbsoluteSymbols(); 162 openFile(Config->OutputFile); 163 writeHeader(); 164 writeSections(); 165 error(Buffer->commit()); 166 } 167 168 namespace { 169 template <bool Is64Bits> struct SectionKey { 170 typedef typename std::conditional<Is64Bits, uint64_t, uint32_t>::type uintX_t; 171 StringRef Name; 172 uint32_t Type; 173 uintX_t Flags; 174 uintX_t EntSize; 175 }; 176 } 177 namespace llvm { 178 template <bool Is64Bits> struct DenseMapInfo<SectionKey<Is64Bits>> { 179 static SectionKey<Is64Bits> getEmptyKey() { 180 return SectionKey<Is64Bits>{DenseMapInfo<StringRef>::getEmptyKey(), 0, 0, 181 0}; 182 } 183 static SectionKey<Is64Bits> getTombstoneKey() { 184 return SectionKey<Is64Bits>{DenseMapInfo<StringRef>::getTombstoneKey(), 0, 185 0, 0}; 186 } 187 static unsigned getHashValue(const SectionKey<Is64Bits> &Val) { 188 return hash_combine(Val.Name, Val.Type, Val.Flags, Val.EntSize); 189 } 190 static bool isEqual(const SectionKey<Is64Bits> &LHS, 191 const SectionKey<Is64Bits> &RHS) { 192 return DenseMapInfo<StringRef>::isEqual(LHS.Name, RHS.Name) && 193 LHS.Type == RHS.Type && LHS.Flags == RHS.Flags && 194 LHS.EntSize == RHS.EntSize; 195 } 196 }; 197 } 198 199 template <class ELFT, class RelT> 200 static bool handleTlsRelocation(unsigned Type, SymbolBody *Body, 201 InputSectionBase<ELFT> &C, RelT &RI) { 202 if (Target->isTlsLocalDynamicReloc(Type)) { 203 if (Target->isTlsOptimized(Type, nullptr)) 204 return true; 205 if (Out<ELFT>::Got->addCurrentModuleTlsIndex()) 206 Out<ELFT>::RelaDyn->addReloc({&C, &RI}); 207 return true; 208 } 209 210 if (!Body || !Body->isTls()) 211 return false; 212 213 if (Target->isTlsGlobalDynamicReloc(Type)) { 214 bool Opt = Target->isTlsOptimized(Type, Body); 215 if (!Opt && Out<ELFT>::Got->addDynTlsEntry(Body)) { 216 Out<ELFT>::RelaDyn->addReloc({&C, &RI}); 217 Out<ELFT>::RelaDyn->addReloc({nullptr, nullptr}); 218 Body->setUsedInDynamicReloc(); 219 return true; 220 } 221 if (!canBePreempted(Body, true)) 222 return true; 223 } 224 return !Target->isTlsDynReloc(Type, *Body); 225 } 226 227 // The reason we have to do this early scan is as follows 228 // * To mmap the output file, we need to know the size 229 // * For that, we need to know how many dynamic relocs we will have. 230 // It might be possible to avoid this by outputting the file with write: 231 // * Write the allocated output sections, computing addresses. 232 // * Apply relocations, recording which ones require a dynamic reloc. 233 // * Write the dynamic relocations. 234 // * Write the rest of the file. 235 template <class ELFT> 236 template <bool isRela> 237 void Writer<ELFT>::scanRelocs( 238 InputSectionBase<ELFT> &C, 239 iterator_range<const Elf_Rel_Impl<ELFT, isRela> *> Rels) { 240 typedef Elf_Rel_Impl<ELFT, isRela> RelType; 241 const ObjectFile<ELFT> &File = *C.getFile(); 242 for (const RelType &RI : Rels) { 243 uint32_t SymIndex = RI.getSymbol(Config->Mips64EL); 244 SymbolBody *Body = File.getSymbolBody(SymIndex); 245 uint32_t Type = RI.getType(Config->Mips64EL); 246 247 // Ignore "hint" relocation because it is for optional code optimization. 248 if (Target->isHintReloc(Type)) 249 continue; 250 251 if (Target->isGotRelative(Type)) 252 HasGotOffRel = true; 253 254 // Set "used" bit for --as-needed. 255 if (Body && Body->isUndefined() && !Body->isWeak()) 256 if (auto *S = dyn_cast<SharedSymbol<ELFT>>(Body->repl())) 257 S->File->IsUsed = true; 258 259 if (Body) 260 Body = Body->repl(); 261 262 if (handleTlsRelocation<ELFT>(Type, Body, C, RI)) 263 continue; 264 265 if (Target->relocNeedsDynRelative(Type)) { 266 RelType *Rel = new (Alloc) RelType; 267 Rel->setSymbolAndType(0, Target->getRelativeReloc(), Config->Mips64EL); 268 Rel->r_offset = RI.r_offset; 269 Out<ELFT>::RelaDyn->addReloc({&C, Rel}); 270 } 271 272 bool NeedsGot = false; 273 bool NeedsMipsLocalGot = false; 274 bool NeedsPlt = false; 275 if (Config->EMachine == EM_MIPS && needsMipsLocalGot(Type, Body)) { 276 NeedsMipsLocalGot = true; 277 // FIXME (simon): Do not add so many redundant entries. 278 Out<ELFT>::Got->addMipsLocalEntry(); 279 } else if (Body) { 280 if (auto *E = dyn_cast<SharedSymbol<ELFT>>(Body)) { 281 if (E->NeedsCopy) 282 continue; 283 if (Target->needsCopyRel(Type, *Body)) 284 E->NeedsCopy = true; 285 } 286 NeedsPlt = Target->relocNeedsPlt(Type, *Body); 287 if (NeedsPlt) { 288 if (Body->isInPlt()) 289 continue; 290 Out<ELFT>::Plt->addEntry(Body); 291 } 292 NeedsGot = Target->relocNeedsGot(Type, *Body); 293 if (NeedsGot) { 294 if (NeedsPlt && Target->supportsLazyRelocations()) { 295 Out<ELFT>::GotPlt->addEntry(Body); 296 } else { 297 if (Body->isInGot()) 298 continue; 299 Out<ELFT>::Got->addEntry(Body); 300 } 301 } 302 } 303 304 // An STT_GNU_IFUNC symbol always uses a PLT entry, and all references 305 // to the symbol go through the PLT. This is true even for a local 306 // symbol, although local symbols normally do not require PLT entries. 307 if (Body && isGnuIFunc<ELFT>(*Body)) { 308 Body->setUsedInDynamicReloc(); 309 Out<ELFT>::RelaPlt->addReloc({&C, &RI}); 310 continue; 311 } 312 313 if (Config->EMachine == EM_MIPS) { 314 if (Type == R_MIPS_LO16) 315 // Ignore R_MIPS_LO16 relocation. If it is a pair for R_MIPS_GOT16 we 316 // already completed all required action (GOT entry allocation) when 317 // handle R_MIPS_GOT16a. If it is a pair for R_MIPS_HI16 against 318 // _gp_disp it does not require dynamic relocation. If its a pair for 319 // R_MIPS_HI16 against a regular symbol it does not require dynamic 320 // relocation too because that case is possible for executable file 321 // linking only. 322 continue; 323 if (NeedsGot || NeedsMipsLocalGot) { 324 // MIPS ABI has special rules to process GOT entries 325 // and doesn't require relocation entries for them. 326 // See "Global Offset Table" in Chapter 5 in the following document 327 // for detailed description: 328 // ftp://www.linux-mips.org/pub/linux/mips/doc/ABI/mipsabi.pdf 329 if (NeedsGot) 330 Body->setUsedInDynamicReloc(); 331 continue; 332 } 333 if (Body == Config->MipsGpDisp) 334 // MIPS _gp_disp designates offset between start of function and gp 335 // pointer into GOT therefore any relocations against it do not require 336 // dynamic relocation. 337 continue; 338 } 339 340 // Here we are creating a relocation for the dynamic linker based on 341 // a relocation from an object file, but some relocations need no 342 // load-time fixup when the final target is known. Skip such relocation. 343 bool CBP = canBePreempted(Body, NeedsGot); 344 bool NoDynrel = Target->isRelRelative(Type) || Target->isSizeReloc(Type) || 345 !Config->Shared; 346 if (!CBP && NoDynrel) 347 continue; 348 349 if (CBP) 350 Body->setUsedInDynamicReloc(); 351 if (NeedsPlt && Target->supportsLazyRelocations()) 352 Out<ELFT>::RelaPlt->addReloc({&C, &RI}); 353 else 354 Out<ELFT>::RelaDyn->addReloc({&C, &RI}); 355 } 356 } 357 358 template <class ELFT> void Writer<ELFT>::scanRelocs(InputSection<ELFT> &C) { 359 if (C.getSectionHdr()->sh_flags & SHF_ALLOC) 360 for (const Elf_Shdr *RelSec : C.RelocSections) 361 scanRelocs(C, *RelSec); 362 } 363 364 template <class ELFT> 365 void Writer<ELFT>::scanRelocs(InputSectionBase<ELFT> &S, 366 const Elf_Shdr &RelSec) { 367 ELFFile<ELFT> &EObj = S.getFile()->getObj(); 368 if (RelSec.sh_type == SHT_RELA) 369 scanRelocs(S, EObj.relas(&RelSec)); 370 else 371 scanRelocs(S, EObj.rels(&RelSec)); 372 } 373 374 template <class ELFT> 375 static void reportUndefined(SymbolTable<ELFT> &Symtab, SymbolBody *Sym) { 376 if (Config->Shared && !Config->NoUndefined) 377 return; 378 379 std::string Msg = "undefined symbol: " + Sym->getName().str(); 380 if (ELFFileBase<ELFT> *File = Symtab.findFile(Sym)) 381 Msg += " in " + File->getName().str(); 382 if (Config->NoInhibitExec) 383 warning(Msg); 384 else 385 error(Msg); 386 } 387 388 template <class ELFT> 389 static bool shouldKeepInSymtab(const ObjectFile<ELFT> &File, StringRef SymName, 390 const typename ELFFile<ELFT>::Elf_Sym &Sym) { 391 if (Sym.getType() == STT_SECTION || Sym.getType() == STT_FILE) 392 return false; 393 394 InputSectionBase<ELFT> *Sec = File.getSection(Sym); 395 // If sym references a section in a discarded group, don't keep it. 396 if (Sec == &InputSection<ELFT>::Discarded) 397 return false; 398 399 if (Config->DiscardNone) 400 return true; 401 402 // In ELF assembly .L symbols are normally discarded by the assembler. 403 // If the assembler fails to do so, the linker discards them if 404 // * --discard-locals is used. 405 // * The symbol is in a SHF_MERGE section, which is normally the reason for 406 // the assembler keeping the .L symbol. 407 if (!SymName.startswith(".L") && !SymName.empty()) 408 return true; 409 410 if (Config->DiscardLocals) 411 return false; 412 413 return !(Sec->getSectionHdr()->sh_flags & SHF_MERGE); 414 } 415 416 // Local symbols are not in the linker's symbol table. This function scans 417 // each object file's symbol table to copy local symbols to the output. 418 template <class ELFT> void Writer<ELFT>::copyLocalSymbols() { 419 if (!Out<ELFT>::SymTab) 420 return; 421 for (const std::unique_ptr<ObjectFile<ELFT>> &F : Symtab.getObjectFiles()) { 422 for (const Elf_Sym &Sym : F->getLocalSymbols()) { 423 ErrorOr<StringRef> SymNameOrErr = Sym.getName(F->getStringTable()); 424 error(SymNameOrErr); 425 StringRef SymName = *SymNameOrErr; 426 if (!shouldKeepInSymtab<ELFT>(*F, SymName, Sym)) 427 continue; 428 if (Sym.st_shndx != SHN_ABS) { 429 InputSectionBase<ELFT> *Section = F->getSection(Sym); 430 if (!Section->isLive()) 431 continue; 432 } 433 Out<ELFT>::SymTab->addLocalSymbol(SymName); 434 F->KeptLocalSyms.push_back(&Sym); 435 } 436 } 437 } 438 439 // PPC64 has a number of special SHT_PROGBITS+SHF_ALLOC+SHF_WRITE sections that 440 // we would like to make sure appear is a specific order to maximize their 441 // coverage by a single signed 16-bit offset from the TOC base pointer. 442 // Conversely, the special .tocbss section should be first among all SHT_NOBITS 443 // sections. This will put it next to the loaded special PPC64 sections (and, 444 // thus, within reach of the TOC base pointer). 445 static int getPPC64SectionRank(StringRef SectionName) { 446 return StringSwitch<int>(SectionName) 447 .Case(".tocbss", 0) 448 .Case(".branch_lt", 2) 449 .Case(".toc", 3) 450 .Case(".toc1", 4) 451 .Case(".opd", 5) 452 .Default(1); 453 } 454 455 template <class ELFT> static bool isRelroSection(OutputSectionBase<ELFT> *Sec) { 456 typename OutputSectionBase<ELFT>::uintX_t Flags = Sec->getFlags(); 457 if (!(Flags & SHF_ALLOC) || !(Flags & SHF_WRITE)) 458 return false; 459 if (Flags & SHF_TLS) 460 return true; 461 uint32_t Type = Sec->getType(); 462 if (Type == SHT_INIT_ARRAY || Type == SHT_FINI_ARRAY || 463 Type == SHT_PREINIT_ARRAY) 464 return true; 465 if (Sec == Out<ELFT>::GotPlt) 466 return Config->ZNow; 467 if (Sec == Out<ELFT>::Dynamic || Sec == Out<ELFT>::Got) 468 return true; 469 StringRef S = Sec->getName(); 470 return S == ".data.rel.ro" || S == ".ctors" || S == ".dtors" || S == ".jcr" || 471 S == ".eh_frame"; 472 } 473 474 // Output section ordering is determined by this function. 475 template <class ELFT> 476 static bool compareOutputSections(OutputSectionBase<ELFT> *A, 477 OutputSectionBase<ELFT> *B) { 478 typedef typename ELFFile<ELFT>::uintX_t uintX_t; 479 480 uintX_t AFlags = A->getFlags(); 481 uintX_t BFlags = B->getFlags(); 482 483 // Allocatable sections go first to reduce the total PT_LOAD size and 484 // so debug info doesn't change addresses in actual code. 485 bool AIsAlloc = AFlags & SHF_ALLOC; 486 bool BIsAlloc = BFlags & SHF_ALLOC; 487 if (AIsAlloc != BIsAlloc) 488 return AIsAlloc; 489 490 // We don't have any special requirements for the relative order of 491 // two non allocatable sections. 492 if (!AIsAlloc) 493 return false; 494 495 // We want the read only sections first so that they go in the PT_LOAD 496 // covering the program headers at the start of the file. 497 bool AIsWritable = AFlags & SHF_WRITE; 498 bool BIsWritable = BFlags & SHF_WRITE; 499 if (AIsWritable != BIsWritable) 500 return BIsWritable; 501 502 // For a corresponding reason, put non exec sections first (the program 503 // header PT_LOAD is not executable). 504 bool AIsExec = AFlags & SHF_EXECINSTR; 505 bool BIsExec = BFlags & SHF_EXECINSTR; 506 if (AIsExec != BIsExec) 507 return BIsExec; 508 509 // If we got here we know that both A and B are in the same PT_LOAD. 510 511 // The TLS initialization block needs to be a single contiguous block in a R/W 512 // PT_LOAD, so stick TLS sections directly before R/W sections. The TLS NOBITS 513 // sections are placed here as they don't take up virtual address space in the 514 // PT_LOAD. 515 bool AIsTls = AFlags & SHF_TLS; 516 bool BIsTls = BFlags & SHF_TLS; 517 if (AIsTls != BIsTls) 518 return AIsTls; 519 520 // The next requirement we have is to put nobits sections last. The 521 // reason is that the only thing the dynamic linker will see about 522 // them is a p_memsz that is larger than p_filesz. Seeing that it 523 // zeros the end of the PT_LOAD, so that has to correspond to the 524 // nobits sections. 525 bool AIsNoBits = A->getType() == SHT_NOBITS; 526 bool BIsNoBits = B->getType() == SHT_NOBITS; 527 if (AIsNoBits != BIsNoBits) 528 return BIsNoBits; 529 530 // We place RelRo section before plain r/w ones. 531 bool AIsRelRo = isRelroSection(A); 532 bool BIsRelRo = isRelroSection(B); 533 if (AIsRelRo != BIsRelRo) 534 return AIsRelRo; 535 536 // Some architectures have additional ordering restrictions for sections 537 // within the same PT_LOAD. 538 if (Config->EMachine == EM_PPC64) 539 return getPPC64SectionRank(A->getName()) < 540 getPPC64SectionRank(B->getName()); 541 542 return false; 543 } 544 545 template <class ELFT> OutputSection<ELFT> *Writer<ELFT>::getBss() { 546 if (!Out<ELFT>::Bss) { 547 Out<ELFT>::Bss = 548 new OutputSection<ELFT>(".bss", SHT_NOBITS, SHF_ALLOC | SHF_WRITE); 549 OwningSections.emplace_back(Out<ELFT>::Bss); 550 OutputSections.push_back(Out<ELFT>::Bss); 551 } 552 return Out<ELFT>::Bss; 553 } 554 555 // Until this function is called, common symbols do not belong to any section. 556 // This function adds them to end of BSS section. 557 template <class ELFT> 558 void Writer<ELFT>::addCommonSymbols(std::vector<DefinedCommon *> &Syms) { 559 if (Syms.empty()) 560 return; 561 562 // Sort the common symbols by alignment as an heuristic to pack them better. 563 std::stable_sort(Syms.begin(), Syms.end(), 564 [](const DefinedCommon *A, const DefinedCommon *B) { 565 return A->MaxAlignment > B->MaxAlignment; 566 }); 567 568 uintX_t Off = getBss()->getSize(); 569 for (DefinedCommon *C : Syms) { 570 Off = alignTo(Off, C->MaxAlignment); 571 C->OffsetInBss = Off; 572 Off += C->Size; 573 } 574 575 Out<ELFT>::Bss->setSize(Off); 576 } 577 578 // Reserve space in .bss for copy relocations. 579 template <class ELFT> 580 void Writer<ELFT>::addCopyRelSymbols(std::vector<SharedSymbol<ELFT> *> &Syms) { 581 if (Syms.empty()) 582 return; 583 uintX_t Off = getBss()->getSize(); 584 for (SharedSymbol<ELFT> *C : Syms) { 585 const Elf_Sym &Sym = C->Sym; 586 const Elf_Shdr *Sec = C->File->getSection(Sym); 587 uintX_t SecAlign = Sec->sh_addralign; 588 unsigned TrailingZeros = 589 std::min(countTrailingZeros(SecAlign), 590 countTrailingZeros((uintX_t)Sym.st_value)); 591 uintX_t Align = 1 << TrailingZeros; 592 Out<ELFT>::Bss->updateAlign(Align); 593 Off = alignTo(Off, Align); 594 C->OffsetInBss = Off; 595 Off += Sym.st_size; 596 } 597 Out<ELFT>::Bss->setSize(Off); 598 } 599 600 template <class ELFT> 601 StringRef Writer<ELFT>::getOutputSectionName(StringRef S) const { 602 auto It = InputToOutputSection.find(S); 603 if (It != std::end(InputToOutputSection)) 604 return It->second; 605 606 if (S.startswith(".text.")) 607 return ".text"; 608 if (S.startswith(".rodata.")) 609 return ".rodata"; 610 if (S.startswith(".data.rel.ro")) 611 return ".data.rel.ro"; 612 if (S.startswith(".data.")) 613 return ".data"; 614 if (S.startswith(".bss.")) 615 return ".bss"; 616 return S; 617 } 618 619 template <class ELFT> 620 void reportDiscarded(InputSectionBase<ELFT> *IS, 621 const std::unique_ptr<ObjectFile<ELFT>> &File) { 622 if (!Config->PrintGcSections || !IS || IS->isLive()) 623 return; 624 llvm::errs() << "removing unused section from '" << IS->getSectionName() 625 << "' in file '" << File->getName() << "'\n"; 626 } 627 628 template <class ELFT> 629 bool Writer<ELFT>::isDiscarded(InputSectionBase<ELFT> *IS) const { 630 if (!IS || !IS->isLive() || IS == &InputSection<ELFT>::Discarded) 631 return true; 632 return InputToOutputSection.lookup(IS->getSectionName()) == "/DISCARD/"; 633 } 634 635 template <class ELFT> 636 static bool compareSections(OutputSectionBase<ELFT> *A, 637 OutputSectionBase<ELFT> *B) { 638 auto ItA = Config->OutputSections.find(A->getName()); 639 auto ItEnd = std::end(Config->OutputSections); 640 if (ItA == ItEnd) 641 return compareOutputSections(A, B); 642 auto ItB = Config->OutputSections.find(B->getName()); 643 if (ItB == ItEnd) 644 return compareOutputSections(A, B); 645 646 return std::distance(ItA, ItB) > 0; 647 } 648 649 // The beginning and the ending of .rel[a].plt section are marked 650 // with __rel[a]_iplt_{start,end} symbols if it is a statically linked 651 // executable. The runtime needs these symbols in order to resolve 652 // all IRELATIVE relocs on startup. For dynamic executables, we don't 653 // need these symbols, since IRELATIVE relocs are resolved through GOT 654 // and PLT. For details, see http://www.airs.com/blog/archives/403. 655 template <class ELFT> 656 void Writer<ELFT>::addRelIpltSymbols() { 657 if (isOutputDynamic() || !Out<ELFT>::RelaPlt) 658 return; 659 bool IsRela = shouldUseRela<ELFT>(); 660 661 StringRef S = IsRela ? "__rela_iplt_start" : "__rel_iplt_start"; 662 if (Symtab.find(S)) 663 Symtab.addAbsolute(S, ElfSym<ELFT>::RelaIpltStart); 664 665 S = IsRela ? "__rela_iplt_end" : "__rel_iplt_end"; 666 if (Symtab.find(S)) 667 Symtab.addAbsolute(S, ElfSym<ELFT>::RelaIpltEnd); 668 } 669 670 template <class ELFT> static bool includeInSymtab(const SymbolBody &B) { 671 if (!B.isUsedInRegularObj()) 672 return false; 673 674 // Don't include synthetic symbols like __init_array_start in every output. 675 if (auto *U = dyn_cast<DefinedRegular<ELFT>>(&B)) 676 if (&U->Sym == &ElfSym<ELFT>::Ignored) 677 return false; 678 679 return true; 680 } 681 682 static bool includeInDynamicSymtab(const SymbolBody &B) { 683 uint8_t V = B.getVisibility(); 684 if (V != STV_DEFAULT && V != STV_PROTECTED) 685 return false; 686 if (Config->ExportDynamic || Config->Shared) 687 return true; 688 return B.isUsedInDynamicReloc(); 689 } 690 691 // This class knows how to create an output section for a given 692 // input section. Output section type is determined by various 693 // factors, including input section's sh_flags, sh_type and 694 // linker scripts. 695 namespace { 696 template <class ELFT> class OutputSectionFactory { 697 typedef typename ELFFile<ELFT>::Elf_Shdr Elf_Shdr; 698 typedef typename ELFFile<ELFT>::uintX_t uintX_t; 699 700 public: 701 std::pair<OutputSectionBase<ELFT> *, bool> create(InputSectionBase<ELFT> *C, 702 StringRef OutsecName); 703 704 OutputSectionBase<ELFT> *lookup(StringRef Name, uint32_t Type, uintX_t Flags); 705 706 private: 707 SectionKey<ELFT::Is64Bits> createKey(InputSectionBase<ELFT> *C, 708 StringRef OutsecName); 709 710 SmallDenseMap<SectionKey<ELFT::Is64Bits>, OutputSectionBase<ELFT> *> Map; 711 }; 712 } 713 714 template <class ELFT> 715 std::pair<OutputSectionBase<ELFT> *, bool> 716 OutputSectionFactory<ELFT>::create(InputSectionBase<ELFT> *C, 717 StringRef OutsecName) { 718 SectionKey<ELFT::Is64Bits> Key = createKey(C, OutsecName); 719 OutputSectionBase<ELFT> *&Sec = Map[Key]; 720 if (Sec) 721 return {Sec, false}; 722 723 switch (C->SectionKind) { 724 case InputSectionBase<ELFT>::Regular: 725 Sec = new OutputSection<ELFT>(Key.Name, Key.Type, Key.Flags); 726 break; 727 case InputSectionBase<ELFT>::EHFrame: 728 Sec = new EHOutputSection<ELFT>(Key.Name, Key.Type, Key.Flags); 729 break; 730 case InputSectionBase<ELFT>::Merge: 731 Sec = new MergeOutputSection<ELFT>(Key.Name, Key.Type, Key.Flags); 732 break; 733 case InputSectionBase<ELFT>::MipsReginfo: 734 Sec = new MipsReginfoOutputSection<ELFT>(); 735 break; 736 } 737 return {Sec, true}; 738 } 739 740 template <class ELFT> 741 OutputSectionBase<ELFT> *OutputSectionFactory<ELFT>::lookup(StringRef Name, 742 uint32_t Type, 743 uintX_t Flags) { 744 return Map.lookup({Name, Type, Flags, 0}); 745 } 746 747 template <class ELFT> 748 SectionKey<ELFT::Is64Bits> 749 OutputSectionFactory<ELFT>::createKey(InputSectionBase<ELFT> *C, 750 StringRef OutsecName) { 751 const Elf_Shdr *H = C->getSectionHdr(); 752 uintX_t Flags = H->sh_flags & ~SHF_GROUP; 753 754 // For SHF_MERGE we create different output sections for each sh_entsize. 755 // This makes each output section simple and keeps a single level 756 // mapping from input to output. 757 uintX_t EntSize = isa<MergeInputSection<ELFT>>(C) ? H->sh_entsize : 0; 758 759 // GNU as can give .eh_frame secion type SHT_PROGBITS or SHT_X86_64_UNWIND 760 // depending on the construct. We want to canonicalize it so that 761 // there is only one .eh_frame in the end. 762 uint32_t Type = H->sh_type; 763 if (Type == SHT_PROGBITS && Config->EMachine == EM_X86_64 && 764 isa<EHInputSection<ELFT>>(C)) 765 Type = SHT_X86_64_UNWIND; 766 767 return SectionKey<ELFT::Is64Bits>{OutsecName, Type, Flags, EntSize}; 768 } 769 770 // The linker is expected to define some symbols depending on 771 // the linking result. This function defines such symbols. 772 template <class ELFT> void Writer<ELFT>::addReservedSymbols() { 773 // __tls_get_addr is defined by the dynamic linker for dynamic ELFs. For 774 // static linking the linker is required to optimize away any references to 775 // __tls_get_addr, so it's not defined anywhere. Create a hidden definition 776 // to avoid the undefined symbol error. 777 if (!isOutputDynamic()) 778 Symtab.addIgnored("__tls_get_addr"); 779 780 // If the "_end" symbol is referenced, it is expected to point to the address 781 // right after the data segment. Usually, this symbol points to the end 782 // of .bss section or to the end of .data section if .bss section is absent. 783 // The order of the sections can be affected by linker script, 784 // so it is hard to predict which section will be the last one. 785 // So, if this symbol is referenced, we just add the placeholder here 786 // and update its value later. 787 if (Symtab.find("_end")) 788 Symtab.addAbsolute("_end", ElfSym<ELFT>::End); 789 790 // If there is an undefined symbol "end", we should initialize it 791 // with the same value as "_end". In any other case it should stay intact, 792 // because it is an allowable name for a user symbol. 793 if (SymbolBody *B = Symtab.find("end")) 794 if (B->isUndefined()) 795 Symtab.addAbsolute("end", ElfSym<ELFT>::End); 796 } 797 798 // Create output section objects and add them to OutputSections. 799 template <class ELFT> void Writer<ELFT>::createSections() { 800 // Add .interp first because some loaders want to see that section 801 // on the first page of the executable file when loaded into memory. 802 if (needsInterpSection()) 803 OutputSections.push_back(Out<ELFT>::Interp); 804 805 // Create output sections for input object file sections. 806 std::vector<OutputSectionBase<ELFT> *> RegularSections; 807 OutputSectionFactory<ELFT> Factory; 808 for (const std::unique_ptr<ObjectFile<ELFT>> &F : Symtab.getObjectFiles()) { 809 for (InputSectionBase<ELFT> *C : F->getSections()) { 810 if (isDiscarded(C)) { 811 reportDiscarded(C, F); 812 continue; 813 } 814 OutputSectionBase<ELFT> *Sec; 815 bool IsNew; 816 std::tie(Sec, IsNew) = 817 Factory.create(C, getOutputSectionName(C->getSectionName())); 818 if (IsNew) { 819 OwningSections.emplace_back(Sec); 820 OutputSections.push_back(Sec); 821 RegularSections.push_back(Sec); 822 } 823 Sec->addSection(C); 824 } 825 } 826 827 Out<ELFT>::Bss = static_cast<OutputSection<ELFT> *>( 828 Factory.lookup(".bss", SHT_NOBITS, SHF_ALLOC | SHF_WRITE)); 829 830 // If we have a .opd section (used under PPC64 for function descriptors), 831 // store a pointer to it here so that we can use it later when processing 832 // relocations. 833 Out<ELFT>::Opd = Factory.lookup(".opd", SHT_PROGBITS, SHF_WRITE | SHF_ALLOC); 834 835 Out<ELFT>::Dynamic->PreInitArraySec = Factory.lookup( 836 ".preinit_array", SHT_PREINIT_ARRAY, SHF_WRITE | SHF_ALLOC); 837 Out<ELFT>::Dynamic->InitArraySec = 838 Factory.lookup(".init_array", SHT_INIT_ARRAY, SHF_WRITE | SHF_ALLOC); 839 Out<ELFT>::Dynamic->FiniArraySec = 840 Factory.lookup(".fini_array", SHT_FINI_ARRAY, SHF_WRITE | SHF_ALLOC); 841 842 // The linker needs to define SECNAME_start, SECNAME_end and SECNAME_stop 843 // symbols for sections, so that the runtime can get the start and end 844 // addresses of each section by section name. Add such symbols. 845 addStartEndSymbols(); 846 for (OutputSectionBase<ELFT> *Sec : RegularSections) 847 addStartStopSymbols(Sec); 848 849 // Scan relocations. This must be done after every symbol is declared so that 850 // we can correctly decide if a dynamic relocation is needed. 851 for (const std::unique_ptr<ObjectFile<ELFT>> &F : Symtab.getObjectFiles()) { 852 for (InputSectionBase<ELFT> *C : F->getSections()) { 853 if (isDiscarded(C)) 854 continue; 855 if (auto *S = dyn_cast<InputSection<ELFT>>(C)) 856 scanRelocs(*S); 857 else if (auto *S = dyn_cast<EHInputSection<ELFT>>(C)) 858 if (S->RelocSection) 859 scanRelocs(*S, *S->RelocSection); 860 } 861 } 862 863 // Define __rel[a]_iplt_{start,end} symbols if needed. 864 addRelIpltSymbols(); 865 866 // Now that we have defined all possible symbols including linker- 867 // synthesized ones. Visit all symbols to give the finishing touches. 868 std::vector<DefinedCommon *> CommonSymbols; 869 std::vector<SharedSymbol<ELFT> *> CopyRelSymbols; 870 for (auto &P : Symtab.getSymbols()) { 871 SymbolBody *Body = P.second->Body; 872 if (auto *U = dyn_cast<Undefined>(Body)) 873 if (!U->isWeak() && !U->canKeepUndefined()) 874 reportUndefined<ELFT>(Symtab, Body); 875 876 if (auto *C = dyn_cast<DefinedCommon>(Body)) 877 CommonSymbols.push_back(C); 878 if (auto *SC = dyn_cast<SharedSymbol<ELFT>>(Body)) 879 if (SC->NeedsCopy) 880 CopyRelSymbols.push_back(SC); 881 882 if (!includeInSymtab<ELFT>(*Body)) 883 continue; 884 if (Out<ELFT>::SymTab) 885 Out<ELFT>::SymTab->addSymbol(Body); 886 887 if (isOutputDynamic() && includeInDynamicSymtab(*Body)) 888 Out<ELFT>::DynSymTab->addSymbol(Body); 889 } 890 addCommonSymbols(CommonSymbols); 891 addCopyRelSymbols(CopyRelSymbols); 892 893 // So far we have added sections from input object files. 894 // This function adds linker-created Out<ELFT>::* sections. 895 addPredefinedSections(); 896 897 std::stable_sort(OutputSections.begin(), OutputSections.end(), 898 compareSections<ELFT>); 899 900 for (unsigned I = 0, N = OutputSections.size(); I < N; ++I) { 901 OutputSections[I]->SectionIndex = I + 1; 902 HasRelro |= (Config->ZRelro && isRelroSection(OutputSections[I])); 903 } 904 905 for (OutputSectionBase<ELFT> *Sec : OutputSections) 906 Out<ELFT>::ShStrTab->reserve(Sec->getName()); 907 908 // Finalizers fix each section's size. 909 // .dynsym is finalized early since that may fill up .gnu.hash. 910 if (isOutputDynamic()) 911 Out<ELFT>::DynSymTab->finalize(); 912 913 // Fill other section headers. The dynamic string table in finalized 914 // once the .dynamic finalizer has added a few last strings. 915 for (OutputSectionBase<ELFT> *Sec : OutputSections) 916 if (Sec != Out<ELFT>::DynStrTab) 917 Sec->finalize(); 918 } 919 920 // This function add Out<ELFT>::* sections to OutputSections. 921 template <class ELFT> void Writer<ELFT>::addPredefinedSections() { 922 auto Add = [&](OutputSectionBase<ELFT> *C) { 923 if (C) 924 OutputSections.push_back(C); 925 }; 926 927 // This order is not the same as the final output order 928 // because we sort the sections using their attributes below. 929 Add(Out<ELFT>::SymTab); 930 Add(Out<ELFT>::ShStrTab); 931 Add(Out<ELFT>::StrTab); 932 if (isOutputDynamic()) { 933 Add(Out<ELFT>::DynSymTab); 934 Add(Out<ELFT>::GnuHashTab); 935 Add(Out<ELFT>::HashTab); 936 Add(Out<ELFT>::Dynamic); 937 Add(Out<ELFT>::DynStrTab); 938 if (Out<ELFT>::RelaDyn->hasRelocs()) 939 Add(Out<ELFT>::RelaDyn); 940 941 // This is a MIPS specific section to hold a space within the data segment 942 // of executable file which is pointed to by the DT_MIPS_RLD_MAP entry. 943 // See "Dynamic section" in Chapter 5 in the following document: 944 // ftp://www.linux-mips.org/pub/linux/mips/doc/ABI/mipsabi.pdf 945 if (Config->EMachine == EM_MIPS && !Config->Shared) { 946 Out<ELFT>::MipsRldMap = new OutputSection<ELFT>(".rld_map", SHT_PROGBITS, 947 SHF_ALLOC | SHF_WRITE); 948 Out<ELFT>::MipsRldMap->setSize(ELFT::Is64Bits ? 8 : 4); 949 Out<ELFT>::MipsRldMap->updateAlign(ELFT::Is64Bits ? 8 : 4); 950 OwningSections.emplace_back(Out<ELFT>::MipsRldMap); 951 Add(Out<ELFT>::MipsRldMap); 952 } 953 } 954 955 // We always need to add rel[a].plt to output if it has entries. 956 // Even during static linking it can contain R_[*]_IRELATIVE relocations. 957 if (Out<ELFT>::RelaPlt && Out<ELFT>::RelaPlt->hasRelocs()) { 958 Add(Out<ELFT>::RelaPlt); 959 Out<ELFT>::RelaPlt->Static = !isOutputDynamic(); 960 } 961 962 bool needsGot = !Out<ELFT>::Got->empty(); 963 // We add the .got section to the result for dynamic MIPS target because 964 // its address and properties are mentioned in the .dynamic section. 965 if (Config->EMachine == EM_MIPS) 966 needsGot |= isOutputDynamic(); 967 // If we have a relocation that is relative to GOT (such as GOTOFFREL), 968 // we need to emit a GOT even if it's empty. 969 if (HasGotOffRel) 970 needsGot = true; 971 972 if (needsGot) 973 Add(Out<ELFT>::Got); 974 if (Out<ELFT>::GotPlt && !Out<ELFT>::GotPlt->empty()) 975 Add(Out<ELFT>::GotPlt); 976 if (!Out<ELFT>::Plt->empty()) 977 Add(Out<ELFT>::Plt); 978 979 if (Out<ELFT>::EhFrameHdr->Live) 980 Add(Out<ELFT>::EhFrameHdr); 981 } 982 983 // The linker is expected to define SECNAME_start and SECNAME_end 984 // symbols for a few sections. This function defines them. 985 template <class ELFT> void Writer<ELFT>::addStartEndSymbols() { 986 auto Define = [&](StringRef Start, StringRef End, 987 OutputSectionBase<ELFT> *OS) { 988 if (OS) { 989 Symtab.addSynthetic(Start, *OS, 0); 990 Symtab.addSynthetic(End, *OS, OS->getSize()); 991 } else { 992 Symtab.addIgnored(Start); 993 Symtab.addIgnored(End); 994 } 995 }; 996 997 Define("__preinit_array_start", "__preinit_array_end", 998 Out<ELFT>::Dynamic->PreInitArraySec); 999 Define("__init_array_start", "__init_array_end", 1000 Out<ELFT>::Dynamic->InitArraySec); 1001 Define("__fini_array_start", "__fini_array_end", 1002 Out<ELFT>::Dynamic->FiniArraySec); 1003 } 1004 1005 static bool isAlpha(char C) { 1006 return ('a' <= C && C <= 'z') || ('A' <= C && C <= 'Z') || C == '_'; 1007 } 1008 1009 static bool isAlnum(char C) { return isAlpha(C) || ('0' <= C && C <= '9'); } 1010 1011 // Returns true if S is valid as a C language identifier. 1012 static bool isValidCIdentifier(StringRef S) { 1013 if (S.empty() || !isAlpha(S[0])) 1014 return false; 1015 return std::all_of(S.begin() + 1, S.end(), isAlnum); 1016 } 1017 1018 // If a section name is valid as a C identifier (which is rare because of 1019 // the leading '.'), linkers are expected to define __start_<secname> and 1020 // __stop_<secname> symbols. They are at beginning and end of the section, 1021 // respectively. This is not requested by the ELF standard, but GNU ld and 1022 // gold provide the feature, and used by many programs. 1023 template <class ELFT> 1024 void Writer<ELFT>::addStartStopSymbols(OutputSectionBase<ELFT> *Sec) { 1025 StringRef S = Sec->getName(); 1026 if (!isValidCIdentifier(S)) 1027 return; 1028 StringSaver Saver(Alloc); 1029 StringRef Start = Saver.save("__start_" + S); 1030 StringRef Stop = Saver.save("__stop_" + S); 1031 if (SymbolBody *B = Symtab.find(Start)) 1032 if (B->isUndefined()) 1033 Symtab.addSynthetic(Start, *Sec, 0); 1034 if (SymbolBody *B = Symtab.find(Stop)) 1035 if (B->isUndefined()) 1036 Symtab.addSynthetic(Stop, *Sec, Sec->getSize()); 1037 } 1038 1039 template <class ELFT> static bool needsPhdr(OutputSectionBase<ELFT> *Sec) { 1040 return Sec->getFlags() & SHF_ALLOC; 1041 } 1042 1043 static uint32_t toPhdrFlags(uint64_t Flags) { 1044 uint32_t Ret = PF_R; 1045 if (Flags & SHF_WRITE) 1046 Ret |= PF_W; 1047 if (Flags & SHF_EXECINSTR) 1048 Ret |= PF_X; 1049 return Ret; 1050 } 1051 1052 /// For AMDGPU we need to use custom segment kinds in order to specify which 1053 /// address space data should be loaded into. 1054 template <class ELFT> 1055 static uint32_t getAmdgpuPhdr(OutputSectionBase<ELFT> *Sec) { 1056 uint32_t Flags = Sec->getFlags(); 1057 if (Flags & SHF_AMDGPU_HSA_CODE) 1058 return PT_AMDGPU_HSA_LOAD_CODE_AGENT; 1059 if ((Flags & SHF_AMDGPU_HSA_GLOBAL) && !(Flags & SHF_AMDGPU_HSA_AGENT)) 1060 return PT_AMDGPU_HSA_LOAD_GLOBAL_PROGRAM; 1061 return PT_LOAD; 1062 } 1063 1064 template <class ELFT> 1065 void Writer<ELFT>::updateRelro(Elf_Phdr *Cur, Elf_Phdr *GnuRelroPhdr, 1066 uintX_t VA) { 1067 if (!GnuRelroPhdr->p_type) 1068 setPhdr(GnuRelroPhdr, PT_GNU_RELRO, PF_R, Cur->p_offset, Cur->p_vaddr, 1069 VA - Cur->p_vaddr, 1 /*p_align*/); 1070 GnuRelroPhdr->p_filesz = VA - Cur->p_vaddr; 1071 GnuRelroPhdr->p_memsz = VA - Cur->p_vaddr; 1072 } 1073 1074 // Visits all sections to create PHDRs and to assign incremental, 1075 // non-overlapping addresses to output sections. 1076 template <class ELFT> void Writer<ELFT>::assignAddresses() { 1077 uintX_t VA = Target->getVAStart() + sizeof(Elf_Ehdr); 1078 uintX_t FileOff = sizeof(Elf_Ehdr); 1079 1080 // Calculate and reserve the space for the program header first so that 1081 // the first section can start right after the program header. 1082 Phdrs.resize(getPhdrsNum()); 1083 size_t PhdrSize = sizeof(Elf_Phdr) * Phdrs.size(); 1084 1085 // The first phdr entry is PT_PHDR which describes the program header itself. 1086 setPhdr(&Phdrs[0], PT_PHDR, PF_R, FileOff, VA, PhdrSize, /*Align=*/8); 1087 FileOff += PhdrSize; 1088 VA += PhdrSize; 1089 1090 // PT_INTERP must be the second entry if exists. 1091 int PhdrIdx = 0; 1092 Elf_Phdr *Interp = nullptr; 1093 if (needsInterpSection()) 1094 Interp = &Phdrs[++PhdrIdx]; 1095 1096 // Add the first PT_LOAD segment for regular output sections. 1097 setPhdr(&Phdrs[++PhdrIdx], PT_LOAD, PF_R, 0, Target->getVAStart(), FileOff, 1098 Target->getPageSize()); 1099 1100 Elf_Phdr GnuRelroPhdr = {}; 1101 Elf_Phdr TlsPhdr{}; 1102 bool RelroAligned = false; 1103 uintX_t ThreadBssOffset = 0; 1104 // Create phdrs as we assign VAs and file offsets to all output sections. 1105 for (OutputSectionBase<ELFT> *Sec : OutputSections) { 1106 Elf_Phdr *PH = &Phdrs[PhdrIdx]; 1107 if (needsPhdr<ELFT>(Sec)) { 1108 uintX_t Flags = toPhdrFlags(Sec->getFlags()); 1109 bool InRelRo = Config->ZRelro && (Flags & PF_W) && isRelroSection(Sec); 1110 bool FirstNonRelRo = GnuRelroPhdr.p_type && !InRelRo && !RelroAligned; 1111 if (FirstNonRelRo || PH->p_flags != Flags) { 1112 VA = alignTo(VA, Target->getPageSize()); 1113 FileOff = alignTo(FileOff, Target->getPageSize()); 1114 if (FirstNonRelRo) 1115 RelroAligned = true; 1116 } 1117 1118 if (PH->p_flags != Flags) { 1119 // Flags changed. Create a new PT_LOAD. 1120 PH = &Phdrs[++PhdrIdx]; 1121 uint32_t PTType = (Config->EMachine != EM_AMDGPU) ? (uint32_t)PT_LOAD 1122 : getAmdgpuPhdr(Sec); 1123 setPhdr(PH, PTType, Flags, FileOff, VA, 0, Target->getPageSize()); 1124 } 1125 1126 if (Sec->getFlags() & SHF_TLS) { 1127 if (!TlsPhdr.p_vaddr) 1128 setPhdr(&TlsPhdr, PT_TLS, PF_R, FileOff, VA, 0, Sec->getAlign()); 1129 if (Sec->getType() != SHT_NOBITS) 1130 VA = alignTo(VA, Sec->getAlign()); 1131 uintX_t TVA = alignTo(VA + ThreadBssOffset, Sec->getAlign()); 1132 Sec->setVA(TVA); 1133 TlsPhdr.p_memsz += Sec->getSize(); 1134 if (Sec->getType() == SHT_NOBITS) { 1135 ThreadBssOffset = TVA - VA + Sec->getSize(); 1136 } else { 1137 TlsPhdr.p_filesz += Sec->getSize(); 1138 VA += Sec->getSize(); 1139 } 1140 TlsPhdr.p_align = std::max<uintX_t>(TlsPhdr.p_align, Sec->getAlign()); 1141 } else { 1142 VA = alignTo(VA, Sec->getAlign()); 1143 Sec->setVA(VA); 1144 VA += Sec->getSize(); 1145 if (InRelRo) 1146 updateRelro(PH, &GnuRelroPhdr, VA); 1147 } 1148 } 1149 1150 FileOff = alignTo(FileOff, Sec->getAlign()); 1151 Sec->setFileOffset(FileOff); 1152 if (Sec->getType() != SHT_NOBITS) 1153 FileOff += Sec->getSize(); 1154 if (needsPhdr<ELFT>(Sec)) { 1155 PH->p_filesz = FileOff - PH->p_offset; 1156 PH->p_memsz = VA - PH->p_vaddr; 1157 } 1158 } 1159 1160 if (TlsPhdr.p_vaddr) { 1161 // The TLS pointer goes after PT_TLS. At least glibc will align it, 1162 // so round up the size to make sure the offsets are correct. 1163 TlsPhdr.p_memsz = alignTo(TlsPhdr.p_memsz, TlsPhdr.p_align); 1164 Phdrs[++PhdrIdx] = TlsPhdr; 1165 Out<ELFT>::TlsPhdr = &Phdrs[PhdrIdx]; 1166 } 1167 1168 // Add an entry for .dynamic. 1169 if (isOutputDynamic()) { 1170 Elf_Phdr *PH = &Phdrs[++PhdrIdx]; 1171 PH->p_type = PT_DYNAMIC; 1172 copyPhdr(PH, Out<ELFT>::Dynamic); 1173 } 1174 1175 if (HasRelro) { 1176 Elf_Phdr *PH = &Phdrs[++PhdrIdx]; 1177 *PH = GnuRelroPhdr; 1178 } 1179 1180 if (Out<ELFT>::EhFrameHdr->Live) { 1181 Elf_Phdr *PH = &Phdrs[++PhdrIdx]; 1182 PH->p_type = PT_GNU_EH_FRAME; 1183 copyPhdr(PH, Out<ELFT>::EhFrameHdr); 1184 } 1185 1186 // PT_GNU_STACK is a special section to tell the loader to make the 1187 // pages for the stack non-executable. 1188 if (!Config->ZExecStack) { 1189 Elf_Phdr *PH = &Phdrs[++PhdrIdx]; 1190 PH->p_type = PT_GNU_STACK; 1191 PH->p_flags = PF_R | PF_W; 1192 } 1193 1194 // Fix up PT_INTERP as we now know the address of .interp section. 1195 if (Interp) { 1196 Interp->p_type = PT_INTERP; 1197 copyPhdr(Interp, Out<ELFT>::Interp); 1198 } 1199 1200 // Add space for section headers. 1201 SectionHeaderOff = alignTo(FileOff, ELFT::Is64Bits ? 8 : 4); 1202 FileSize = SectionHeaderOff + getNumSections() * sizeof(Elf_Shdr); 1203 1204 // Update "_end" and "end" symbols so that they 1205 // point to the end of the data segment. 1206 ElfSym<ELFT>::End.st_value = VA; 1207 } 1208 1209 // Returns the number of PHDR entries. 1210 template <class ELFT> int Writer<ELFT>::getPhdrsNum() const { 1211 bool Tls = false; 1212 int I = 2; // 2 for PT_PHDR and first PT_LOAD 1213 if (needsInterpSection()) 1214 ++I; 1215 if (isOutputDynamic()) 1216 ++I; 1217 if (!Config->ZExecStack) 1218 ++I; 1219 uintX_t Last = PF_R; 1220 for (OutputSectionBase<ELFT> *Sec : OutputSections) { 1221 if (!needsPhdr<ELFT>(Sec)) 1222 continue; 1223 if (Sec->getFlags() & SHF_TLS) 1224 Tls = true; 1225 uintX_t Flags = toPhdrFlags(Sec->getFlags()); 1226 if (Last != Flags) { 1227 Last = Flags; 1228 ++I; 1229 } 1230 } 1231 if (Tls) 1232 ++I; 1233 if (HasRelro) 1234 ++I; 1235 if (Out<ELFT>::EhFrameHdr->Live) 1236 ++I; 1237 return I; 1238 } 1239 1240 static uint32_t getELFFlags() { 1241 if (Config->EMachine != EM_MIPS) 1242 return 0; 1243 // FIXME: In fact ELF flags depends on ELF flags of input object files 1244 // and selected emulation. For now just use hard coded values. 1245 uint32_t V = EF_MIPS_ABI_O32 | EF_MIPS_CPIC | EF_MIPS_ARCH_32R2; 1246 if (Config->Shared) 1247 V |= EF_MIPS_PIC; 1248 return V; 1249 } 1250 1251 template <class ELFT> 1252 static typename ELFFile<ELFT>::uintX_t getEntryAddr() { 1253 if (Config->EntrySym) { 1254 if (SymbolBody *E = Config->EntrySym->repl()) 1255 return getSymVA<ELFT>(*E); 1256 return 0; 1257 } 1258 if (Config->EntryAddr != uint64_t(-1)) 1259 return Config->EntryAddr; 1260 return 0; 1261 } 1262 1263 // This function is called after we have assigned address and size 1264 // to each section. This function fixes some predefined absolute 1265 // symbol values that depend on section address and size. 1266 template <class ELFT> void Writer<ELFT>::fixAbsoluteSymbols() { 1267 // Update __rel[a]_iplt_{start,end} symbols so that they point 1268 // to beginning or ending of .rela.plt section, respectively. 1269 if (Out<ELFT>::RelaPlt) { 1270 uintX_t Start = Out<ELFT>::RelaPlt->getVA(); 1271 ElfSym<ELFT>::RelaIpltStart.st_value = Start; 1272 ElfSym<ELFT>::RelaIpltEnd.st_value = Start + Out<ELFT>::RelaPlt->getSize(); 1273 } 1274 1275 // Update MIPS _gp absolute symbol so that it points to the static data. 1276 if (Config->EMachine == EM_MIPS) 1277 ElfSym<ELFT>::MipsGp.st_value = getMipsGpAddr<ELFT>(); 1278 } 1279 1280 template <class ELFT> void Writer<ELFT>::writeHeader() { 1281 uint8_t *Buf = Buffer->getBufferStart(); 1282 memcpy(Buf, "\177ELF", 4); 1283 1284 // Write the ELF header. 1285 auto *EHdr = reinterpret_cast<Elf_Ehdr *>(Buf); 1286 EHdr->e_ident[EI_CLASS] = ELFT::Is64Bits ? ELFCLASS64 : ELFCLASS32; 1287 EHdr->e_ident[EI_DATA] = ELFT::TargetEndianness == llvm::support::little 1288 ? ELFDATA2LSB 1289 : ELFDATA2MSB; 1290 EHdr->e_ident[EI_VERSION] = EV_CURRENT; 1291 1292 auto &FirstObj = cast<ELFFileBase<ELFT>>(*Config->FirstElf); 1293 EHdr->e_ident[EI_OSABI] = FirstObj.getOSABI(); 1294 1295 EHdr->e_type = Config->Shared ? ET_DYN : ET_EXEC; 1296 EHdr->e_machine = FirstObj.getEMachine(); 1297 EHdr->e_version = EV_CURRENT; 1298 EHdr->e_entry = getEntryAddr<ELFT>(); 1299 EHdr->e_phoff = sizeof(Elf_Ehdr); 1300 EHdr->e_shoff = SectionHeaderOff; 1301 EHdr->e_flags = getELFFlags(); 1302 EHdr->e_ehsize = sizeof(Elf_Ehdr); 1303 EHdr->e_phentsize = sizeof(Elf_Phdr); 1304 EHdr->e_phnum = Phdrs.size(); 1305 EHdr->e_shentsize = sizeof(Elf_Shdr); 1306 EHdr->e_shnum = getNumSections(); 1307 EHdr->e_shstrndx = Out<ELFT>::ShStrTab->SectionIndex; 1308 1309 // Write the program header table. 1310 memcpy(Buf + EHdr->e_phoff, &Phdrs[0], Phdrs.size() * sizeof(Phdrs[0])); 1311 1312 // Write the section header table. Note that the first table entry is null. 1313 auto SHdrs = reinterpret_cast<Elf_Shdr *>(Buf + EHdr->e_shoff); 1314 for (OutputSectionBase<ELFT> *Sec : OutputSections) 1315 Sec->writeHeaderTo(++SHdrs); 1316 } 1317 1318 template <class ELFT> void Writer<ELFT>::openFile(StringRef Path) { 1319 ErrorOr<std::unique_ptr<FileOutputBuffer>> BufferOrErr = 1320 FileOutputBuffer::create(Path, FileSize, FileOutputBuffer::F_executable); 1321 error(BufferOrErr, "failed to open " + Path); 1322 Buffer = std::move(*BufferOrErr); 1323 } 1324 1325 // Write section contents to a mmap'ed file. 1326 template <class ELFT> void Writer<ELFT>::writeSections() { 1327 uint8_t *Buf = Buffer->getBufferStart(); 1328 1329 // PPC64 needs to process relocations in the .opd section before processing 1330 // relocations in code-containing sections. 1331 if (OutputSectionBase<ELFT> *Sec = Out<ELFT>::Opd) { 1332 Out<ELFT>::OpdBuf = Buf + Sec->getFileOff(); 1333 Sec->writeTo(Buf + Sec->getFileOff()); 1334 } 1335 1336 // Write all sections but string table sections. We know the sizes of the 1337 // string tables already, but they may not have actual strings yet (only 1338 // room may be reserved), because writeTo() is allowed to add actual 1339 // strings to the string tables. 1340 for (OutputSectionBase<ELFT> *Sec : OutputSections) 1341 if (Sec != Out<ELFT>::Opd && Sec->getType() != SHT_STRTAB) 1342 Sec->writeTo(Buf + Sec->getFileOff()); 1343 1344 // Write string table sections. 1345 for (OutputSectionBase<ELFT> *Sec : OutputSections) 1346 if (Sec != Out<ELFT>::Opd && Sec->getType() == SHT_STRTAB) 1347 Sec->writeTo(Buf + Sec->getFileOff()); 1348 } 1349 1350 template <class ELFT> 1351 void Writer<ELFT>::setPhdr(Elf_Phdr *PH, uint32_t Type, uint32_t Flags, 1352 uintX_t FileOff, uintX_t VA, uintX_t Size, 1353 uintX_t Align) { 1354 PH->p_type = Type; 1355 PH->p_flags = Flags; 1356 PH->p_offset = FileOff; 1357 PH->p_vaddr = VA; 1358 PH->p_paddr = VA; 1359 PH->p_filesz = Size; 1360 PH->p_memsz = Size; 1361 PH->p_align = Align; 1362 } 1363 1364 template <class ELFT> 1365 void Writer<ELFT>::copyPhdr(Elf_Phdr *PH, OutputSectionBase<ELFT> *From) { 1366 PH->p_flags = toPhdrFlags(From->getFlags()); 1367 PH->p_offset = From->getFileOff(); 1368 PH->p_vaddr = From->getVA(); 1369 PH->p_paddr = From->getVA(); 1370 PH->p_filesz = From->getSize(); 1371 PH->p_memsz = From->getSize(); 1372 PH->p_align = From->getAlign(); 1373 } 1374 1375 template <class ELFT> void Writer<ELFT>::buildSectionMap() { 1376 for (const std::pair<StringRef, std::vector<StringRef>> &OutSec : 1377 Config->OutputSections) 1378 for (StringRef Name : OutSec.second) 1379 InputToOutputSection[Name] = OutSec.first; 1380 } 1381 1382 template void elf2::writeResult<ELF32LE>(SymbolTable<ELF32LE> *Symtab); 1383 template void elf2::writeResult<ELF32BE>(SymbolTable<ELF32BE> *Symtab); 1384 template void elf2::writeResult<ELF64LE>(SymbolTable<ELF64LE> *Symtab); 1385 template void elf2::writeResult<ELF64BE>(SymbolTable<ELF64BE> *Symtab); 1386