+2022-09-09  Nick Clifton  <nickc@redhat.com>
+
+       PR 29532
+       * elf.c (setup_group): Do not return false if there is no group
+       information available.
+
 2022-09-02  Aaron Merey  <amerey@redhat.com>
 
        * aout-target.h (MY_find_nearest_line_with_alt): New macro.
 
       /* xgettext:c-format */
       _bfd_error_handler (_("%pB: no group info for section '%pA'"),
                          abfd, newsect);
-      return false;
+      /* PR 29532: Return true here, even though the group info has not been
+        read.  Separate debug info files can have empty group sections, but
+        we do not want this to prevent them from being loaded as otherwise
+        GDB will not be able to use them.  */
+      return true;
     }
   return true;
 }
 
+2022-09-09  Nick Clifton  <nickc@redhat.com>
+
+       PR 29532
+       * objcopy.c (setup_section): Leave group sections intact when
+       creating separate debuginfo files.
+
 2022-09-08  Nick Clifton  <nickc@redhat.com>
 
        PR 29523
 
           && (flags & (SEC_ALLOC | SEC_GROUP)) != 0
           && !is_nondebug_keep_contents_section (ibfd, isection))
     {
-      flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
+      flagword remove = SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP;
+
       if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
        {
-         make_nobits = true;
+         /* PR 29532: Copy group sections intact as otherwise we end up with
+            empty groups.  This prevents separate debug info files from
+            being used with GDB, if they were based upon files that
+            originally contained groups.  */
+         if (flags & SEC_GROUP)
+           remove = SEC_LOAD;
+         else
+           make_nobits = true;
 
          /* Twiddle the input section flags so that it seems to
             elf.c:copy_private_bfd_data that section flags have not
             changed between input and output sections.  This hack
             prevents wholesale rewriting of the program headers.  */
-         isection->flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
+         isection->flags &= ~remove;
        }
+      flags &= ~remove;
     }
 
   osection = bfd_make_section_anyway_with_flags (obfd, name, flags);