|
|
7db648 |
--- binutils.orig/bfd/elf64-s390.c 2020-06-15 11:01:54.671940830 +0100
|
|
|
7db648 |
+++ binutils-2.30/bfd/elf64-s390.c 2020-06-15 11:04:44.663343784 +0100
|
|
|
7db648 |
@@ -2335,6 +2335,9 @@ elf_s390_relocate_section (bfd *output_b
|
|
|
7db648 |
&& SYMBOL_REFERENCES_LOCAL (info, h))
|
|
|
7db648 |
|| resolved_to_zero)
|
|
|
7db648 |
{
|
|
|
7db648 |
+ Elf_Internal_Sym *isym;
|
|
|
7db648 |
+ asection *sym_sec;
|
|
|
7db648 |
+
|
|
|
7db648 |
/* This is actually a static link, or it is a
|
|
|
7db648 |
-Bsymbolic link and the symbol is defined
|
|
|
7db648 |
locally, or the symbol was forced to be local
|
|
|
7db648 |
@@ -2356,6 +2359,10 @@ elf_s390_relocate_section (bfd *output_b
|
|
|
7db648 |
h->got.offset |= 1;
|
|
|
7db648 |
}
|
|
|
7db648 |
|
|
|
7db648 |
+ /* When turning a GOT slot dereference into a direct
|
|
|
7db648 |
+ reference using larl we have to make sure that
|
|
|
7db648 |
+ the symbol is 1. properly aligned and 2. it is no
|
|
|
7db648 |
+ ABS symbol or will become one. */
|
|
|
7db648 |
if ((h->def_regular
|
|
|
7db648 |
&& bfd_link_pic (info)
|
|
|
7db648 |
&& SYMBOL_REFERENCES_LOCAL (info, h))
|
|
|
7db648 |
@@ -2370,8 +2377,17 @@ elf_s390_relocate_section (bfd *output_b
|
|
|
7db648 |
contents + rel->r_offset - 2)
|
|
|
7db648 |
& 0xff00f000) == 0xe300c000
|
|
|
7db648 |
&& bfd_get_8 (input_bfd,
|
|
|
7db648 |
- contents + rel->r_offset + 3) == 0x04)))
|
|
|
7db648 |
-
|
|
|
7db648 |
+ contents + rel->r_offset + 3) == 0x04))
|
|
|
7db648 |
+ && (isym = bfd_sym_from_r_symndx (&htab->sym_cache,
|
|
|
7db648 |
+ input_bfd, r_symndx))
|
|
|
7db648 |
+ && isym->st_shndx != SHN_ABS
|
|
|
7db648 |
+ && h != htab->elf.hdynamic
|
|
|
7db648 |
+ && h != htab->elf.hgot
|
|
|
7db648 |
+ && h != htab->elf.hplt
|
|
|
7db648 |
+ && !(isym->st_value & 1)
|
|
|
7db648 |
+ && (sym_sec = bfd_section_from_elf_index (input_bfd,
|
|
|
7db648 |
+ isym->st_shndx))
|
|
|
7db648 |
+ && sym_sec->alignment_power)
|
|
|
7db648 |
{
|
|
|
7db648 |
unsigned short new_insn =
|
|
|
7db648 |
(0xc000 | (bfd_get_8 (input_bfd,
|