This fixes a compile time warning which is being treated as an error. Older
authorNick Clifton <nickc@redhat.com>
Fri, 25 Apr 2014 16:00:20 +0000 (17:00 +0100)
committerNick Clifton <nickc@redhat.com>
Fri, 25 Apr 2014 16:00:20 +0000 (17:00 +0100)
versions of gcc complain about part of a conditional expression always
evaluating to false because of the size of the operands involved, even when
the entire expression is already known to be false.

* peXXigen.c (_bfd_XXi_swap_sym_out): Another fix for building on
a 342-bit host.  This time for older versions of gcc.

bfd/ChangeLog
bfd/peXXigen.c

index f22dc907f80991f2d957c3e0842d573eb2fd7643..ccff4ced2b75fc79088ac3061853a012e362cdb9 100644 (file)
@@ -1,3 +1,9 @@
+2014-04-25  Nick Clifton  <nickc@redhat.com>
+
+       PR ld/16821
+       * peXXigen.c (_bfd_XXi_swap_sym_out): Another fix for building on
+       a 342-bit host.  This time for older versions of gcc.
+
 2014-04-24  Nick Clifton  <nickc@redhat.com>
 
        * peXXigen.c (rsrc_print_section): Fix compile time warning for
index d462753c17e9f37474b94b45db38023128bd1ca2..dc45daf573282212352ce339a55e01b2787f1c76 100644 (file)
@@ -236,7 +236,15 @@ _bfd_XXi_swap_sym_out (bfd * abfd, void * inp, void * extp)
      reduce the absolute value to < 1^32, and then transforming the
      symbol into a section relative symbol.  This of course is a hack.  */
   if (sizeof (in->n_value) > 4
+      /* GCC 4.6.x erroneously complains about the next test always being
+        false when compiled on a 32-bit host.  (The sizeof test above
+        should have made the warning unnecessary).  Hence we have to
+        predicate the test.  It should not matter if the test is omitted
+        since the worst that can happen is that some absolute symbols
+        are needlessly converted to equivalent section relative symbols.  */
+#if defined BFD64 || ! defined __GNUC__ || __GNUC__ > 4 || __GNUC_MINOR__ > 6
       && in->n_value > ((1ULL << 32) - 1)
+#endif
       && in->n_scnum == -1)
     {
       asection * sec;
@@ -248,7 +256,7 @@ _bfd_XXi_swap_sym_out (bfd * abfd, void * inp, void * extp)
          in->n_scnum = sec->target_index;
        }
       /* else: FIXME: The value is outside the range of any section.  This
-        happens for __image_base__ and __ImageBase__ and maybe some other
+        happens for __image_base__ and __ImageBase and maybe some other
         symbols as well.  We should find a way to handle these values.  */
     }