]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
bfd / PE/COFF: avoid setting SEC_ALLOC when finding IMAGE_SCN_MEM_DISCARDABLE
authorJan Beulich <jbeulich@suse.com>
Fri, 10 Oct 2025 13:58:30 +0000 (15:58 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 10 Oct 2025 13:58:30 +0000 (15:58 +0200)
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.

bfd/coffcode.h

index 4a1f4be3773981ebe1543e12da3efc2809b3237e..a466af19736ef9941e8f739cf0ced731c1143024 100644 (file)
@@ -1347,6 +1347,11 @@ styp_to_sec_flags (bfd *abfd,
          || 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