aarch64-pe can't fill 16 bytes in section .text
authorAlan Modra <amodra@gmail.com>
Tue, 15 Nov 2022 08:13:43 +0000 (18:43 +1030)
committerAlan Modra <amodra@gmail.com>
Tue, 15 Nov 2022 21:21:24 +0000 (07:51 +1030)
Without commit b66e671854, this:
 .p2align 4
 nop
 .p2align 3
 nop
results in an error when coff_frob_section attempts to pad out the
section to a 16-byte boundary.  Due to miscalculating the pad pattern
repeat count, write.c:write_contents attempts to shove 16 bytes of
padding into the remaining 4 bytes of the .text section.

* config/obj-coff.c (coff_frob_section): Correct fill count.
Don't pad after errors.

gas/config/obj-coff.c

index 98c39e43907a4e98ad46de479264352a8b7dd531..9be697fb62ede85aa69e4cf09e88d9febd48a0c6 100644 (file)
@@ -1725,7 +1725,8 @@ coff_frob_section (segT sec)
   bfd_vma align_power = (bfd_vma) sec->alignment_power + OCTETS_PER_BYTE_POWER;
   bfd_vma mask = ((bfd_vma) 1 << align_power) - 1;
 
-  if (size & mask)
+  if (!do_not_pad_sections_to_alignment
+      && (size & mask) != 0)
     {
       bfd_vma new_size;
       fragS *last;
@@ -1740,7 +1741,10 @@ coff_frob_section (segT sec)
       while (fragp->fr_next != last)
        fragp = fragp->fr_next;
       last->fr_address = size;
-      fragp->fr_offset += new_size - size;
+      if ((new_size - size) % fragp->fr_var == 0)
+       fragp->fr_offset += (new_size - size) / fragp->fr_var;
+      else
+       abort ();
     }
 #endif