1 //===- LinkerScript.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 // This file contains the parser/evaluator of the linker script. 11 // It parses a linker script and write the result to Config or ScriptConfig 12 // objects. 13 // 14 // If SECTIONS command is used, a ScriptConfig contains an AST 15 // of the command which will later be consumed by createSections() and 16 // assignAddresses(). 17 // 18 //===----------------------------------------------------------------------===// 19 20 #include "LinkerScript.h" 21 #include "Config.h" 22 #include "Driver.h" 23 #include "InputSection.h" 24 #include "Memory.h" 25 #include "OutputSections.h" 26 #include "ScriptParser.h" 27 #include "Strings.h" 28 #include "SymbolTable.h" 29 #include "Symbols.h" 30 #include "Target.h" 31 #include "Writer.h" 32 #include "llvm/ADT/STLExtras.h" 33 #include "llvm/ADT/SmallString.h" 34 #include "llvm/ADT/StringRef.h" 35 #include "llvm/ADT/StringSwitch.h" 36 #include "llvm/Support/Casting.h" 37 #include "llvm/Support/ELF.h" 38 #include "llvm/Support/Endian.h" 39 #include "llvm/Support/ErrorHandling.h" 40 #include "llvm/Support/FileSystem.h" 41 #include "llvm/Support/MathExtras.h" 42 #include "llvm/Support/MemoryBuffer.h" 43 #include "llvm/Support/Path.h" 44 #include <algorithm> 45 #include <cassert> 46 #include <cstddef> 47 #include <cstdint> 48 #include <iterator> 49 #include <limits> 50 #include <memory> 51 #include <string> 52 #include <tuple> 53 #include <vector> 54 55 using namespace llvm; 56 using namespace llvm::ELF; 57 using namespace llvm::object; 58 using namespace llvm::support::endian; 59 using namespace lld; 60 using namespace lld::elf; 61 62 LinkerScriptBase *elf::ScriptBase; 63 ScriptConfiguration *elf::ScriptConfig; 64 65 template <class ELFT> static void addRegular(SymbolAssignment *Cmd) { 66 uint8_t Visibility = Cmd->Hidden ? STV_HIDDEN : STV_DEFAULT; 67 Symbol *Sym = Symtab<ELFT>::X->addRegular(Cmd->Name, Visibility, STT_NOTYPE, 68 0, 0, STB_GLOBAL, nullptr); 69 Cmd->Sym = Sym->body(); 70 71 // If we have no SECTIONS then we don't have '.' and don't call 72 // assignAddresses(). We calculate symbol value immediately in this case. 73 if (!ScriptConfig->HasSections) 74 cast<DefinedRegular<ELFT>>(Cmd->Sym)->Value = Cmd->Expression(0); 75 } 76 77 template <class ELFT> static void addSynthetic(SymbolAssignment *Cmd) { 78 Symbol *Sym = Symtab<ELFT>::X->addSynthetic( 79 Cmd->Name, nullptr, 0, Cmd->Hidden ? STV_HIDDEN : STV_DEFAULT); 80 Cmd->Sym = Sym->body(); 81 } 82 83 template <class ELFT> static void addSymbol(SymbolAssignment *Cmd) { 84 if (Cmd->Expression.IsAbsolute()) 85 addRegular<ELFT>(Cmd); 86 else 87 addSynthetic<ELFT>(Cmd); 88 } 89 // If a symbol was in PROVIDE(), we need to define it only when 90 // it is an undefined symbol. 91 template <class ELFT> static bool shouldDefine(SymbolAssignment *Cmd) { 92 if (Cmd->Name == ".") 93 return false; 94 if (!Cmd->Provide) 95 return true; 96 SymbolBody *B = Symtab<ELFT>::X->find(Cmd->Name); 97 return B && B->isUndefined(); 98 } 99 100 bool SymbolAssignment::classof(const BaseCommand *C) { 101 return C->Kind == AssignmentKind; 102 } 103 104 bool OutputSectionCommand::classof(const BaseCommand *C) { 105 return C->Kind == OutputSectionKind; 106 } 107 108 bool InputSectionDescription::classof(const BaseCommand *C) { 109 return C->Kind == InputSectionKind; 110 } 111 112 bool AssertCommand::classof(const BaseCommand *C) { 113 return C->Kind == AssertKind; 114 } 115 116 bool BytesDataCommand::classof(const BaseCommand *C) { 117 return C->Kind == BytesDataKind; 118 } 119 120 template <class ELFT> LinkerScript<ELFT>::LinkerScript() = default; 121 template <class ELFT> LinkerScript<ELFT>::~LinkerScript() = default; 122 123 template <class ELFT> 124 bool LinkerScript<ELFT>::shouldKeep(InputSectionBase<ELFT> *S) { 125 for (InputSectionDescription *ID : Opt.KeptSections) { 126 StringRef Filename = S->getFile()->getName(); 127 if (!ID->FilePat.match(sys::path::filename(Filename))) 128 continue; 129 130 for (SectionPattern &P : ID->SectionPatterns) 131 if (P.SectionPat.match(S->Name)) 132 return true; 133 } 134 return false; 135 } 136 137 static bool comparePriority(InputSectionData *A, InputSectionData *B) { 138 return getPriority(A->Name) < getPriority(B->Name); 139 } 140 141 static bool compareName(InputSectionData *A, InputSectionData *B) { 142 return A->Name < B->Name; 143 } 144 145 static bool compareAlignment(InputSectionData *A, InputSectionData *B) { 146 // ">" is not a mistake. Larger alignments are placed before smaller 147 // alignments in order to reduce the amount of padding necessary. 148 // This is compatible with GNU. 149 return A->Alignment > B->Alignment; 150 } 151 152 static std::function<bool(InputSectionData *, InputSectionData *)> 153 getComparator(SortSectionPolicy K) { 154 switch (K) { 155 case SortSectionPolicy::Alignment: 156 return compareAlignment; 157 case SortSectionPolicy::Name: 158 return compareName; 159 case SortSectionPolicy::Priority: 160 return comparePriority; 161 default: 162 llvm_unreachable("unknown sort policy"); 163 } 164 } 165 166 template <class ELFT> 167 static bool matchConstraints(ArrayRef<InputSectionBase<ELFT> *> Sections, 168 ConstraintKind Kind) { 169 if (Kind == ConstraintKind::NoConstraint) 170 return true; 171 bool IsRW = llvm::any_of(Sections, [=](InputSectionData *Sec2) { 172 auto *Sec = static_cast<InputSectionBase<ELFT> *>(Sec2); 173 return Sec->Flags & SHF_WRITE; 174 }); 175 return (IsRW && Kind == ConstraintKind::ReadWrite) || 176 (!IsRW && Kind == ConstraintKind::ReadOnly); 177 } 178 179 static void sortSections(InputSectionData **Begin, InputSectionData **End, 180 SortSectionPolicy K) { 181 if (K != SortSectionPolicy::Default && K != SortSectionPolicy::None) 182 std::stable_sort(Begin, End, getComparator(K)); 183 } 184 185 // Compute and remember which sections the InputSectionDescription matches. 186 template <class ELFT> 187 void LinkerScript<ELFT>::computeInputSections(InputSectionDescription *I) { 188 // Collects all sections that satisfy constraints of I 189 // and attach them to I. 190 for (SectionPattern &Pat : I->SectionPatterns) { 191 size_t SizeBefore = I->Sections.size(); 192 193 for (InputSectionBase<ELFT> *S : Symtab<ELFT>::X->Sections) { 194 if (!S->Live || S->OutSec) 195 continue; 196 197 StringRef Filename; 198 if (elf::ObjectFile<ELFT> *F = S->getFile()) 199 Filename = sys::path::filename(F->getName()); 200 201 if (I->FilePat.match(Filename) && !Pat.ExcludedFilePat.match(Filename) && 202 Pat.SectionPat.match(S->Name)) 203 I->Sections.push_back(S); 204 } 205 206 // Sort sections as instructed by SORT-family commands and --sort-section 207 // option. Because SORT-family commands can be nested at most two depth 208 // (e.g. SORT_BY_NAME(SORT_BY_ALIGNMENT(.text.*))) and because the command 209 // line option is respected even if a SORT command is given, the exact 210 // behavior we have here is a bit complicated. Here are the rules. 211 // 212 // 1. If two SORT commands are given, --sort-section is ignored. 213 // 2. If one SORT command is given, and if it is not SORT_NONE, 214 // --sort-section is handled as an inner SORT command. 215 // 3. If one SORT command is given, and if it is SORT_NONE, don't sort. 216 // 4. If no SORT command is given, sort according to --sort-section. 217 InputSectionData **Begin = I->Sections.data() + SizeBefore; 218 InputSectionData **End = I->Sections.data() + I->Sections.size(); 219 if (Pat.SortOuter != SortSectionPolicy::None) { 220 if (Pat.SortInner == SortSectionPolicy::Default) 221 sortSections(Begin, End, Config->SortSection); 222 else 223 sortSections(Begin, End, Pat.SortInner); 224 sortSections(Begin, End, Pat.SortOuter); 225 } 226 } 227 228 // We do not add duplicate input sections, so mark them with a dummy output 229 // section for now. 230 for (InputSectionData *S : I->Sections) { 231 auto *S2 = static_cast<InputSectionBase<ELFT> *>(S); 232 S2->OutSec = (OutputSectionBase *)-1; 233 } 234 } 235 236 template <class ELFT> 237 void LinkerScript<ELFT>::discard(ArrayRef<InputSectionBase<ELFT> *> V) { 238 for (InputSectionBase<ELFT> *S : V) { 239 S->Live = false; 240 reportDiscarded(S); 241 } 242 } 243 244 template <class ELFT> 245 std::vector<InputSectionBase<ELFT> *> 246 LinkerScript<ELFT>::createInputSectionList(OutputSectionCommand &OutCmd) { 247 std::vector<InputSectionBase<ELFT> *> Ret; 248 249 for (const std::unique_ptr<BaseCommand> &Base : OutCmd.Commands) { 250 auto *Cmd = dyn_cast<InputSectionDescription>(Base.get()); 251 if (!Cmd) 252 continue; 253 computeInputSections(Cmd); 254 for (InputSectionData *S : Cmd->Sections) 255 Ret.push_back(static_cast<InputSectionBase<ELFT> *>(S)); 256 } 257 258 // After we created final list we should now set OutSec pointer to null, 259 // instead of -1. Otherwise we may get a crash when writing relocs, in 260 // case section is discarded by linker script 261 for (InputSectionBase<ELFT> *S : Ret) 262 S->OutSec = nullptr; 263 264 return Ret; 265 } 266 267 template <class ELFT> 268 static SectionKey<ELFT::Is64Bits> createKey(InputSectionBase<ELFT> *C, 269 StringRef OutsecName) { 270 // When using linker script the merge rules are different. 271 // Unfortunately, linker scripts are name based. This means that expressions 272 // like *(.foo*) can refer to multiple input sections that would normally be 273 // placed in different output sections. We cannot put them in different 274 // output sections or we would produce wrong results for 275 // start = .; *(.foo.*) end = .; *(.bar) 276 // and a mapping of .foo1 and .bar1 to one section and .foo2 and .bar2 to 277 // another. The problem is that there is no way to layout those output 278 // sections such that the .foo sections are the only thing between the 279 // start and end symbols. 280 281 // An extra annoyance is that we cannot simply disable merging of the contents 282 // of SHF_MERGE sections, but our implementation requires one output section 283 // per "kind" (string or not, which size/aligment). 284 // Fortunately, creating symbols in the middle of a merge section is not 285 // supported by bfd or gold, so we can just create multiple section in that 286 // case. 287 typedef typename ELFT::uint uintX_t; 288 uintX_t Flags = C->Flags & (SHF_MERGE | SHF_STRINGS); 289 290 uintX_t Alignment = 0; 291 if (isa<MergeInputSection<ELFT>>(C)) 292 Alignment = std::max<uintX_t>(C->Alignment, C->Entsize); 293 294 return SectionKey<ELFT::Is64Bits>{OutsecName, /*Type*/ 0, Flags, Alignment}; 295 } 296 297 template <class ELFT> 298 void LinkerScript<ELFT>::addSection(OutputSectionFactory<ELFT> &Factory, 299 InputSectionBase<ELFT> *Sec, 300 StringRef Name) { 301 OutputSectionBase *OutSec; 302 bool IsNew; 303 std::tie(OutSec, IsNew) = Factory.create(createKey(Sec, Name), Sec); 304 if (IsNew) 305 OutputSections->push_back(OutSec); 306 OutSec->addSection(Sec); 307 } 308 309 template <class ELFT> 310 void LinkerScript<ELFT>::processCommands(OutputSectionFactory<ELFT> &Factory) { 311 for (unsigned I = 0; I < Opt.Commands.size(); ++I) { 312 auto Iter = Opt.Commands.begin() + I; 313 const std::unique_ptr<BaseCommand> &Base1 = *Iter; 314 if (auto *Cmd = dyn_cast<SymbolAssignment>(Base1.get())) { 315 if (shouldDefine<ELFT>(Cmd)) 316 addSymbol<ELFT>(Cmd); 317 continue; 318 } 319 if (auto *Cmd = dyn_cast<AssertCommand>(Base1.get())) { 320 // If we don't have SECTIONS then output sections have already been 321 // created by Writer<ELFT>. The LinkerScript<ELFT>::assignAddresses 322 // will not be called, so ASSERT should be evaluated now. 323 if (!Opt.HasSections) 324 Cmd->Expression(0); 325 continue; 326 } 327 328 if (auto *Cmd = dyn_cast<OutputSectionCommand>(Base1.get())) { 329 std::vector<InputSectionBase<ELFT> *> V = createInputSectionList(*Cmd); 330 331 if (Cmd->Name == "/DISCARD/") { 332 discard(V); 333 continue; 334 } 335 336 if (!matchConstraints<ELFT>(V, Cmd->Constraint)) { 337 for (InputSectionBase<ELFT> *S : V) 338 S->OutSec = nullptr; 339 Opt.Commands.erase(Iter); 340 --I; 341 continue; 342 } 343 344 for (const std::unique_ptr<BaseCommand> &Base : Cmd->Commands) 345 if (auto *OutCmd = dyn_cast<SymbolAssignment>(Base.get())) 346 if (shouldDefine<ELFT>(OutCmd)) 347 addSymbol<ELFT>(OutCmd); 348 349 if (V.empty()) 350 continue; 351 352 for (InputSectionBase<ELFT> *Sec : V) { 353 addSection(Factory, Sec, Cmd->Name); 354 if (uint32_t Subalign = Cmd->SubalignExpr ? Cmd->SubalignExpr(0) : 0) 355 Sec->Alignment = Subalign; 356 } 357 } 358 } 359 } 360 361 template <class ELFT> 362 void LinkerScript<ELFT>::createSections(OutputSectionFactory<ELFT> &Factory) { 363 processCommands(Factory); 364 365 // Add orphan sections. 366 for (InputSectionBase<ELFT> *S : Symtab<ELFT>::X->Sections) 367 if (S->Live && !S->OutSec) 368 addSection(Factory, S, getOutputSectionName(S->Name)); 369 } 370 371 // Sets value of a section-defined symbol. Two kinds of 372 // symbols are processed: synthetic symbols, whose value 373 // is an offset from beginning of section and regular 374 // symbols whose value is absolute. 375 template <class ELFT> 376 static void assignSectionSymbol(SymbolAssignment *Cmd, OutputSectionBase *Sec, 377 typename ELFT::uint Value) { 378 if (!Cmd->Sym) 379 return; 380 381 if (auto *Body = dyn_cast<DefinedSynthetic<ELFT>>(Cmd->Sym)) { 382 Body->Section = Sec; 383 Body->Value = Cmd->Expression(Value) - Sec->Addr; 384 return; 385 } 386 auto *Body = cast<DefinedRegular<ELFT>>(Cmd->Sym); 387 Body->Value = Cmd->Expression(Value); 388 } 389 390 template <class ELFT> static bool isTbss(OutputSectionBase *Sec) { 391 return (Sec->Flags & SHF_TLS) && Sec->Type == SHT_NOBITS; 392 } 393 394 template <class ELFT> void LinkerScript<ELFT>::output(InputSection<ELFT> *S) { 395 if (!AlreadyOutputIS.insert(S).second) 396 return; 397 bool IsTbss = isTbss<ELFT>(CurOutSec); 398 399 uintX_t Pos = IsTbss ? Dot + ThreadBssOffset : Dot; 400 Pos = alignTo(Pos, S->Alignment); 401 S->OutSecOff = Pos - CurOutSec->Addr; 402 Pos += S->getSize(); 403 404 // Update output section size after adding each section. This is so that 405 // SIZEOF works correctly in the case below: 406 // .foo { *(.aaa) a = SIZEOF(.foo); *(.bbb) } 407 CurOutSec->Size = Pos - CurOutSec->Addr; 408 409 if (IsTbss) 410 ThreadBssOffset = Pos - Dot; 411 else 412 Dot = Pos; 413 } 414 415 template <class ELFT> void LinkerScript<ELFT>::flush() { 416 if (!CurOutSec || !AlreadyOutputOS.insert(CurOutSec).second) 417 return; 418 if (auto *OutSec = dyn_cast<OutputSection<ELFT>>(CurOutSec)) { 419 for (InputSection<ELFT> *I : OutSec->Sections) 420 output(I); 421 } else { 422 Dot += CurOutSec->Size; 423 } 424 } 425 426 template <class ELFT> 427 void LinkerScript<ELFT>::switchTo(OutputSectionBase *Sec) { 428 if (CurOutSec == Sec) 429 return; 430 if (AlreadyOutputOS.count(Sec)) 431 return; 432 433 flush(); 434 CurOutSec = Sec; 435 436 Dot = alignTo(Dot, CurOutSec->Addralign); 437 CurOutSec->Addr = isTbss<ELFT>(CurOutSec) ? Dot + ThreadBssOffset : Dot; 438 439 // If neither AT nor AT> is specified for an allocatable section, the linker 440 // will set the LMA such that the difference between VMA and LMA for the 441 // section is the same as the preceding output section in the same region 442 // https://sourceware.org/binutils/docs-2.20/ld/Output-Section-LMA.html 443 CurOutSec->setLMAOffset(LMAOffset); 444 } 445 446 template <class ELFT> void LinkerScript<ELFT>::process(BaseCommand &Base) { 447 // This handles the assignments to symbol or to a location counter (.) 448 if (auto *AssignCmd = dyn_cast<SymbolAssignment>(&Base)) { 449 if (AssignCmd->Name == ".") { 450 // Update to location counter means update to section size. 451 Dot = AssignCmd->Expression(Dot); 452 CurOutSec->Size = Dot - CurOutSec->Addr; 453 return; 454 } 455 assignSectionSymbol<ELFT>(AssignCmd, CurOutSec, Dot); 456 return; 457 } 458 459 // Handle BYTE(), SHORT(), LONG(), or QUAD(). 460 if (auto *DataCmd = dyn_cast<BytesDataCommand>(&Base)) { 461 DataCmd->Offset = Dot - CurOutSec->Addr; 462 Dot += DataCmd->Size; 463 CurOutSec->Size = Dot - CurOutSec->Addr; 464 return; 465 } 466 467 // It handles single input section description command, 468 // calculates and assigns the offsets for each section and also 469 // updates the output section size. 470 auto &ICmd = cast<InputSectionDescription>(Base); 471 for (InputSectionData *ID : ICmd.Sections) { 472 auto *IB = static_cast<InputSectionBase<ELFT> *>(ID); 473 switchTo(IB->OutSec); 474 if (auto *I = dyn_cast<InputSection<ELFT>>(IB)) 475 output(I); 476 else 477 flush(); 478 } 479 } 480 481 template <class ELFT> 482 static std::vector<OutputSectionBase *> 483 findSections(StringRef Name, const std::vector<OutputSectionBase *> &Sections) { 484 std::vector<OutputSectionBase *> Ret; 485 for (OutputSectionBase *Sec : Sections) 486 if (Sec->getName() == Name) 487 Ret.push_back(Sec); 488 return Ret; 489 } 490 491 template <class ELFT> 492 void LinkerScript<ELFT>::assignOffsets(OutputSectionCommand *Cmd) { 493 if (Cmd->LMAExpr) 494 LMAOffset = Cmd->LMAExpr(Dot) - Dot; 495 std::vector<OutputSectionBase *> Sections = 496 findSections<ELFT>(Cmd->Name, *OutputSections); 497 if (Sections.empty()) 498 return; 499 switchTo(Sections[0]); 500 // Find the last section output location. We will output orphan sections 501 // there so that end symbols point to the correct location. 502 auto E = std::find_if(Cmd->Commands.rbegin(), Cmd->Commands.rend(), 503 [](const std::unique_ptr<BaseCommand> &Cmd) { 504 return !isa<SymbolAssignment>(*Cmd); 505 }) 506 .base(); 507 for (auto I = Cmd->Commands.begin(); I != E; ++I) 508 process(**I); 509 for (OutputSectionBase *Base : Sections) 510 switchTo(Base); 511 flush(); 512 std::for_each(E, Cmd->Commands.end(), 513 [this](std::unique_ptr<BaseCommand> &B) { process(*B.get()); }); 514 } 515 516 template <class ELFT> void LinkerScript<ELFT>::adjustSectionsBeforeSorting() { 517 // It is common practice to use very generic linker scripts. So for any 518 // given run some of the output sections in the script will be empty. 519 // We could create corresponding empty output sections, but that would 520 // clutter the output. 521 // We instead remove trivially empty sections. The bfd linker seems even 522 // more aggressive at removing them. 523 auto Pos = std::remove_if( 524 Opt.Commands.begin(), Opt.Commands.end(), 525 [&](const std::unique_ptr<BaseCommand> &Base) { 526 auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get()); 527 if (!Cmd) 528 return false; 529 std::vector<OutputSectionBase *> Secs = 530 findSections<ELFT>(Cmd->Name, *OutputSections); 531 if (!Secs.empty()) 532 return false; 533 for (const std::unique_ptr<BaseCommand> &I : Cmd->Commands) 534 if (!isa<InputSectionDescription>(I.get())) 535 return false; 536 return true; 537 }); 538 Opt.Commands.erase(Pos, Opt.Commands.end()); 539 540 // If the output section contains only symbol assignments, create a 541 // corresponding output section. The bfd linker seems to only create them if 542 // '.' is assigned to, but creating these section should not have any bad 543 // consequeces and gives us a section to put the symbol in. 544 uintX_t Flags = SHF_ALLOC; 545 uint32_t Type = 0; 546 for (const std::unique_ptr<BaseCommand> &Base : Opt.Commands) { 547 auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get()); 548 if (!Cmd) 549 continue; 550 std::vector<OutputSectionBase *> Secs = 551 findSections<ELFT>(Cmd->Name, *OutputSections); 552 if (!Secs.empty()) { 553 Flags = Secs[0]->Flags; 554 Type = Secs[0]->Type; 555 continue; 556 } 557 558 auto *OutSec = make<OutputSection<ELFT>>(Cmd->Name, Type, Flags); 559 OutputSections->push_back(OutSec); 560 } 561 } 562 563 // When placing orphan sections, we want to place them after symbol assignments 564 // so that an orphan after 565 // begin_foo = .; 566 // foo : { *(foo) } 567 // end_foo = .; 568 // doesn't break the intended meaning of the begin/end symbols. 569 // We don't want to go over sections since Writer<ELFT>::sortSections is the 570 // one in charge of deciding the order of the sections. 571 // We don't want to go over alignments, since doing so in 572 // rx_sec : { *(rx_sec) } 573 // . = ALIGN(0x1000); 574 // /* The RW PT_LOAD starts here*/ 575 // rw_sec : { *(rw_sec) } 576 // would mean that the RW PT_LOAD would become unaligned. 577 static bool shouldSkip(const BaseCommand &Cmd) { 578 if (isa<OutputSectionCommand>(Cmd)) 579 return false; 580 const auto *Assign = dyn_cast<SymbolAssignment>(&Cmd); 581 if (!Assign) 582 return true; 583 return Assign->Name != "."; 584 } 585 586 template <class ELFT> 587 void LinkerScript<ELFT>::assignAddresses(std::vector<PhdrEntry<ELFT>> &Phdrs) { 588 // Orphan sections are sections present in the input files which 589 // are not explicitly placed into the output file by the linker script. 590 // We place orphan sections at end of file. 591 // Other linkers places them using some heuristics as described in 592 // https://sourceware.org/binutils/docs/ld/Orphan-Sections.html#Orphan-Sections. 593 594 // The OutputSections are already in the correct order. 595 // This loops creates or moves commands as needed so that they are in the 596 // correct order. 597 int CmdIndex = 0; 598 for (OutputSectionBase *Sec : *OutputSections) { 599 StringRef Name = Sec->getName(); 600 601 // Find the last spot where we can insert a command and still get the 602 // correct result. 603 auto CmdIter = Opt.Commands.begin() + CmdIndex; 604 auto E = Opt.Commands.end(); 605 while (CmdIter != E && shouldSkip(**CmdIter)) { 606 ++CmdIter; 607 ++CmdIndex; 608 } 609 610 auto Pos = 611 std::find_if(CmdIter, E, [&](const std::unique_ptr<BaseCommand> &Base) { 612 auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get()); 613 return Cmd && Cmd->Name == Name; 614 }); 615 if (Pos == E) { 616 Opt.Commands.insert(CmdIter, 617 llvm::make_unique<OutputSectionCommand>(Name)); 618 ++CmdIndex; 619 continue; 620 } 621 622 // Continue from where we found it. 623 CmdIndex = (Pos - Opt.Commands.begin()) + 1; 624 } 625 626 // Assign addresses as instructed by linker script SECTIONS sub-commands. 627 Dot = 0; 628 629 for (const std::unique_ptr<BaseCommand> &Base : Opt.Commands) { 630 if (auto *Cmd = dyn_cast<SymbolAssignment>(Base.get())) { 631 if (Cmd->Name == ".") { 632 Dot = Cmd->Expression(Dot); 633 } else if (Cmd->Sym) { 634 assignSectionSymbol<ELFT>( 635 Cmd, CurOutSec ? CurOutSec : (*OutputSections)[0], Dot); 636 } 637 continue; 638 } 639 640 if (auto *Cmd = dyn_cast<AssertCommand>(Base.get())) { 641 Cmd->Expression(Dot); 642 continue; 643 } 644 645 auto *Cmd = cast<OutputSectionCommand>(Base.get()); 646 647 if (Cmd->AddrExpr) 648 Dot = Cmd->AddrExpr(Dot); 649 650 assignOffsets(Cmd); 651 } 652 653 uintX_t MinVA = std::numeric_limits<uintX_t>::max(); 654 for (OutputSectionBase *Sec : *OutputSections) { 655 if (Sec->Flags & SHF_ALLOC) 656 MinVA = std::min<uint64_t>(MinVA, Sec->Addr); 657 else 658 Sec->Addr = 0; 659 } 660 661 uintX_t HeaderSize = getHeaderSize(); 662 auto FirstPTLoad = 663 std::find_if(Phdrs.begin(), Phdrs.end(), [](const PhdrEntry<ELFT> &E) { 664 return E.H.p_type == PT_LOAD; 665 }); 666 667 if (HeaderSize <= MinVA && FirstPTLoad != Phdrs.end()) { 668 // If linker script specifies program headers and first PT_LOAD doesn't 669 // have both PHDRS and FILEHDR attributes then do nothing 670 if (!Opt.PhdrsCommands.empty()) { 671 size_t SegNum = std::distance(Phdrs.begin(), FirstPTLoad); 672 if (!Opt.PhdrsCommands[SegNum].HasPhdrs || 673 !Opt.PhdrsCommands[SegNum].HasFilehdr) 674 return; 675 } 676 // ELF and Program headers need to be right before the first section in 677 // memory. Set their addresses accordingly. 678 MinVA = alignDown(MinVA - HeaderSize, Target->PageSize); 679 Out<ELFT>::ElfHeader->Addr = MinVA; 680 Out<ELFT>::ProgramHeaders->Addr = Out<ELFT>::ElfHeader->Size + MinVA; 681 FirstPTLoad->First = Out<ELFT>::ElfHeader; 682 if (!FirstPTLoad->Last) 683 FirstPTLoad->Last = Out<ELFT>::ProgramHeaders; 684 } else if (!FirstPTLoad->First) { 685 // Sometimes the very first PT_LOAD segment can be empty. 686 // This happens if (all conditions met): 687 // - Linker script is used 688 // - First section in ELF image is not RO 689 // - Not enough space for program headers. 690 // The code below removes empty PT_LOAD segment and updates 691 // program headers size. 692 Phdrs.erase(FirstPTLoad); 693 Out<ELFT>::ProgramHeaders->Size = 694 sizeof(typename ELFT::Phdr) * Phdrs.size(); 695 } 696 } 697 698 // Creates program headers as instructed by PHDRS linker script command. 699 template <class ELFT> 700 std::vector<PhdrEntry<ELFT>> LinkerScript<ELFT>::createPhdrs() { 701 std::vector<PhdrEntry<ELFT>> Ret; 702 703 // Process PHDRS and FILEHDR keywords because they are not 704 // real output sections and cannot be added in the following loop. 705 std::vector<size_t> DefPhdrIds; 706 for (const PhdrsCommand &Cmd : Opt.PhdrsCommands) { 707 Ret.emplace_back(Cmd.Type, Cmd.Flags == UINT_MAX ? PF_R : Cmd.Flags); 708 PhdrEntry<ELFT> &Phdr = Ret.back(); 709 710 if (Cmd.HasFilehdr) 711 Phdr.add(Out<ELFT>::ElfHeader); 712 if (Cmd.HasPhdrs) 713 Phdr.add(Out<ELFT>::ProgramHeaders); 714 715 if (Cmd.LMAExpr) { 716 Phdr.H.p_paddr = Cmd.LMAExpr(0); 717 Phdr.HasLMA = true; 718 } 719 720 // If output section command doesn't specify any segments, 721 // and we haven't previously assigned any section to segment, 722 // then we simply assign section to the very first load segment. 723 // Below is an example of such linker script: 724 // PHDRS { seg PT_LOAD; } 725 // SECTIONS { .aaa : { *(.aaa) } } 726 if (DefPhdrIds.empty() && Phdr.H.p_type == PT_LOAD) 727 DefPhdrIds.push_back(Ret.size() - 1); 728 } 729 730 // Add output sections to program headers. 731 for (OutputSectionBase *Sec : *OutputSections) { 732 if (!(Sec->Flags & SHF_ALLOC)) 733 break; 734 735 std::vector<size_t> PhdrIds = getPhdrIndices(Sec->getName()); 736 if (PhdrIds.empty()) 737 PhdrIds = std::move(DefPhdrIds); 738 739 // Assign headers specified by linker script 740 for (size_t Id : PhdrIds) { 741 Ret[Id].add(Sec); 742 if (Opt.PhdrsCommands[Id].Flags == UINT_MAX) 743 Ret[Id].H.p_flags |= Sec->getPhdrFlags(); 744 } 745 DefPhdrIds = std::move(PhdrIds); 746 } 747 return Ret; 748 } 749 750 template <class ELFT> bool LinkerScript<ELFT>::ignoreInterpSection() { 751 // Ignore .interp section in case we have PHDRS specification 752 // and PT_INTERP isn't listed. 753 return !Opt.PhdrsCommands.empty() && 754 llvm::find_if(Opt.PhdrsCommands, [](const PhdrsCommand &Cmd) { 755 return Cmd.Type == PT_INTERP; 756 }) == Opt.PhdrsCommands.end(); 757 } 758 759 template <class ELFT> 760 ArrayRef<uint8_t> LinkerScript<ELFT>::getFiller(StringRef Name) { 761 for (const std::unique_ptr<BaseCommand> &Base : Opt.Commands) 762 if (auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get())) 763 if (Cmd->Name == Name) 764 return Cmd->Filler; 765 return {}; 766 } 767 768 template <class ELFT> 769 static void writeInt(uint8_t *Buf, uint64_t Data, uint64_t Size) { 770 const endianness E = ELFT::TargetEndianness; 771 772 switch (Size) { 773 case 1: 774 *Buf = (uint8_t)Data; 775 break; 776 case 2: 777 write16<E>(Buf, Data); 778 break; 779 case 4: 780 write32<E>(Buf, Data); 781 break; 782 case 8: 783 write64<E>(Buf, Data); 784 break; 785 default: 786 llvm_unreachable("unsupported Size argument"); 787 } 788 } 789 790 template <class ELFT> 791 void LinkerScript<ELFT>::writeDataBytes(StringRef Name, uint8_t *Buf) { 792 int I = getSectionIndex(Name); 793 if (I == INT_MAX) 794 return; 795 796 OutputSectionCommand *Cmd = 797 dyn_cast<OutputSectionCommand>(Opt.Commands[I].get()); 798 for (const std::unique_ptr<BaseCommand> &Base2 : Cmd->Commands) 799 if (auto *DataCmd = dyn_cast<BytesDataCommand>(Base2.get())) 800 writeInt<ELFT>(&Buf[DataCmd->Offset], DataCmd->Data, DataCmd->Size); 801 } 802 803 template <class ELFT> bool LinkerScript<ELFT>::hasLMA(StringRef Name) { 804 for (const std::unique_ptr<BaseCommand> &Base : Opt.Commands) 805 if (auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get())) 806 if (Cmd->LMAExpr && Cmd->Name == Name) 807 return true; 808 return false; 809 } 810 811 // Returns the index of the given section name in linker script 812 // SECTIONS commands. Sections are laid out as the same order as they 813 // were in the script. If a given name did not appear in the script, 814 // it returns INT_MAX, so that it will be laid out at end of file. 815 template <class ELFT> int LinkerScript<ELFT>::getSectionIndex(StringRef Name) { 816 int I = 0; 817 for (std::unique_ptr<BaseCommand> &Base : Opt.Commands) { 818 if (auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get())) 819 if (Cmd->Name == Name) 820 return I; 821 ++I; 822 } 823 return INT_MAX; 824 } 825 826 template <class ELFT> bool LinkerScript<ELFT>::hasPhdrsCommands() { 827 return !Opt.PhdrsCommands.empty(); 828 } 829 830 template <class ELFT> 831 uint64_t LinkerScript<ELFT>::getOutputSectionAddress(StringRef Name) { 832 for (OutputSectionBase *Sec : *OutputSections) 833 if (Sec->getName() == Name) 834 return Sec->Addr; 835 error("undefined section " + Name); 836 return 0; 837 } 838 839 template <class ELFT> 840 uint64_t LinkerScript<ELFT>::getOutputSectionLMA(StringRef Name) { 841 for (OutputSectionBase *Sec : *OutputSections) 842 if (Sec->getName() == Name) 843 return Sec->getLMA(); 844 error("undefined section " + Name); 845 return 0; 846 } 847 848 template <class ELFT> 849 uint64_t LinkerScript<ELFT>::getOutputSectionSize(StringRef Name) { 850 for (OutputSectionBase *Sec : *OutputSections) 851 if (Sec->getName() == Name) 852 return Sec->Size; 853 error("undefined section " + Name); 854 return 0; 855 } 856 857 template <class ELFT> 858 uint64_t LinkerScript<ELFT>::getOutputSectionAlign(StringRef Name) { 859 for (OutputSectionBase *Sec : *OutputSections) 860 if (Sec->getName() == Name) 861 return Sec->Addralign; 862 error("undefined section " + Name); 863 return 0; 864 } 865 866 template <class ELFT> uint64_t LinkerScript<ELFT>::getHeaderSize() { 867 return elf::getHeaderSize<ELFT>(); 868 } 869 870 template <class ELFT> uint64_t LinkerScript<ELFT>::getSymbolValue(StringRef S) { 871 if (SymbolBody *B = Symtab<ELFT>::X->find(S)) 872 return B->getVA<ELFT>(); 873 error("symbol not found: " + S); 874 return 0; 875 } 876 877 template <class ELFT> bool LinkerScript<ELFT>::isDefined(StringRef S) { 878 return Symtab<ELFT>::X->find(S) != nullptr; 879 } 880 881 template <class ELFT> bool LinkerScript<ELFT>::isAbsolute(StringRef S) { 882 SymbolBody *Sym = Symtab<ELFT>::X->find(S); 883 auto *DR = dyn_cast_or_null<DefinedRegular<ELFT>>(Sym); 884 return DR && !DR->Section; 885 } 886 887 // Returns indices of ELF headers containing specific section, identified 888 // by Name. Each index is a zero based number of ELF header listed within 889 // PHDRS {} script block. 890 template <class ELFT> 891 std::vector<size_t> LinkerScript<ELFT>::getPhdrIndices(StringRef SectionName) { 892 for (const std::unique_ptr<BaseCommand> &Base : Opt.Commands) { 893 auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get()); 894 if (!Cmd || Cmd->Name != SectionName) 895 continue; 896 897 std::vector<size_t> Ret; 898 for (StringRef PhdrName : Cmd->Phdrs) 899 Ret.push_back(getPhdrIndex(PhdrName)); 900 return Ret; 901 } 902 return {}; 903 } 904 905 template <class ELFT> 906 size_t LinkerScript<ELFT>::getPhdrIndex(StringRef PhdrName) { 907 size_t I = 0; 908 for (PhdrsCommand &Cmd : Opt.PhdrsCommands) { 909 if (Cmd.Name == PhdrName) 910 return I; 911 ++I; 912 } 913 error("section header '" + PhdrName + "' is not listed in PHDRS"); 914 return 0; 915 } 916 917 class elf::ScriptParser : public ScriptParserBase { 918 typedef void (ScriptParser::*Handler)(); 919 920 public: 921 ScriptParser(StringRef S, bool B) : ScriptParserBase(S), IsUnderSysroot(B) {} 922 923 void readLinkerScript(); 924 void readVersionScript(); 925 926 private: 927 void addFile(StringRef Path); 928 929 void readAsNeeded(); 930 void readEntry(); 931 void readExtern(); 932 void readGroup(); 933 void readInclude(); 934 void readOutput(); 935 void readOutputArch(); 936 void readOutputFormat(); 937 void readPhdrs(); 938 void readSearchDir(); 939 void readSections(); 940 void readVersion(); 941 void readVersionScriptCommand(); 942 943 SymbolAssignment *readAssignment(StringRef Name); 944 BytesDataCommand *readBytesDataCommand(StringRef Tok); 945 std::vector<uint8_t> readFill(); 946 OutputSectionCommand *readOutputSectionDescription(StringRef OutSec); 947 std::vector<uint8_t> readOutputSectionFiller(StringRef Tok); 948 std::vector<StringRef> readOutputSectionPhdrs(); 949 InputSectionDescription *readInputSectionDescription(StringRef Tok); 950 StringMatcher readFilePatterns(); 951 std::vector<SectionPattern> readInputSectionsList(); 952 InputSectionDescription *readInputSectionRules(StringRef FilePattern); 953 unsigned readPhdrType(); 954 SortSectionPolicy readSortKind(); 955 SymbolAssignment *readProvideHidden(bool Provide, bool Hidden); 956 SymbolAssignment *readProvideOrAssignment(StringRef Tok); 957 void readSort(); 958 Expr readAssert(); 959 960 Expr readExpr(); 961 Expr readExpr1(Expr Lhs, int MinPrec); 962 StringRef readParenLiteral(); 963 Expr readPrimary(); 964 Expr readTernary(Expr Cond); 965 Expr readParenExpr(); 966 967 // For parsing version script. 968 void readExtern(std::vector<SymbolVersion> *Globals); 969 void readVersionDeclaration(StringRef VerStr); 970 void readGlobal(StringRef VerStr); 971 void readLocal(StringRef VerStr); 972 973 ScriptConfiguration &Opt = *ScriptConfig; 974 bool IsUnderSysroot; 975 }; 976 977 void ScriptParser::readVersionScript() { 978 readVersionScriptCommand(); 979 if (!atEOF()) 980 setError("EOF expected, but got " + next()); 981 } 982 983 void ScriptParser::readVersionScriptCommand() { 984 if (consume("{")) { 985 readVersionDeclaration(""); 986 return; 987 } 988 989 while (!atEOF() && !Error && peek() != "}") { 990 StringRef VerStr = next(); 991 if (VerStr == "{") { 992 setError("anonymous version definition is used in " 993 "combination with other version definitions"); 994 return; 995 } 996 expect("{"); 997 readVersionDeclaration(VerStr); 998 } 999 } 1000 1001 void ScriptParser::readVersion() { 1002 expect("{"); 1003 readVersionScriptCommand(); 1004 expect("}"); 1005 } 1006 1007 void ScriptParser::readLinkerScript() { 1008 while (!atEOF()) { 1009 StringRef Tok = next(); 1010 if (Tok == ";") 1011 continue; 1012 1013 if (Tok == "ASSERT") { 1014 Opt.Commands.emplace_back(new AssertCommand(readAssert())); 1015 } else if (Tok == "ENTRY") { 1016 readEntry(); 1017 } else if (Tok == "EXTERN") { 1018 readExtern(); 1019 } else if (Tok == "GROUP" || Tok == "INPUT") { 1020 readGroup(); 1021 } else if (Tok == "INCLUDE") { 1022 readInclude(); 1023 } else if (Tok == "OUTPUT") { 1024 readOutput(); 1025 } else if (Tok == "OUTPUT_ARCH") { 1026 readOutputArch(); 1027 } else if (Tok == "OUTPUT_FORMAT") { 1028 readOutputFormat(); 1029 } else if (Tok == "PHDRS") { 1030 readPhdrs(); 1031 } else if (Tok == "SEARCH_DIR") { 1032 readSearchDir(); 1033 } else if (Tok == "SECTIONS") { 1034 readSections(); 1035 } else if (Tok == "VERSION") { 1036 readVersion(); 1037 } else if (SymbolAssignment *Cmd = readProvideOrAssignment(Tok)) { 1038 Opt.Commands.emplace_back(Cmd); 1039 } else { 1040 setError("unknown directive: " + Tok); 1041 } 1042 } 1043 } 1044 1045 void ScriptParser::addFile(StringRef S) { 1046 if (IsUnderSysroot && S.startswith("/")) { 1047 SmallString<128> PathData; 1048 StringRef Path = (Config->Sysroot + S).toStringRef(PathData); 1049 if (sys::fs::exists(Path)) { 1050 Driver->addFile(Saver.save(Path)); 1051 return; 1052 } 1053 } 1054 1055 if (sys::path::is_absolute(S)) { 1056 Driver->addFile(S); 1057 } else if (S.startswith("=")) { 1058 if (Config->Sysroot.empty()) 1059 Driver->addFile(S.substr(1)); 1060 else 1061 Driver->addFile(Saver.save(Config->Sysroot + "/" + S.substr(1))); 1062 } else if (S.startswith("-l")) { 1063 Driver->addLibrary(S.substr(2)); 1064 } else if (sys::fs::exists(S)) { 1065 Driver->addFile(S); 1066 } else { 1067 std::string Path = findFromSearchPaths(S); 1068 if (Path.empty()) 1069 setError("unable to find " + S); 1070 else 1071 Driver->addFile(Saver.save(Path)); 1072 } 1073 } 1074 1075 void ScriptParser::readAsNeeded() { 1076 expect("("); 1077 bool Orig = Config->AsNeeded; 1078 Config->AsNeeded = true; 1079 while (!Error && !consume(")")) 1080 addFile(unquote(next())); 1081 Config->AsNeeded = Orig; 1082 } 1083 1084 void ScriptParser::readEntry() { 1085 // -e <symbol> takes predecence over ENTRY(<symbol>). 1086 expect("("); 1087 StringRef Tok = next(); 1088 if (Config->Entry.empty()) 1089 Config->Entry = Tok; 1090 expect(")"); 1091 } 1092 1093 void ScriptParser::readExtern() { 1094 expect("("); 1095 while (!Error && !consume(")")) 1096 Config->Undefined.push_back(next()); 1097 } 1098 1099 void ScriptParser::readGroup() { 1100 expect("("); 1101 while (!Error && !consume(")")) { 1102 StringRef Tok = next(); 1103 if (Tok == "AS_NEEDED") 1104 readAsNeeded(); 1105 else 1106 addFile(unquote(Tok)); 1107 } 1108 } 1109 1110 void ScriptParser::readInclude() { 1111 StringRef Tok = next(); 1112 auto MBOrErr = MemoryBuffer::getFile(unquote(Tok)); 1113 if (!MBOrErr) { 1114 setError("cannot open " + Tok); 1115 return; 1116 } 1117 std::unique_ptr<MemoryBuffer> &MB = *MBOrErr; 1118 StringRef S = Saver.save(MB->getMemBufferRef().getBuffer()); 1119 std::vector<StringRef> V = tokenize(S); 1120 Tokens.insert(Tokens.begin() + Pos, V.begin(), V.end()); 1121 } 1122 1123 void ScriptParser::readOutput() { 1124 // -o <file> takes predecence over OUTPUT(<file>). 1125 expect("("); 1126 StringRef Tok = next(); 1127 if (Config->OutputFile.empty()) 1128 Config->OutputFile = unquote(Tok); 1129 expect(")"); 1130 } 1131 1132 void ScriptParser::readOutputArch() { 1133 // Error checking only for now. 1134 expect("("); 1135 skip(); 1136 expect(")"); 1137 } 1138 1139 void ScriptParser::readOutputFormat() { 1140 // Error checking only for now. 1141 expect("("); 1142 skip(); 1143 StringRef Tok = next(); 1144 if (Tok == ")") 1145 return; 1146 if (Tok != ",") { 1147 setError("unexpected token: " + Tok); 1148 return; 1149 } 1150 skip(); 1151 expect(","); 1152 skip(); 1153 expect(")"); 1154 } 1155 1156 void ScriptParser::readPhdrs() { 1157 expect("{"); 1158 while (!Error && !consume("}")) { 1159 StringRef Tok = next(); 1160 Opt.PhdrsCommands.push_back( 1161 {Tok, PT_NULL, false, false, UINT_MAX, nullptr}); 1162 PhdrsCommand &PhdrCmd = Opt.PhdrsCommands.back(); 1163 1164 PhdrCmd.Type = readPhdrType(); 1165 do { 1166 Tok = next(); 1167 if (Tok == ";") 1168 break; 1169 if (Tok == "FILEHDR") 1170 PhdrCmd.HasFilehdr = true; 1171 else if (Tok == "PHDRS") 1172 PhdrCmd.HasPhdrs = true; 1173 else if (Tok == "AT") 1174 PhdrCmd.LMAExpr = readParenExpr(); 1175 else if (Tok == "FLAGS") { 1176 expect("("); 1177 // Passing 0 for the value of dot is a bit of a hack. It means that 1178 // we accept expressions like ".|1". 1179 PhdrCmd.Flags = readExpr()(0); 1180 expect(")"); 1181 } else 1182 setError("unexpected header attribute: " + Tok); 1183 } while (!Error); 1184 } 1185 } 1186 1187 void ScriptParser::readSearchDir() { 1188 expect("("); 1189 StringRef Tok = next(); 1190 if (!Config->Nostdlib) 1191 Config->SearchPaths.push_back(unquote(Tok)); 1192 expect(")"); 1193 } 1194 1195 void ScriptParser::readSections() { 1196 Opt.HasSections = true; 1197 expect("{"); 1198 while (!Error && !consume("}")) { 1199 StringRef Tok = next(); 1200 BaseCommand *Cmd = readProvideOrAssignment(Tok); 1201 if (!Cmd) { 1202 if (Tok == "ASSERT") 1203 Cmd = new AssertCommand(readAssert()); 1204 else 1205 Cmd = readOutputSectionDescription(Tok); 1206 } 1207 Opt.Commands.emplace_back(Cmd); 1208 } 1209 } 1210 1211 static int precedence(StringRef Op) { 1212 return StringSwitch<int>(Op) 1213 .Cases("*", "/", 5) 1214 .Cases("+", "-", 4) 1215 .Cases("<<", ">>", 3) 1216 .Cases("<", "<=", ">", ">=", "==", "!=", 2) 1217 .Cases("&", "|", 1) 1218 .Default(-1); 1219 } 1220 1221 StringMatcher ScriptParser::readFilePatterns() { 1222 std::vector<StringRef> V; 1223 while (!Error && !consume(")")) 1224 V.push_back(next()); 1225 return StringMatcher(V); 1226 } 1227 1228 SortSectionPolicy ScriptParser::readSortKind() { 1229 if (consume("SORT") || consume("SORT_BY_NAME")) 1230 return SortSectionPolicy::Name; 1231 if (consume("SORT_BY_ALIGNMENT")) 1232 return SortSectionPolicy::Alignment; 1233 if (consume("SORT_BY_INIT_PRIORITY")) 1234 return SortSectionPolicy::Priority; 1235 if (consume("SORT_NONE")) 1236 return SortSectionPolicy::None; 1237 return SortSectionPolicy::Default; 1238 } 1239 1240 // Method reads a list of sequence of excluded files and section globs given in 1241 // a following form: ((EXCLUDE_FILE(file_pattern+))? section_pattern+)+ 1242 // Example: *(.foo.1 EXCLUDE_FILE (*a.o) .foo.2 EXCLUDE_FILE (*b.o) .foo.3) 1243 // The semantics of that is next: 1244 // * Include .foo.1 from every file. 1245 // * Include .foo.2 from every file but a.o 1246 // * Include .foo.3 from every file but b.o 1247 std::vector<SectionPattern> ScriptParser::readInputSectionsList() { 1248 std::vector<SectionPattern> Ret; 1249 while (!Error && peek() != ")") { 1250 StringMatcher ExcludeFilePat; 1251 if (consume("EXCLUDE_FILE")) { 1252 expect("("); 1253 ExcludeFilePat = readFilePatterns(); 1254 } 1255 1256 std::vector<StringRef> V; 1257 while (!Error && peek() != ")" && peek() != "EXCLUDE_FILE") 1258 V.push_back(next()); 1259 1260 if (!V.empty()) 1261 Ret.push_back({std::move(ExcludeFilePat), StringMatcher(V)}); 1262 else 1263 setError("section pattern is expected"); 1264 } 1265 return Ret; 1266 } 1267 1268 // Section pattern grammar can have complex expressions, for example: 1269 // *(SORT(.foo.* EXCLUDE_FILE (*file1.o) .bar.*) .bar.* SORT(.zed.*)) 1270 // Generally is a sequence of globs and excludes that may be wrapped in a SORT() 1271 // commands, like: SORT(glob0) glob1 glob2 SORT(glob4) 1272 // This methods handles wrapping sequences of excluded files and section globs 1273 // into SORT() if that needed and reads them all. 1274 InputSectionDescription * 1275 ScriptParser::readInputSectionRules(StringRef FilePattern) { 1276 auto *Cmd = new InputSectionDescription(FilePattern); 1277 expect("("); 1278 while (!HasError && !consume(")")) { 1279 SortSectionPolicy Outer = readSortKind(); 1280 SortSectionPolicy Inner = SortSectionPolicy::Default; 1281 std::vector<SectionPattern> V; 1282 if (Outer != SortSectionPolicy::Default) { 1283 expect("("); 1284 Inner = readSortKind(); 1285 if (Inner != SortSectionPolicy::Default) { 1286 expect("("); 1287 V = readInputSectionsList(); 1288 expect(")"); 1289 } else { 1290 V = readInputSectionsList(); 1291 } 1292 expect(")"); 1293 } else { 1294 V = readInputSectionsList(); 1295 } 1296 1297 for (SectionPattern &Pat : V) { 1298 Pat.SortInner = Inner; 1299 Pat.SortOuter = Outer; 1300 } 1301 1302 std::move(V.begin(), V.end(), std::back_inserter(Cmd->SectionPatterns)); 1303 } 1304 return Cmd; 1305 } 1306 1307 InputSectionDescription * 1308 ScriptParser::readInputSectionDescription(StringRef Tok) { 1309 // Input section wildcard can be surrounded by KEEP. 1310 // https://sourceware.org/binutils/docs/ld/Input-Section-Keep.html#Input-Section-Keep 1311 if (Tok == "KEEP") { 1312 expect("("); 1313 StringRef FilePattern = next(); 1314 InputSectionDescription *Cmd = readInputSectionRules(FilePattern); 1315 expect(")"); 1316 Opt.KeptSections.push_back(Cmd); 1317 return Cmd; 1318 } 1319 return readInputSectionRules(Tok); 1320 } 1321 1322 void ScriptParser::readSort() { 1323 expect("("); 1324 expect("CONSTRUCTORS"); 1325 expect(")"); 1326 } 1327 1328 Expr ScriptParser::readAssert() { 1329 expect("("); 1330 Expr E = readExpr(); 1331 expect(","); 1332 StringRef Msg = unquote(next()); 1333 expect(")"); 1334 return [=](uint64_t Dot) { 1335 uint64_t V = E(Dot); 1336 if (!V) 1337 error(Msg); 1338 return V; 1339 }; 1340 } 1341 1342 // Reads a FILL(expr) command. We handle the FILL command as an 1343 // alias for =fillexp section attribute, which is different from 1344 // what GNU linkers do. 1345 // https://sourceware.org/binutils/docs/ld/Output-Section-Data.html 1346 std::vector<uint8_t> ScriptParser::readFill() { 1347 expect("("); 1348 std::vector<uint8_t> V = readOutputSectionFiller(next()); 1349 expect(")"); 1350 expect(";"); 1351 return V; 1352 } 1353 1354 OutputSectionCommand * 1355 ScriptParser::readOutputSectionDescription(StringRef OutSec) { 1356 OutputSectionCommand *Cmd = new OutputSectionCommand(OutSec); 1357 1358 // Read an address expression. 1359 // https://sourceware.org/binutils/docs/ld/Output-Section-Address.html#Output-Section-Address 1360 if (peek() != ":") 1361 Cmd->AddrExpr = readExpr(); 1362 1363 expect(":"); 1364 1365 if (consume("AT")) 1366 Cmd->LMAExpr = readParenExpr(); 1367 if (consume("ALIGN")) 1368 Cmd->AlignExpr = readParenExpr(); 1369 if (consume("SUBALIGN")) 1370 Cmd->SubalignExpr = readParenExpr(); 1371 1372 // Parse constraints. 1373 if (consume("ONLY_IF_RO")) 1374 Cmd->Constraint = ConstraintKind::ReadOnly; 1375 if (consume("ONLY_IF_RW")) 1376 Cmd->Constraint = ConstraintKind::ReadWrite; 1377 expect("{"); 1378 1379 while (!Error && !consume("}")) { 1380 StringRef Tok = next(); 1381 if (SymbolAssignment *Assignment = readProvideOrAssignment(Tok)) 1382 Cmd->Commands.emplace_back(Assignment); 1383 else if (BytesDataCommand *Data = readBytesDataCommand(Tok)) 1384 Cmd->Commands.emplace_back(Data); 1385 else if (Tok == "FILL") 1386 Cmd->Filler = readFill(); 1387 else if (Tok == "SORT") 1388 readSort(); 1389 else if (peek() == "(") 1390 Cmd->Commands.emplace_back(readInputSectionDescription(Tok)); 1391 else 1392 setError("unknown command " + Tok); 1393 } 1394 Cmd->Phdrs = readOutputSectionPhdrs(); 1395 1396 if (consume("=")) 1397 Cmd->Filler = readOutputSectionFiller(next()); 1398 else if (peek().startswith("=")) 1399 Cmd->Filler = readOutputSectionFiller(next().drop_front()); 1400 1401 return Cmd; 1402 } 1403 1404 // Read "=<number>" where <number> is an octal/decimal/hexadecimal number. 1405 // https://sourceware.org/binutils/docs/ld/Output-Section-Fill.html 1406 // 1407 // ld.gold is not fully compatible with ld.bfd. ld.bfd handles 1408 // hexstrings as blobs of arbitrary sizes, while ld.gold handles them 1409 // as 32-bit big-endian values. We will do the same as ld.gold does 1410 // because it's simpler than what ld.bfd does. 1411 std::vector<uint8_t> ScriptParser::readOutputSectionFiller(StringRef Tok) { 1412 uint32_t V; 1413 if (Tok.getAsInteger(0, V)) { 1414 setError("invalid filler expression: " + Tok); 1415 return {}; 1416 } 1417 return {uint8_t(V >> 24), uint8_t(V >> 16), uint8_t(V >> 8), uint8_t(V)}; 1418 } 1419 1420 SymbolAssignment *ScriptParser::readProvideHidden(bool Provide, bool Hidden) { 1421 expect("("); 1422 SymbolAssignment *Cmd = readAssignment(next()); 1423 Cmd->Provide = Provide; 1424 Cmd->Hidden = Hidden; 1425 expect(")"); 1426 expect(";"); 1427 return Cmd; 1428 } 1429 1430 SymbolAssignment *ScriptParser::readProvideOrAssignment(StringRef Tok) { 1431 SymbolAssignment *Cmd = nullptr; 1432 if (peek() == "=" || peek() == "+=") { 1433 Cmd = readAssignment(Tok); 1434 expect(";"); 1435 } else if (Tok == "PROVIDE") { 1436 Cmd = readProvideHidden(true, false); 1437 } else if (Tok == "HIDDEN") { 1438 Cmd = readProvideHidden(false, true); 1439 } else if (Tok == "PROVIDE_HIDDEN") { 1440 Cmd = readProvideHidden(true, true); 1441 } 1442 return Cmd; 1443 } 1444 1445 static uint64_t getSymbolValue(StringRef S, uint64_t Dot) { 1446 if (S == ".") 1447 return Dot; 1448 return ScriptBase->getSymbolValue(S); 1449 } 1450 1451 static bool isAbsolute(StringRef S) { 1452 if (S == ".") 1453 return false; 1454 return ScriptBase->isAbsolute(S); 1455 } 1456 1457 SymbolAssignment *ScriptParser::readAssignment(StringRef Name) { 1458 StringRef Op = next(); 1459 Expr E; 1460 assert(Op == "=" || Op == "+="); 1461 if (consume("ABSOLUTE")) { 1462 // The RHS may be something like "ABSOLUTE(.) & 0xff". 1463 // Call readExpr1 to read the whole expression. 1464 E = readExpr1(readParenExpr(), 0); 1465 E.IsAbsolute = []() { return true; }; 1466 } else { 1467 E = readExpr(); 1468 } 1469 if (Op == "+=") 1470 E = [=](uint64_t Dot) { return getSymbolValue(Name, Dot) + E(Dot); }; 1471 return new SymbolAssignment(Name, E); 1472 } 1473 1474 // This is an operator-precedence parser to parse a linker 1475 // script expression. 1476 Expr ScriptParser::readExpr() { return readExpr1(readPrimary(), 0); } 1477 1478 static Expr combine(StringRef Op, Expr L, Expr R) { 1479 if (Op == "*") 1480 return [=](uint64_t Dot) { return L(Dot) * R(Dot); }; 1481 if (Op == "/") { 1482 return [=](uint64_t Dot) -> uint64_t { 1483 uint64_t RHS = R(Dot); 1484 if (RHS == 0) { 1485 error("division by zero"); 1486 return 0; 1487 } 1488 return L(Dot) / RHS; 1489 }; 1490 } 1491 if (Op == "+") 1492 return {[=](uint64_t Dot) { return L(Dot) + R(Dot); }, 1493 [=]() { return L.IsAbsolute() && R.IsAbsolute(); }}; 1494 if (Op == "-") 1495 return [=](uint64_t Dot) { return L(Dot) - R(Dot); }; 1496 if (Op == "<<") 1497 return [=](uint64_t Dot) { return L(Dot) << R(Dot); }; 1498 if (Op == ">>") 1499 return [=](uint64_t Dot) { return L(Dot) >> R(Dot); }; 1500 if (Op == "<") 1501 return [=](uint64_t Dot) { return L(Dot) < R(Dot); }; 1502 if (Op == ">") 1503 return [=](uint64_t Dot) { return L(Dot) > R(Dot); }; 1504 if (Op == ">=") 1505 return [=](uint64_t Dot) { return L(Dot) >= R(Dot); }; 1506 if (Op == "<=") 1507 return [=](uint64_t Dot) { return L(Dot) <= R(Dot); }; 1508 if (Op == "==") 1509 return [=](uint64_t Dot) { return L(Dot) == R(Dot); }; 1510 if (Op == "!=") 1511 return [=](uint64_t Dot) { return L(Dot) != R(Dot); }; 1512 if (Op == "&") 1513 return [=](uint64_t Dot) { return L(Dot) & R(Dot); }; 1514 if (Op == "|") 1515 return [=](uint64_t Dot) { return L(Dot) | R(Dot); }; 1516 llvm_unreachable("invalid operator"); 1517 } 1518 1519 // This is a part of the operator-precedence parser. This function 1520 // assumes that the remaining token stream starts with an operator. 1521 Expr ScriptParser::readExpr1(Expr Lhs, int MinPrec) { 1522 while (!atEOF() && !Error) { 1523 // Read an operator and an expression. 1524 StringRef Op1 = peek(); 1525 if (Op1 == "?") 1526 return readTernary(Lhs); 1527 if (precedence(Op1) < MinPrec) 1528 break; 1529 skip(); 1530 Expr Rhs = readPrimary(); 1531 1532 // Evaluate the remaining part of the expression first if the 1533 // next operator has greater precedence than the previous one. 1534 // For example, if we have read "+" and "3", and if the next 1535 // operator is "*", then we'll evaluate 3 * ... part first. 1536 while (!atEOF()) { 1537 StringRef Op2 = peek(); 1538 if (precedence(Op2) <= precedence(Op1)) 1539 break; 1540 Rhs = readExpr1(Rhs, precedence(Op2)); 1541 } 1542 1543 Lhs = combine(Op1, Lhs, Rhs); 1544 } 1545 return Lhs; 1546 } 1547 1548 uint64_t static getConstant(StringRef S) { 1549 if (S == "COMMONPAGESIZE") 1550 return Target->PageSize; 1551 if (S == "MAXPAGESIZE") 1552 return Config->MaxPageSize; 1553 error("unknown constant: " + S); 1554 return 0; 1555 } 1556 1557 // Parses Tok as an integer. Returns true if successful. 1558 // It recognizes hexadecimal (prefixed with "0x" or suffixed with "H") 1559 // and decimal numbers. Decimal numbers may have "K" (kilo) or 1560 // "M" (mega) prefixes. 1561 static bool readInteger(StringRef Tok, uint64_t &Result) { 1562 if (Tok.startswith("-")) { 1563 if (!readInteger(Tok.substr(1), Result)) 1564 return false; 1565 Result = -Result; 1566 return true; 1567 } 1568 if (Tok.startswith_lower("0x")) 1569 return !Tok.substr(2).getAsInteger(16, Result); 1570 if (Tok.endswith_lower("H")) 1571 return !Tok.drop_back().getAsInteger(16, Result); 1572 1573 int Suffix = 1; 1574 if (Tok.endswith_lower("K")) { 1575 Suffix = 1024; 1576 Tok = Tok.drop_back(); 1577 } else if (Tok.endswith_lower("M")) { 1578 Suffix = 1024 * 1024; 1579 Tok = Tok.drop_back(); 1580 } 1581 if (Tok.getAsInteger(10, Result)) 1582 return false; 1583 Result *= Suffix; 1584 return true; 1585 } 1586 1587 BytesDataCommand *ScriptParser::readBytesDataCommand(StringRef Tok) { 1588 int Size = StringSwitch<unsigned>(Tok) 1589 .Case("BYTE", 1) 1590 .Case("SHORT", 2) 1591 .Case("LONG", 4) 1592 .Case("QUAD", 8) 1593 .Default(-1); 1594 if (Size == -1) 1595 return nullptr; 1596 1597 expect("("); 1598 uint64_t Val = 0; 1599 StringRef S = next(); 1600 if (!readInteger(S, Val)) 1601 setError("unexpected value: " + S); 1602 expect(")"); 1603 return new BytesDataCommand(Val, Size); 1604 } 1605 1606 StringRef ScriptParser::readParenLiteral() { 1607 expect("("); 1608 StringRef Tok = next(); 1609 expect(")"); 1610 return Tok; 1611 } 1612 1613 Expr ScriptParser::readPrimary() { 1614 if (peek() == "(") 1615 return readParenExpr(); 1616 1617 StringRef Tok = next(); 1618 1619 if (Tok == "~") { 1620 Expr E = readPrimary(); 1621 return [=](uint64_t Dot) { return ~E(Dot); }; 1622 } 1623 if (Tok == "-") { 1624 Expr E = readPrimary(); 1625 return [=](uint64_t Dot) { return -E(Dot); }; 1626 } 1627 1628 // Built-in functions are parsed here. 1629 // https://sourceware.org/binutils/docs/ld/Builtin-Functions.html. 1630 if (Tok == "ADDR") { 1631 StringRef Name = readParenLiteral(); 1632 return 1633 [=](uint64_t Dot) { return ScriptBase->getOutputSectionAddress(Name); }; 1634 } 1635 if (Tok == "LOADADDR") { 1636 StringRef Name = readParenLiteral(); 1637 return [=](uint64_t Dot) { return ScriptBase->getOutputSectionLMA(Name); }; 1638 } 1639 if (Tok == "ASSERT") 1640 return readAssert(); 1641 if (Tok == "ALIGN") { 1642 Expr E = readParenExpr(); 1643 return [=](uint64_t Dot) { return alignTo(Dot, E(Dot)); }; 1644 } 1645 if (Tok == "CONSTANT") { 1646 StringRef Name = readParenLiteral(); 1647 return [=](uint64_t Dot) { return getConstant(Name); }; 1648 } 1649 if (Tok == "DEFINED") { 1650 expect("("); 1651 StringRef Tok = next(); 1652 expect(")"); 1653 return [=](uint64_t Dot) { return ScriptBase->isDefined(Tok) ? 1 : 0; }; 1654 } 1655 if (Tok == "SEGMENT_START") { 1656 expect("("); 1657 skip(); 1658 expect(","); 1659 Expr E = readExpr(); 1660 expect(")"); 1661 return [=](uint64_t Dot) { return E(Dot); }; 1662 } 1663 if (Tok == "DATA_SEGMENT_ALIGN") { 1664 expect("("); 1665 Expr E = readExpr(); 1666 expect(","); 1667 readExpr(); 1668 expect(")"); 1669 return [=](uint64_t Dot) { return alignTo(Dot, E(Dot)); }; 1670 } 1671 if (Tok == "DATA_SEGMENT_END") { 1672 expect("("); 1673 expect("."); 1674 expect(")"); 1675 return [](uint64_t Dot) { return Dot; }; 1676 } 1677 // GNU linkers implements more complicated logic to handle 1678 // DATA_SEGMENT_RELRO_END. We instead ignore the arguments and just align to 1679 // the next page boundary for simplicity. 1680 if (Tok == "DATA_SEGMENT_RELRO_END") { 1681 expect("("); 1682 readExpr(); 1683 expect(","); 1684 readExpr(); 1685 expect(")"); 1686 return [](uint64_t Dot) { return alignTo(Dot, Target->PageSize); }; 1687 } 1688 if (Tok == "SIZEOF") { 1689 StringRef Name = readParenLiteral(); 1690 return [=](uint64_t Dot) { return ScriptBase->getOutputSectionSize(Name); }; 1691 } 1692 if (Tok == "ALIGNOF") { 1693 StringRef Name = readParenLiteral(); 1694 return 1695 [=](uint64_t Dot) { return ScriptBase->getOutputSectionAlign(Name); }; 1696 } 1697 if (Tok == "SIZEOF_HEADERS") 1698 return [=](uint64_t Dot) { return ScriptBase->getHeaderSize(); }; 1699 1700 // Tok is a literal number. 1701 uint64_t V; 1702 if (readInteger(Tok, V)) 1703 return [=](uint64_t Dot) { return V; }; 1704 1705 // Tok is a symbol name. 1706 if (Tok != "." && !isValidCIdentifier(Tok)) 1707 setError("malformed number: " + Tok); 1708 return {[=](uint64_t Dot) { return getSymbolValue(Tok, Dot); }, 1709 [=]() { return isAbsolute(Tok); }}; 1710 } 1711 1712 Expr ScriptParser::readTernary(Expr Cond) { 1713 skip(); 1714 Expr L = readExpr(); 1715 expect(":"); 1716 Expr R = readExpr(); 1717 return [=](uint64_t Dot) { return Cond(Dot) ? L(Dot) : R(Dot); }; 1718 } 1719 1720 Expr ScriptParser::readParenExpr() { 1721 expect("("); 1722 Expr E = readExpr(); 1723 expect(")"); 1724 return E; 1725 } 1726 1727 std::vector<StringRef> ScriptParser::readOutputSectionPhdrs() { 1728 std::vector<StringRef> Phdrs; 1729 while (!Error && peek().startswith(":")) { 1730 StringRef Tok = next(); 1731 Phdrs.push_back((Tok.size() == 1) ? next() : Tok.substr(1)); 1732 } 1733 return Phdrs; 1734 } 1735 1736 // Read a program header type name. The next token must be a 1737 // name of a program header type or a constant (e.g. "0x3"). 1738 unsigned ScriptParser::readPhdrType() { 1739 StringRef Tok = next(); 1740 uint64_t Val; 1741 if (readInteger(Tok, Val)) 1742 return Val; 1743 1744 unsigned Ret = StringSwitch<unsigned>(Tok) 1745 .Case("PT_NULL", PT_NULL) 1746 .Case("PT_LOAD", PT_LOAD) 1747 .Case("PT_DYNAMIC", PT_DYNAMIC) 1748 .Case("PT_INTERP", PT_INTERP) 1749 .Case("PT_NOTE", PT_NOTE) 1750 .Case("PT_SHLIB", PT_SHLIB) 1751 .Case("PT_PHDR", PT_PHDR) 1752 .Case("PT_TLS", PT_TLS) 1753 .Case("PT_GNU_EH_FRAME", PT_GNU_EH_FRAME) 1754 .Case("PT_GNU_STACK", PT_GNU_STACK) 1755 .Case("PT_GNU_RELRO", PT_GNU_RELRO) 1756 .Case("PT_OPENBSD_RANDOMIZE", PT_OPENBSD_RANDOMIZE) 1757 .Case("PT_OPENBSD_WXNEEDED", PT_OPENBSD_WXNEEDED) 1758 .Default(-1); 1759 1760 if (Ret == (unsigned)-1) { 1761 setError("invalid program header type: " + Tok); 1762 return PT_NULL; 1763 } 1764 return Ret; 1765 } 1766 1767 void ScriptParser::readVersionDeclaration(StringRef VerStr) { 1768 // Identifiers start at 2 because 0 and 1 are reserved 1769 // for VER_NDX_LOCAL and VER_NDX_GLOBAL constants. 1770 size_t VersionId = Config->VersionDefinitions.size() + 2; 1771 Config->VersionDefinitions.push_back({VerStr, VersionId}); 1772 1773 if (consume("global:") || peek() != "local:") 1774 readGlobal(VerStr); 1775 if (consume("local:")) 1776 readLocal(VerStr); 1777 expect("}"); 1778 1779 // Each version may have a parent version. For example, "Ver2" defined as 1780 // "Ver2 { global: foo; local: *; } Ver1;" has "Ver1" as a parent. This 1781 // version hierarchy is, probably against your instinct, purely for human; the 1782 // runtime doesn't care about them at all. In LLD, we simply skip the token. 1783 if (!VerStr.empty() && peek() != ";") 1784 skip(); 1785 expect(";"); 1786 } 1787 1788 void ScriptParser::readLocal(StringRef VerStr) { 1789 if (consume("*")) { 1790 Config->DefaultSymbolVersion = VER_NDX_LOCAL; 1791 expect(";"); 1792 return; 1793 } 1794 1795 if (VerStr.empty()) 1796 setError("locals list for anonymous version is not supported"); 1797 1798 std::vector<SymbolVersion> &Locals = Config->VersionDefinitions.back().Locals; 1799 while (!Error && peek() != "}") { 1800 StringRef Tok = next(); 1801 Locals.push_back({unquote(Tok), false, hasWildcard(Tok)}); 1802 expect(";"); 1803 } 1804 } 1805 1806 void ScriptParser::readExtern(std::vector<SymbolVersion> *Globals) { 1807 expect("\"C++\""); 1808 expect("{"); 1809 1810 for (;;) { 1811 if (peek() == "}" || Error) 1812 break; 1813 bool HasWildcard = !peek().startswith("\"") && hasWildcard(peek()); 1814 Globals->push_back({unquote(next()), true, HasWildcard}); 1815 expect(";"); 1816 } 1817 1818 expect("}"); 1819 expect(";"); 1820 } 1821 1822 void ScriptParser::readGlobal(StringRef VerStr) { 1823 std::vector<SymbolVersion> *Globals; 1824 if (VerStr.empty()) 1825 Globals = &Config->VersionScriptGlobals; 1826 else 1827 Globals = &Config->VersionDefinitions.back().Globals; 1828 1829 for (;;) { 1830 if (consume("extern")) 1831 readExtern(Globals); 1832 1833 StringRef Cur = peek(); 1834 if (Cur == "}" || Cur == "local:" || Error) 1835 return; 1836 skip(); 1837 Globals->push_back({unquote(Cur), false, hasWildcard(Cur)}); 1838 expect(";"); 1839 } 1840 } 1841 1842 static bool isUnderSysroot(StringRef Path) { 1843 if (Config->Sysroot == "") 1844 return false; 1845 for (; !Path.empty(); Path = sys::path::parent_path(Path)) 1846 if (sys::fs::equivalent(Config->Sysroot, Path)) 1847 return true; 1848 return false; 1849 } 1850 1851 void elf::readLinkerScript(MemoryBufferRef MB) { 1852 StringRef Path = MB.getBufferIdentifier(); 1853 ScriptParser(MB.getBuffer(), isUnderSysroot(Path)).readLinkerScript(); 1854 } 1855 1856 void elf::readVersionScript(MemoryBufferRef MB) { 1857 ScriptParser(MB.getBuffer(), false).readVersionScript(); 1858 } 1859 1860 template class elf::LinkerScript<ELF32LE>; 1861 template class elf::LinkerScript<ELF32BE>; 1862 template class elf::LinkerScript<ELF64LE>; 1863 template class elf::LinkerScript<ELF64BE>; 1864