* elf64-alpha.c (elf64_alpha_relocate_section) <R_ALPHA_GPREL32>:
authorRichard Henderson <rth@redhat.com>
Wed, 9 Apr 2003 20:08:14 +0000 (20:08 +0000)
committerRichard Henderson <rth@redhat.com>
Wed, 9 Apr 2003 20:08:14 +0000 (20:08 +0000)
        Ignore relocations against r_symndx == 0.

bfd/ChangeLog
bfd/elf64-alpha.c

index eb9b28bc880a4eff36529c6201f2dacba7230982..2396d5b72edb7604c6a844ef6f8e5c4cc4dfdbb2 100644 (file)
@@ -1,3 +1,8 @@
+2003-04-09  Richard Henderson  <rth@redhat.com>
+
+       * elf64-alpha.c (elf64_alpha_relocate_section) <R_ALPHA_GPREL32>:
+       Ignore relocations against r_symndx == 0.
+
 2003-04-09  H.J. Lu <hjl@gnu.org>
 
        * elf64-alpha.c (elf64_alpha_relocate_section): Don't return
index ddf739555539b885d70179eecc748e739865d4c1..bf18e205c0da494c48c63bb052a2680f11b82126 100644 (file)
@@ -4579,8 +4579,20 @@ elf64_alpha_relocate_section (output_bfd, info, input_bfd, input_section,
          value -= gp;
          goto default_reloc;
 
-       case R_ALPHA_GPREL16:
        case R_ALPHA_GPREL32:
+         /* If the target section was a removed linkonce section,
+            r_symndx will be zero.  In this case, assume that the
+            switch will not be used, so don't fill it in.  If we
+            do nothing here, we'll get relocation truncated messages,
+            due to the placement of the application above 4GB.  */
+         if (r_symndx == 0)
+           {
+             r = bfd_reloc_ok;
+             break;
+           }
+         /* FALLTHRU */
+
+       case R_ALPHA_GPREL16:
        case R_ALPHA_GPRELLOW:
          if (dynamic_symbol_p)
             {