diff options
author | Alan Modra <amodra@bigpond.net.au> | 2002-11-05 22:59:23 +0000 |
---|---|---|
committer | Alan Modra <amodra@bigpond.net.au> | 2002-11-05 22:59:23 +0000 |
commit | 73ebf38bd58c7fb48d75a4b9169932f9a5f778d1 (patch) | |
tree | 6d6cd3f428eea2326718a759ce9ef15b875efa55 /bfd/elf64-sparc.c | |
parent | d2ec940daea2186ac1658f06d54a43c87f059674 (diff) | |
download | binutils-redhat-73ebf38bd58c7fb48d75a4b9169932f9a5f778d1.tar.gz |
* elf64-sparc.c (sparc64_elf_relocate_section): Adjust addend of
dynamic relocs against section symbols for the output section vma.
Diffstat (limited to 'bfd/elf64-sparc.c')
-rw-r--r-- | bfd/elf64-sparc.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/bfd/elf64-sparc.c b/bfd/elf64-sparc.c index f79d76c30b..e3a120bba0 100644 --- a/bfd/elf64-sparc.c +++ b/bfd/elf64-sparc.c @@ -2164,11 +2164,9 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section, } else { + outrel.r_addend = relocation + rel->r_addend; if (r_type == R_SPARC_64) - { - outrel.r_info = ELF64_R_INFO (0, R_SPARC_RELATIVE); - outrel.r_addend = relocation + rel->r_addend; - } + outrel.r_info = ELF64_R_INFO (0, R_SPARC_RELATIVE); else { long indx; @@ -2198,6 +2196,13 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section, osec = sec->output_section; indx = elf_section_data (osec)->dynindx; + /* We are turning this relocation into one + against a section symbol, so subtract out + the output section's address but not the + offset of the input section in the output + section. */ + outrel.r_addend -= osec->vma; + /* FIXME: we really should be able to link non-pic shared libraries. */ if (indx == 0) @@ -2216,7 +2221,6 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section, ELF64_R_TYPE_INFO ( ELF64_R_TYPE_DATA (rel->r_info), r_type)); - outrel.r_addend = relocation + rel->r_addend; } } |