PR24337, segfault in _bfd_elf_rela_local_sym
authorAlan Modra <amodra@gmail.com>
Fri, 15 Mar 2019 06:19:42 +0000 (16:49 +1030)
committerAlan Modra <amodra@gmail.com>
Fri, 15 Mar 2019 09:35:18 +0000 (20:05 +1030)
PR 24337
* elf.c (_bfd_elf_rela_local_sym): Don't segfault on NULL sec.
(_bfd_elf_rel_local_sym): Likewise.

bfd/ChangeLog
bfd/elf.c

index b1011b1eb6c9508f1b654fae2a07207478021b1e..eacd828d7e364be4bfa4e87444a9c8114adb77be 100644 (file)
@@ -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
index 73fb86971f3dcc0461ba17d5d24d3cf7add41761..585bf3ca7d9e02d4fa0e1c8e4b9670f492df559f 100644 (file)
--- a/bfd/elf.c
+++ b/bfd/elf.c
@@ -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,
This page took 0.029014 seconds and 4 git commands to generate.