* elf64-sparc.c (sparc64_elf_relocate_section): Adjust addend of
authorAlan Modra <amodra@gmail.com>
Tue, 5 Nov 2002 22:59:23 +0000 (22:59 +0000)
committerAlan Modra <amodra@gmail.com>
Tue, 5 Nov 2002 22:59:23 +0000 (22:59 +0000)
dynamic relocs against section symbols for the output section vma.

bfd/ChangeLog
bfd/elf64-sparc.c

index bfa082be5d42f4fca1cfd15781ed8efe72870929..4dd935b3ba4d4d0a7bba75fc8b3573ee1f1abe25 100644 (file)
@@ -1,3 +1,9 @@
+2002-11-06  David O'Brien  <obrien@FreeBSD.org>
+           Alan Modra  <amodra@bigpond.net.au>
+
+       * elf64-sparc.c (sparc64_elf_relocate_section): Adjust addend of
+       dynamic relocs against section symbols for the output section vma.
+
 2002-11-05  Alan Modra  <amodra@bigpond.net.au>
 
        * elf32-arm.h (t2a1_push_insn, t2a2_ldr_insn, t2a3_mov_insn,
index f79d76c30bd244658d8fdda7203dc1ca119eb1da..e3a120bba082a5cd5b5a5bdfbe83631db736efb4 100644 (file)
@@ -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;
                      }
                  }