diff options
| author | George Rimar <grimar@accesssoftek.com> | 2016-11-15 07:56:28 +0000 |
|---|---|---|
| committer | George Rimar <grimar@accesssoftek.com> | 2016-11-15 07:56:28 +0000 |
| commit | 308752e474fa98842a74dc16e171c595b40db651 (patch) | |
| tree | 0cbca1feaa4085e9dbddef47ebe682bf86aae74f /lld/ELF/InputFiles.cpp | |
| parent | b573553424cd1700cc1128eb8431de8cdfc3b04c (diff) | |
| download | bcm5719-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.cpp | 11 |
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)); } |

