]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
RISC-V: Fix the offset of CFA relocation.
authorKuan-Lin Chen <rufus@andestech.com>
Thu, 2 Feb 2017 07:27:18 +0000 (15:27 +0800)
committerPalmer Dabbelt <palmer@dabbelt.com>
Thu, 30 Mar 2017 20:00:16 +0000 (13:00 -0700)
gas/ChangeLog:

2017-03-02  Kuan-Lin Chen  <rufus@andestech.com>

        * config/tc-riscv.c (md_apply_fix): Compute the correct offsets
        for CFA relocations.

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

index 90a532ddb42d7d53a8749b8e6eb20f6677b2af5e..50a7303995e8aaaf0ad963c6dd747e48a49d2e7c 100644 (file)
@@ -1,3 +1,8 @@
+2017-03-02  Kuan-Lin Chen  <rufus@andestech.com>
+
+       * config/tc-riscv.c (md_apply_fix): Compute the correct offsets
+       for CFA relocations.
+
 2017-03-27  Alan Modra  <amodra@gmail.com>
 
        PR 21303
index ec5b0bb03629d506bc76250eed4eb2cb0a25a655..c79f313617837eeced1107b15c36e2ab528f5001 100644 (file)
@@ -1837,6 +1837,7 @@ md_apply_fix (fixS *fixP, valueT *valP, segT seg ATTRIBUTE_UNUSED)
   unsigned int subtype;
   bfd_byte *buf = (bfd_byte *) (fixP->fx_frag->fr_literal + fixP->fx_where);
   bfd_boolean relaxable = FALSE;
+  offsetT loc;
 
   /* Remember value for tc_gen_reloc.  */
   fixP->fx_addnumber = *valP;
@@ -1922,30 +1923,31 @@ md_apply_fix (fixS *fixP, valueT *valP, segT seg ATTRIBUTE_UNUSED)
 
            case BFD_RELOC_RISCV_CFA:
              /* Load the byte to get the subtype.  */
-             subtype = bfd_get_8 (NULL, &fixP->fx_frag->fr_literal[fixP->fx_where]);
+             subtype = bfd_get_8 (NULL, &((fragS *) (fixP->fx_frag->fr_opcode))->fr_literal[fixP->fx_where]);
+             loc = fixP->fx_frag->fr_fix - (subtype & 7);
              switch (subtype)
                {
                case DW_CFA_advance_loc1:
-                 fixP->fx_where++;
-                 fixP->fx_next->fx_where++;
+                 fixP->fx_where = loc + 1;
+                 fixP->fx_next->fx_where = loc + 1;
                  fixP->fx_r_type = BFD_RELOC_RISCV_SET8;
                  fixP->fx_next->fx_r_type = BFD_RELOC_RISCV_SUB8;
                  break;
 
                case DW_CFA_advance_loc2:
                  fixP->fx_size = 2;
-                 fixP->fx_where++;
                  fixP->fx_next->fx_size = 2;
-                 fixP->fx_next->fx_where++;
+                 fixP->fx_where = loc + 1;
+                 fixP->fx_next->fx_where = loc + 1;
                  fixP->fx_r_type = BFD_RELOC_RISCV_SET16;
                  fixP->fx_next->fx_r_type = BFD_RELOC_RISCV_SUB16;
                  break;
 
                case DW_CFA_advance_loc4:
                  fixP->fx_size = 4;
-                 fixP->fx_where++;
                  fixP->fx_next->fx_size = 4;
-                 fixP->fx_next->fx_where++;
+                 fixP->fx_where = loc;
+                 fixP->fx_next->fx_where = loc;
                  fixP->fx_r_type = BFD_RELOC_RISCV_SET32;
                  fixP->fx_next->fx_r_type = BFD_RELOC_RISCV_SUB32;
                  break;
@@ -2069,7 +2071,6 @@ riscv_pre_output_hook (void)
          {
            if (frag->fr_type == rs_cfa)
              {
-               fragS *loc4_frag;
                expressionS exp;
 
                symbolS *add_symbol = frag->fr_symbol->sy_value.X_add_symbol;
@@ -2080,8 +2081,7 @@ riscv_pre_output_hook (void)
                exp.X_add_number = 0;
                exp.X_op_symbol = op_symbol;
 
-               loc4_frag = (fragS *) frag->fr_opcode;
-               fix_new_exp (loc4_frag, (int) frag->fr_offset, 1, &exp, 0,
+               fix_new_exp (frag, (int) frag->fr_offset, 1, &exp, 0,
                             BFD_RELOC_RISCV_CFA);
              }
          }