* elf64-alpha.c (elf64_alpha_relax_section): Don't store computed gp.
authorRichard Henderson <rth@redhat.com>
Sat, 1 Jun 2002 21:56:41 +0000 (21:56 +0000)
committerRichard Henderson <rth@redhat.com>
Sat, 1 Jun 2002 21:56:41 +0000 (21:56 +0000)
bfd/ChangeLog
bfd/elf64-alpha.c

index e3090a230ba6b9b620fdda2e73c75ab85ed386ea..bc28d60b1480c57dc9619cef461334b66a53466f 100644 (file)
@@ -1,5 +1,7 @@
 2002-06-01  Richard Henderson  <rth@redhat.com>
 
+       * elf64-alpha.c (elf64_alpha_relax_section): Don't store computed gp.
+
        * elf64-alpha.c (elf64_alpha_check_relocs): Fix typo on maybe_dynamic
        check; don't suppress dynamic relocs for non-allocated sections.
 
index 5986aef8f1343daef2a931dc438a59724b92fcfe..c37a81298abfe2e14ef56f1364aaef3ba083a496 100644 (file)
@@ -1656,19 +1656,15 @@ elf64_alpha_relax_section (abfd, sec, link_info, again)
   info.relocs = internal_relocs;
   info.relend = irelend = internal_relocs + sec->reloc_count;
 
-  /* Find the GP for this object.  */
+  /* Find the GP for this object.  Do not store the result back via 
+     _bfd_set_gp_value, since this could change again before final.  */
   info.gotobj = alpha_elf_tdata (abfd)->gotobj;
   if (info.gotobj)
     {
       asection *sgot = alpha_elf_tdata (info.gotobj)->got;
-      info.gp = _bfd_get_gp_value (info.gotobj);
-      if (info.gp == 0)
-       {
-         info.gp = (sgot->output_section->vma
-                    + sgot->output_offset
-                    + 0x8000);
-         _bfd_set_gp_value (info.gotobj, info.gp);
-       }
+      info.gp = (sgot->output_section->vma
+                + sgot->output_offset
+                + 0x8000);
     }
 
   for (irel = internal_relocs; irel < irelend; irel++)