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.
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;
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