diff options
author | Kaz Kojima <kkojima@rr.iij4u.or.jp> | 2011-06-22 22:02:16 +0000 |
---|---|---|
committer | Kaz Kojima <kkojima@rr.iij4u.or.jp> | 2011-06-22 22:02:16 +0000 |
commit | b68593b98ef56827eedce7c84e9845ac6ba06999 (patch) | |
tree | 86174d920cde04402297323733157637477286ef /bfd | |
parent | b24539b3f73987e158d7c34fee758f40297d69d9 (diff) | |
download | gdb-b68593b98ef56827eedce7c84e9845ac6ba06999.zip gdb-b68593b98ef56827eedce7c84e9845ac6ba06999.tar.gz gdb-b68593b98ef56827eedce7c84e9845ac6ba06999.tar.bz2 |
* elf32-sh.c (sh_elf_relocate_section): Allow R_SH_TLS_LE_32 for PIE.
(sh_elf_check_relocs): Likewise.
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 5 | ||||
-rw-r--r-- | bfd/elf32-sh.c | 4 |
2 files changed, 7 insertions, 2 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 59cfd13..877f0c8 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2011-06-22 Kaz Kojima <kkojima@rr.iij4u.or.jp> + + * elf32-sh.c (sh_elf_relocate_section): Allow R_SH_TLS_LE_32 for PIE. + (sh_elf_check_relocs): Likewise. + 2011-06-22 Richard Henderson <rth@redhat.com> * elf64-alpha.c (elf64_alpha_check_relocs): No dynamic reloc for diff --git a/bfd/elf32-sh.c b/bfd/elf32-sh.c index b85b7c2..ca2c4af 100644 --- a/bfd/elf32-sh.c +++ b/bfd/elf32-sh.c @@ -5516,7 +5516,7 @@ sh_elf_relocate_section (bfd *output_bfd, struct bfd_link_info *info, check_segment[0] = check_segment[1] = -1; - if (! info->shared) + if (! info->shared || info->pie) { relocation = tpoff (info, relocation); addend = rel->r_addend; @@ -6614,7 +6614,7 @@ sh_elf_check_relocs (bfd *abfd, struct bfd_link_info *info, asection *sec, break; case R_SH_TLS_LE_32: - if (info->shared) + if (info->shared && !info->pie) { (*_bfd_error_handler) (_("%B: TLS local exec code cannot be linked into shared objects"), |