PR26489, ASAN: ppc64_elf_size_stubs elf64-ppc.c:13389
authorAlan Modra <amodra@gmail.com>
Mon, 24 Aug 2020 16:25:38 +0000 (01:55 +0930)
committerAlan Modra <amodra@gmail.com>
Mon, 24 Aug 2020 16:42:35 +0000 (02:12 +0930)
Stub sections are inserted after sec_info is sized, so have higher ids.
Test flags that will exclude stub sections before looking at the
sec_info array.

PR 26489
* elf64-ppc.c (ppc64_elf_size_stubs): Test code_sec->has_toc_reloc
and code_sec->makes_toc_func_call before sec_info[code_sec->id].

bfd/ChangeLog
bfd/elf64-ppc.c

index 8f062b085f3126cd0cd0f1151825b0fb19a9edaa..ca79c4e583072bfd0fdaefe3232a000e89598324 100644 (file)
@@ -1,3 +1,9 @@
+2020-08-25  Alan Modra  <amodra@gmail.com>
+
+       PR 26489
+       * elf64-ppc.c (ppc64_elf_size_stubs): Test code_sec->has_toc_reloc
+       and code_sec->makes_toc_func_call before sec_info[code_sec->id].
+
 2020-08-25  Alan Modra  <amodra@gmail.com>
 
        PR 26492
index 5a21bfafbcf961fa6bce130fb04245d7a0ab4f17..d144796b466351888e4e07b29aee1fd53e4ff425 100644 (file)
@@ -13426,10 +13426,10 @@ ppc64_elf_size_stubs (struct bfd_link_info *info)
                         fact a call needing a TOC adjustment.  */
                      if ((code_sec != NULL
                           && code_sec->output_section != NULL
-                          && (htab->sec_info[code_sec->id].toc_off
-                              != htab->sec_info[section->id].toc_off)
                           && (code_sec->has_toc_reloc
-                              || code_sec->makes_toc_func_call))
+                              || code_sec->makes_toc_func_call)
+                          && (htab->sec_info[code_sec->id].toc_off
+                              != htab->sec_info[section->id].toc_off))
                          || (((hash ? hash->elf.other : sym->st_other)
                               & STO_PPC64_LOCAL_MASK)
                              == 1 << STO_PPC64_LOCAL_BIT))