Handle invalid values of PLT entry size generated by linker
Make sure we figure out correct plt entry field in case linker has generated a small value below realistic entry size like 4 bytes or below. Differential revision: http://reviews.llvm.org/D19252 llvm-svn: 267405
This commit is contained in:
@@ -2610,7 +2610,10 @@ GetPltEntrySizeAndOffset(const ELFSectionHeader* rel_hdr, const ELFSectionHeader
|
||||
elf_xword plt_entsize = plt_hdr->sh_addralign ?
|
||||
llvm::alignTo (plt_hdr->sh_entsize, plt_hdr->sh_addralign) : plt_hdr->sh_entsize;
|
||||
|
||||
if (plt_entsize == 0)
|
||||
// Some linkers e.g ld for arm, fill plt_hdr->sh_entsize field incorrectly.
|
||||
// PLT entries relocation code in general requires multiple instruction and
|
||||
// should be greater than 4 bytes in most cases. Try to guess correct size just in case.
|
||||
if (plt_entsize <= 4)
|
||||
{
|
||||
// The linker haven't set the plt_hdr->sh_entsize field. Try to guess the size of the plt
|
||||
// entries based on the number of entries and the size of the plt section with the
|
||||
|
||||
Reference in New Issue
Block a user