* rescoff.c (write_coff_file): Use 64-bit alignment for resource
authorNick Clifton <nickc@redhat.com>
Wed, 13 Nov 2013 12:54:29 +0000 (12:54 +0000)
committerNick Clifton <nickc@redhat.com>
Wed, 13 Nov 2013 12:54:29 +0000 (12:54 +0000)
data.
(coff_res_to_bin): Likewise.

binutils/ChangeLog
binutils/rescoff.c

index 237debe8aaa4e370e58f32e9dbe3b7d57321eb29..cc9c6f9c5cd304c9a3730539ddce24c4b295509f 100644 (file)
@@ -1,3 +1,9 @@
+2013-11-13  Martin Mitas  <mity@morous.org>
+
+       * rescoff.c (write_coff_file): Use 64-bit alignment for resource
+       data.
+       (coff_res_to_bin): Likewise.
+
 2013-11-07  Doug Evans  <dje@google.com>
 
        Add pretty-printing of .debug_gnu_pubnames, .debug_gnu_pubtypes.
index 8799ea2bd46b2d1bb0847fcb6eee7cc2970740f6..c59471914f8b08e7fc8ec2ae67742b9bf7bd7799 100644 (file)
@@ -1,6 +1,5 @@
 /* rescoff.c -- read and write resources in Windows COFF files.
-   Copyright 1997, 1998, 1999, 2000, 2003, 2005, 2007, 2008
-   Free Software Foundation, Inc.
+   Copyright 1997-2013 Free Software Foundation, Inc.
    Written by Ian Lance Taylor, Cygnus Support.
    Rewritten by Kai Tietz, Onevision.
 
@@ -501,22 +500,22 @@ write_coff_file (const char *filename, const char *target,
      know the various offsets we will need.  */
   coff_bin_sizes (resources, &cwi);
 
-  /* Force the directory strings to be 32 bit aligned.  Every other
-     structure is 32 bit aligned anyhow.  */
-  cwi.dirstrsize = (cwi.dirstrsize + 3) &~ 3;
+  /* Force the directory strings to be 64 bit aligned.  Every other
+     structure is 64 bit aligned anyhow.  */
+  cwi.dirstrsize = (cwi.dirstrsize + 7) & ~7;
 
   /* Actually convert the resources to binary.  */
   coff_to_bin (resources, &cwi);
 
-  /* Add another 2 bytes to the directory strings if needed for
+  /* Add another few bytes to the directory strings if needed for
      alignment.  */
-  if ((cwi.dirstrs.length & 3) != 0)
+  if ((cwi.dirstrs.length & 7) != 0)
     {
+      rc_uint_type pad = 8 - (cwi.dirstrs.length & 7);
       bfd_byte *ex;
 
-      ex = coff_alloc (&cwi.dirstrs, 2);
-      ex[0] = 0;
-      ex[1] = 0;
+      ex = coff_alloc (& cwi.dirstrs, pad);
+      memset (ex, 0, pad);
     }
 
   /* Make sure that the data we built came out to the same size as we
@@ -741,10 +740,10 @@ coff_res_to_bin (const rc_res_resource *res, struct coff_write_info *cwi)
     cwi->resources.last->next = d;
 
   cwi->resources.last = d;
-  cwi->resources.length += (d->length + 3) & ~3;
+  cwi->resources.length += (d->length + 7) & ~7;
 
   windres_put_32 (cwi->wrbfd, erd->size, d->length);
 
-  /* Force the next resource to have 32 bit alignment.  */
-  d->length = (d->length + 3) & ~3;
+  /* Force the next resource to have 64 bit alignment.  */
+  d->length = (d->length + 7) & ~7;
 }