Before teaching _bfd_XXi_swap_scnhdr_out() to respect SEC_ALLOC when
considering whether to force IMAGE_SCN_MEM_DISCARDABLE for a section,
make sure we won't "invert" present wrong behavior when transforming an
incoming object's section attributes to an outgoing one's (objcopy or
"ld -r"): Right now, IMAGE_SCN_MEM_DISCARDABLE would appear out of the
blue for certain sections. We don't want the opposite, though, i.e. we
want avoid silently dropping IMAGE_SCN_MEM_DISCARDABLE when it's present
for an incoming object's section.
|| startswith (name, ".sdata")))
sec_flags |= SEC_SMALL_DATA;
+ /* As there is no internal representation of the "discardable" flag,
+ reflect it by keeping SEC_ALLOC clear. */
+ if (internal_s->s_flags & IMAGE_SCN_MEM_DISCARDABLE)
+ sec_flags &= ~SEC_ALLOC;
+
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
/* As a GNU extension, if the name begins with .gnu.linkonce, we
only link a single copy of the section. This is used to support