Skip to content

Commit

Permalink
[ELF] SHF_LINK_ORDER should sort based on InputSectionDescriptions
Browse files Browse the repository at this point in the history
    
This change alters the sorting for OutputSections with the SHF_LINK_ORDER
flag in OutputSection::finalize() to use the InputSectionDescription
representation and not the OutputSection::Sections representation.

Differential revision: https://reviews.llvm.org/D33772

llvm-svn: 304700
  • Loading branch information
smithp35 committed Jun 5, 2017
1 parent 77a12b3 commit 43e852f
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 6 deletions.
14 changes: 13 additions & 1 deletion lld/ELF/OutputSections.cpp
Expand Up @@ -99,8 +99,20 @@ template <class ELFT> static void finalizeShtGroup(OutputSection *Sec) {

template <class ELFT> void OutputSection::finalize() {
if ((this->Flags & SHF_LINK_ORDER) && !this->Sections.empty()) {
OutputSectionCommand *Cmd = Script->getCmd(this);
// Link order may be distributed across several InputSectionDescriptions
// but sort must consider them all at once.
std::vector<InputSection **> ScriptSections;
std::vector<InputSection *> Sections;
for (BaseCommand *Base : Cmd->Commands)
if (auto *ISD = dyn_cast<InputSectionDescription>(Base))
for (InputSection *&IS : ISD->Sections) {
ScriptSections.push_back(&IS);
Sections.push_back(IS);
}
std::sort(Sections.begin(), Sections.end(), compareByFilePosition);
assignOffsets();
for (int I = 0, N = Sections.size(); I < N; ++I)
*ScriptSections[I] = Sections[I];

// We must preserve the link order dependency of sections with the
// SHF_LINK_ORDER flag. The dependency is indicated by the sh_link field. We
Expand Down
11 changes: 6 additions & 5 deletions lld/ELF/Writer.cpp
Expand Up @@ -257,11 +257,6 @@ template <class ELFT> void Writer<ELFT>::run() {
if (ErrorCount)
return;

if (!Script->Opt.HasSections)
Script->fabricateDefaultCommands();
else
Script->synchronize();

for (BaseCommand *Base : Script->Opt.Commands)
if (auto *Cmd = dyn_cast<OutputSectionCommand>(Base))
OutputSectionCommands.push_back(Cmd);
Expand Down Expand Up @@ -1261,6 +1256,12 @@ template <class ELFT> void Writer<ELFT>::finalizeSections() {
applySynthetic({InX::MipsGot},
[](SyntheticSection *SS) { SS->updateAllocSize(); });
}

if (!Script->Opt.HasSections)
Script->fabricateDefaultCommands();
else
Script->synchronize();

// Fill other section headers. The dynamic table is finalized
// at the end because some tags like RELSZ depend on result
// of finalizing other sections.
Expand Down

0 comments on commit 43e852f

Please sign in to comment.