diff options
author | Daniel Jacobowitz <dan@debian.org> | 2005-05-20 22:02:08 +0000 |
---|---|---|
committer | Daniel Jacobowitz <dan@debian.org> | 2005-05-20 22:02:08 +0000 |
commit | daec67b3a92a799bf8e6e5966ff0c98f39a33264 (patch) | |
tree | b2e73e08f07672229411e3554abd28bc04023dfb | |
parent | 1142a712a0fea9b2d5403e5cca5b978d283be73f (diff) | |
download | binutils-redhat-daec67b3a92a799bf8e6e5966ff0c98f39a33264.tar.gz |
* elf32-i386.c (elf_i386_adjust_dynamic_symbol): Don't eliminate
copy relocations for VxWorks.
-rw-r--r-- | bfd/ChangeLog | 5 | ||||
-rw-r--r-- | bfd/elf32-i386.c | 12 |
2 files changed, 12 insertions, 5 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index a32d1fced2..d05d1853a6 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,10 @@ 2005-05-20 Daniel Jacobowitz <dan@codesourcery.com> + * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Don't eliminate + copy relocations for VxWorks. + +2005-05-20 Daniel Jacobowitz <dan@codesourcery.com> + * bfd/elf32-ppc.c (struct ppc_elf_link_hash_entry): Add new field has_sda_refs. (ppc_elf_copy_indirect_symbol): Copy has_sda_refs. diff --git a/bfd/elf32-i386.c b/bfd/elf32-i386.c index bfc3417c10..3e5f33939a 100644 --- a/bfd/elf32-i386.c +++ b/bfd/elf32-i386.c @@ -1431,7 +1431,13 @@ elf_i386_adjust_dynamic_symbol (struct bfd_link_info *info, return TRUE; } - if (ELIMINATE_COPY_RELOCS) + htab = elf_i386_hash_table (info); + + /* If there aren't any dynamic relocs in read-only sections, then + we can keep the dynamic relocs and avoid the copy reloc. This + doesn't work on VxWorks, where we can not have dynamic relocations + (other than copy and jump slot relocations) in an executable. */ + if (ELIMINATE_COPY_RELOCS && !htab->is_vxworks) { struct elf_i386_link_hash_entry * eh; struct elf_i386_dyn_relocs *p; @@ -1444,8 +1450,6 @@ elf_i386_adjust_dynamic_symbol (struct bfd_link_info *info, break; } - /* If we didn't find any dynamic relocs in read-only sections, then - we'll be keeping the dynamic relocs and avoiding the copy reloc. */ if (p == NULL) { h->non_got_ref = 0; @@ -1463,8 +1467,6 @@ elf_i386_adjust_dynamic_symbol (struct bfd_link_info *info, both the dynamic object and the regular object will refer to the same memory location for the variable. */ - htab = elf_i386_hash_table (info); - /* We must generate a R_386_COPY reloc to tell the dynamic linker to copy the initial value out of the dynamic object and into the runtime process image. */ |