summaryrefslogtreecommitdiffstats
path: root/lld/ELF/LinkerScript.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2016-09-20 13:12:07 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2016-09-20 13:12:07 +0000
commit6d38e4dbe1603c916343d25c47b4c9ced283455c (patch)
treec92e5e5cb10bf903246407067a941f3bd537d4ec /lld/ELF/LinkerScript.cpp
parent2e721aa8c8f14ad00fb8ee3e6c8bff4e30d497a3 (diff)
downloadbcm5719-llvm-6d38e4dbe1603c916343d25c47b4c9ced283455c.tar.gz
bcm5719-llvm-6d38e4dbe1603c916343d25c47b4c9ced283455c.zip
Remove empty section commands.
We were already not creating them, and with this other parts of the code don't have to worry about them. llvm-svn: 281968
Diffstat (limited to 'lld/ELF/LinkerScript.cpp')
-rw-r--r--lld/ELF/LinkerScript.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/lld/ELF/LinkerScript.cpp b/lld/ELF/LinkerScript.cpp
index e4f8378417c..ea2c14b3b1b 100644
--- a/lld/ELF/LinkerScript.cpp
+++ b/lld/ELF/LinkerScript.cpp
@@ -446,6 +446,29 @@ void LinkerScript<ELFT>::assignOffsets(OutputSectionCommand *Cmd) {
}
template <class ELFT> void LinkerScript<ELFT>::assignAddresses() {
+ // It is common practice to use very generic linker scripts. So for any
+ // given run some of the output sections in the script will be empty.
+ // We could create corresponding empty output sections, but that would
+ // clutter the output.
+ // We instead remove trivially empty sections. The bfd linker seems even
+ // more aggressive at removing them.
+ auto Pos = std::remove_if(
+ Opt.Commands.begin(), Opt.Commands.end(),
+ [&](const std::unique_ptr<BaseCommand> &Base) {
+ auto *Cmd = dyn_cast<OutputSectionCommand>(Base.get());
+ if (!Cmd)
+ return false;
+ std::vector<OutputSectionBase<ELFT> *> Secs =
+ findSections(*Cmd, *OutputSections);
+ if (!Secs.empty())
+ return false;
+ for (const std::unique_ptr<BaseCommand> &I : Cmd->Commands)
+ if (!isa<InputSectionDescription>(I.get()))
+ return false;
+ return true;
+ });
+ Opt.Commands.erase(Pos, Opt.Commands.end());
+
// Orphan sections are sections present in the input files which
// are not explicitly placed into the output file by the linker script.
// We place orphan sections at end of file.
OpenPOWER on IntegriCloud