PR24337, segfault in _bfd_elf_rela_local_sym
PR 24337 * elf.c (_bfd_elf_rela_local_sym): Don't segfault on NULL sec. (_bfd_elf_rel_local_sym): Likewise.
This commit is contained in:
parent
f55b1e3248
commit
1ff31e135f
2 changed files with 11 additions and 4 deletions
|
@ -1,3 +1,9 @@
|
|||
2019-03-15 Alan Modra <amodra@gmail.com>
|
||||
|
||||
PR 24337
|
||||
* elf.c (_bfd_elf_rela_local_sym): Don't segfault on NULL sec.
|
||||
(_bfd_elf_rel_local_sym): Likewise.
|
||||
|
||||
2019-03-15 Alan Modra <amodra@gmail.com>
|
||||
|
||||
PR 24336
|
||||
|
|
|
@ -11822,9 +11822,10 @@ _bfd_elf_rela_local_sym (bfd *abfd,
|
|||
asection *sec = *psec;
|
||||
bfd_vma relocation;
|
||||
|
||||
relocation = (sec->output_section->vma
|
||||
+ sec->output_offset
|
||||
+ sym->st_value);
|
||||
relocation = sym->st_value;
|
||||
if (sec == NULL)
|
||||
return relocation;
|
||||
relocation += sec->output_section->vma + sec->output_offset;
|
||||
if ((sec->flags & SEC_MERGE)
|
||||
&& ELF_ST_TYPE (sym->st_info) == STT_SECTION
|
||||
&& sec->sec_info_type == SEC_INFO_TYPE_MERGE)
|
||||
|
@ -11858,7 +11859,7 @@ _bfd_elf_rel_local_sym (bfd *abfd,
|
|||
{
|
||||
asection *sec = *psec;
|
||||
|
||||
if (sec->sec_info_type != SEC_INFO_TYPE_MERGE)
|
||||
if (sec == NULL || sec->sec_info_type != SEC_INFO_TYPE_MERGE)
|
||||
return sym->st_value + addend;
|
||||
|
||||
return _bfd_merged_section_offset (abfd, psec,
|
||||
|
|
Loading…
Add table
Reference in a new issue