pdp11 reloc processing
authorAlan Modra <amodra@gmail.com>
Thu, 20 Feb 2020 13:05:21 +0000 (23:35 +1030)
committerAlan Modra <amodra@gmail.com>
Fri, 21 Feb 2020 00:17:05 +0000 (10:47 +1030)
This allows pdp11 to handle 32-bit fixups that can be applied by gas,
and improves the error message emitted when the required reloc isn't
available.

* config/tc-pdp11.c (md_apply_fix): Handle BFD_RELOC_32.
(tc_gen_reloc): Only give a BAD_CASE assertion on pcrel relocs.

gas/ChangeLog
gas/config/tc-pdp11.c

index 4bc78e9bfc298d8eca462190706c97c766dd029b..01cce9f4bd3160b250865576ebc8937ba29694ad 100644 (file)
@@ -1,3 +1,8 @@
+2020-02-21  Alan Modra  <amodra@gmail.com>
+
+       * config/tc-pdp11.c (md_apply_fix): Handle BFD_RELOC_32.
+       (tc_gen_reloc): Only give a BAD_CASE assertion on pcrel relocs.
+
 2020-02-21  Alan Modra  <amodra@gmail.com>
 
        PR 25569
index 7b3f663d1288cc1b65208d228edd270408c528f9..d38a3cd6d2598fb2a9372c9f46ae0d1f755390b8 100644 (file)
@@ -257,6 +257,10 @@ md_apply_fix (fixS *fixP,
       mask = 0xffff;
       shift = 0;
       break;
+    case BFD_RELOC_32:
+      mask = 0xffffffff;
+      shift = 0;
+      break;
     case BFD_RELOC_PDP11_DISP_8_PCREL:
       mask = 0x00ff;
       shift = 1;
@@ -1419,22 +1423,22 @@ tc_gen_reloc (asection *section ATTRIBUTE_UNUSED,
   /* This is taken account for in md_apply_fix().  */
   reloc->addend = -symbol_get_bfdsym (fixp->fx_addsy)->section->vma;
 
-  switch (fixp->fx_r_type)
+  code = fixp->fx_r_type;
+  if (fixp->fx_pcrel)
     {
-    case BFD_RELOC_16:
-      if (fixp->fx_pcrel)
-       code = BFD_RELOC_16_PCREL;
-      else
-       code = BFD_RELOC_16;
-      break;
+      switch (code)
+       {
+       case BFD_RELOC_16:
+         code = BFD_RELOC_16_PCREL;
+         break;
 
-    case BFD_RELOC_16_PCREL:
-      code = BFD_RELOC_16_PCREL;
-      break;
+       case BFD_RELOC_16_PCREL:
+         break;
 
-    default:
-      BAD_CASE (fixp->fx_r_type);
-      return NULL;
+       default:
+         BAD_CASE (code);
+         return NULL;
+       }
     }
 
   reloc->howto = bfd_reloc_type_lookup (stdoutput, code);