Disambiguate test for relaxation type.
authorDJ Delorie <dj@redhat.com>
Tue, 26 Aug 2014 18:03:29 +0000 (14:03 -0400)
committerDJ Delorie <dj@redhat.com>
Tue, 26 Aug 2014 18:03:29 +0000 (14:03 -0400)
* elf32-rl78.c (rl78_elf_relax_section): Disambiguate test for
relaxation type.

bfd/ChangeLog
bfd/elf32-rl78.c

index d94f590..9635195 100644 (file)
@@ -1,3 +1,8 @@
+2014-08-26  DJ Delorie  <dj@redhat.com>
+
+       * elf32-rl78.c (rl78_elf_relax_section): Disambiguate test for
+       relaxation type.
+
 2014-08-26  Jiong Wang  <jiong.wang@arm.com>
 
        * elfnn-aarch64.c (elfNN_aarch64_check_relocs): Initialize non_got_ref
index 9124e0a..2a5ec99 100644 (file)
@@ -2199,7 +2199,7 @@ rl78_elf_relax_section
         61 F3 EF ad    SKNH ; BR $rel8
        */
 
-      if (irel->r_addend & RL78_RELAXA_BRA)
+      if ((irel->r_addend & RL78_RELAXA_MASK) == RL78_RELAXA_BRA)
        {
          /* SKIP opcodes that skip non-branches will have a relax tag
             but no corresponding symbol to relax against; we just
@@ -2334,7 +2334,7 @@ rl78_elf_relax_section
 
        }
 
-      if (irel->r_addend & RL78_RELAXA_ADDR16)
+      if ((irel->r_addend &  RL78_RELAXA_MASK) == RL78_RELAXA_ADDR16)
        {
          /*----------------------------------------------------------------------*/
          /* Some insns have both a 16-bit address operand and an 8-bit