From: Alan Modra Date: Thu, 19 Apr 2018 04:43:41 +0000 (+0930) Subject: PR22537, Segmentation fault with static PIE X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f6a8b8c7ac2d5369070a6b76a94ee0f3052433ff;p=binutils-gdb.git PR22537, Segmentation fault with static PIE The only stub type that makes sense for undefined symbols, or those defined in shared libraries, is a plt call stub. This patch arranges to have "destination" set to -1 on such symbols, making for an easy test in hppa_type_of_stub. PR 22537 * elf32-hppa.c (elf32_hppa_size_stubs): Init "destination" to -1. (hppa_type_of_stub): Don't return a long branch stub for symbols other than those defined statically. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 2d896412e07..d92c334f3a5 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,10 @@ +2018-04-19 Alan Modra + + PR 22537 + * elf32-hppa.c (elf32_hppa_size_stubs): Init "destination" to -1. + (hppa_type_of_stub): Don't return a long branch stub for + symbols other than those defined statically. + 2018-04-19 Alan Modra * Makefile.am: Revert 2018-04-18 coff-mips changes. diff --git a/bfd/elf32-hppa.c b/bfd/elf32-hppa.c index 3ce38078b8d..44fb753c0ea 100644 --- a/bfd/elf32-hppa.c +++ b/bfd/elf32-hppa.c @@ -612,6 +612,9 @@ hppa_type_of_stub (asection *input_sec, return hppa_stub_import; } + if (destination == (bfd_vma) -1) + return hppa_stub_none; + /* Determine where the call point is. */ location = (input_sec->output_offset + input_sec->output_section->vma @@ -2843,7 +2846,7 @@ elf32_hppa_size_stubs section. */ sym_sec = NULL; sym_value = 0; - destination = 0; + destination = -1; hh = NULL; if (r_indx < symtab_hdr->sh_info) {