]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
elf: Report corrupted group section
authorH.J. Lu <hjl.tools@gmail.com>
Fri, 20 Jun 2025 22:52:00 +0000 (06:52 +0800)
committerH.J. Lu <hjl.tools@gmail.com>
Mon, 23 Jun 2025 14:28:14 +0000 (22:28 +0800)
Report corrupted group section instead of trying to recover.

PR binutils/33050
* elf.c (bfd_elf_set_group_contents): Report corrupted group
section.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
bfd/elf.c

index 14ce15c72545222a7f01c079f197f5d3780e23a7..ee894eb05f201ce677e16cffd9ce955cefe626a7 100644 (file)
--- a/bfd/elf.c
+++ b/bfd/elf.c
@@ -3971,20 +3971,17 @@ bfd_elf_set_group_contents (bfd *abfd, asection *sec, void *failedptrarg)
        break;
     }
 
-  /* We should always get here with loc == sec->contents + 4, but it is
-     possible to craft bogus SHT_GROUP sections that will cause segfaults
-     in objcopy without checking loc here and in the loop above.  */
-  if (loc == sec->contents)
-    BFD_ASSERT (0);
-  else
+  /* We should always get here with loc == sec->contents + 4.  Return
+     an error for bogus SHT_GROUP sections.  */
+  loc -= 4;
+  if (loc != sec->contents)
     {
-      loc -= 4;
-      if (loc != sec->contents)
-       {
-         BFD_ASSERT (0);
-         memset (sec->contents + 4, 0, loc - sec->contents);
-         loc = sec->contents;
-       }
+      /* xgettext:c-format */
+      _bfd_error_handler (_("%pB: corrupted group section: `%pA'"),
+                         abfd, sec);
+      bfd_set_error (bfd_error_bad_value);
+      *failedptr = true;
+      return;
     }
 
   H_PUT_32 (abfd, sec->flags & SEC_LINK_ONCE ? GRP_COMDAT : 0, loc);