]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
* elf64-sparc.c (sparc64_elf_relocate_section): Adjust addend of
authorDaniel Jacobowitz <drow@false.org>
Wed, 6 Nov 2002 04:32:04 +0000 (04:32 +0000)
committerDaniel Jacobowitz <drow@false.org>
Wed, 6 Nov 2002 04:32:04 +0000 (04:32 +0000)
        dynamic relocs against section symbols for the output section vma.

bfd/ChangeLog
bfd/elf64-sparc.c

index 37652df3ce817109e97dd56e52fe291bb86341a2..1e98cf5fb8b0e2175f90d8e075df7c9f4988acab 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-10-31  David O'Brien  <obrien@FreeBSD.org>
 
        * elf-eh-frame.c (_bfd_elf_discard_section_eh_frame): Don't mix
index 920b481bf8035b4e4d3f9d3f15f00acf8370b812..1ca03dcb85443586ac0fce8dd801f33499434828 100644 (file)
@@ -2181,11 +2181,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;
@@ -2215,6 +2213,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)
@@ -2233,7 +2238,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;
                      }
                  }