summaryrefslogtreecommitdiffstats
path: root/lld/ELF/InputFiles.cpp
diff options
context:
space:
mode:
authorGeorge Rimar <grimar@accesssoftek.com>2016-11-15 07:56:28 +0000
committerGeorge Rimar <grimar@accesssoftek.com>2016-11-15 07:56:28 +0000
commit308752e474fa98842a74dc16e171c595b40db651 (patch)
tree0cbca1feaa4085e9dbddef47ebe682bf86aae74f /lld/ELF/InputFiles.cpp
parentb573553424cd1700cc1128eb8431de8cdfc3b04c (diff)
downloadbcm5719-llvm-308752e474fa98842a74dc16e171c595b40db651.tar.gz
bcm5719-llvm-308752e474fa98842a74dc16e171c595b40db651.zip
[ELF] - Allow symbols of STT_NOTYPE to be associated with SHT_SYMTAB sections.
Found this when tried to link lang/ccl FreeBSD port. Issue is very close to D23201. This is the reason of lang/ccl port link fail. GNU assembler 2.17.50 [FreeBSD] 2007-07-03 could generate broken objects, where notype symbols are associated with symtab: ... [ 9] .symtab SYMTAB 0000000000000000 00003c78 0000000000006858 0000000000000018 10 803 8 ... 192: 000000000000000d 0 NOTYPE LOCAL DEFAULT 9 _cons_org Patch allows to handle such objects. Differential revision: https://reviews.llvm.org/D26613 llvm-svn: 286939
Diffstat (limited to 'lld/ELF/InputFiles.cpp')
-rw-r--r--lld/ELF/InputFiles.cpp11
1 files changed, 6 insertions, 5 deletions
diff --git a/lld/ELF/InputFiles.cpp b/lld/ELF/InputFiles.cpp
index 6faef18b0dc..e5ec606b0b1 100644
--- a/lld/ELF/InputFiles.cpp
+++ b/lld/ELF/InputFiles.cpp
@@ -417,13 +417,14 @@ elf::ObjectFile<ELFT>::getSection(const Elf_Sym &Sym) const {
fatal(getFilename(this) + ": invalid section index: " + Twine(Index));
InputSectionBase<ELFT> *S = Sections[Index];
- // We found that GNU assembler 2.17.50 [FreeBSD] 2007-07-03
- // could generate broken objects. STT_SECTION symbols can be
+ // We found that GNU assembler 2.17.50 [FreeBSD] 2007-07-03 could
+ // generate broken objects. STT_SECTION/STT_NOTYPE symbols can be
// associated with SHT_REL[A]/SHT_SYMTAB/SHT_STRTAB sections.
- // In this case it is fine for section to be null here as we
- // do not allocate sections of these types.
+ // In this case it is fine for section to be null here as we do not
+ // allocate sections of these types.
if (!S) {
- if (Index == 0 || Sym.getType() == STT_SECTION)
+ if (Index == 0 || Sym.getType() == STT_SECTION ||
+ Sym.getType() == STT_NOTYPE)
return nullptr;
fatal(getFilename(this) + ": invalid section index: " + Twine(Index));
}
OpenPOWER on IntegriCloud