]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
bfd: support for NT_386_TLS notes
authorAndrew Burgess <aburgess@redhat.com>
Fri, 25 Jul 2025 18:51:58 +0000 (19:51 +0100)
committerAndrew Burgess <aburgess@redhat.com>
Thu, 14 Aug 2025 15:06:47 +0000 (16:06 +0100)
In a later commit I'd like to add support to GDB for including the
NT_386_TLS note in the core files that GDB creates (using 'gcore'
command).

To achieve this we need some standard boilerplate code added to bfd.

The only part of this patch which I think needs consideration is the
name I selected for the pseudo section to hold the note contents when
a core file is loaded.  I chose '.reg-i386-tls'.  The '.reg' prefix is
the standard used by most other pseudo sections, and the '-i386-tls'
suffix seemed to match the note name, though I added the 'i' to
'i386', instead of just using '.reg-386-tls'.  I thought 'i386' seemed
clearer.

There's no test included here, but when I merge the NT_386_TLS
creation to GDB it will depend on this and act as a test.  I plan to
post that work to the GDB list once this patch is merged.

bfd/elf-bfd.h
bfd/elf.c

index f24342cb029a8ae243ef506a7b0ee83051892be9..accdd6d41a8a7c99ea277321a2d00bcef0cff799 100644 (file)
@@ -2927,6 +2927,8 @@ extern char *elfcore_write_xstatereg
   (bfd *, char *, int *, const void *, int);
 extern char *elfcore_write_x86_segbases
   (bfd *, char *, int *, const void *, int);
+extern char *elfcore_write_i386_tls
+  (bfd *, char *, int *, const void *, int);
 extern char *elfcore_write_ppc_vmx
   (bfd *, char *, int *, const void *, int);
 extern char *elfcore_write_ppc_vsx
index 1b2e331eaa8fa3ba4d45417f1b49578a6f798256..4f6bcde236545b20fabd5c2a8ae6b5d0c16a7e8d 100644 (file)
--- a/bfd/elf.c
+++ b/bfd/elf.c
@@ -49,6 +49,10 @@ SECTION
 #include CORE_HEADER
 #endif
 
+/* Name of a pseudo-section which represents NT_386_TLS notes within a core
+   file.  */
+#define PSEUDO_SECTION_NAME_I386_TLS ".reg-i386-tls"
+
 static int elf_sort_sections (const void *, const void *);
 static bool assign_file_positions_except_relocs (bfd *, struct bfd_link_info *);
 static bool swap_out_syms (bfd *, struct elf_strtab_hash **, int,
@@ -10673,6 +10677,13 @@ elfcore_grok_gdb_tdesc (bfd *abfd, Elf_Internal_Note *note)
   return elfcore_make_note_pseudosection (abfd, ".gdb-tdesc", note);
 }
 
+static bool
+elfcore_grok_i386_tls (bfd *abfd, Elf_Internal_Note *note)
+{
+  return elfcore_make_note_pseudosection (abfd, PSEUDO_SECTION_NAME_I386_TLS,
+                                         note);
+}
+
 static bool
 elfcore_grok_loongarch_cpucfg (bfd *abfd, Elf_Internal_Note *note)
 {
@@ -11336,6 +11347,13 @@ elfcore_grok_note (bfd *abfd, Elf_Internal_Note *note)
       else
        return true;
 
+    case NT_386_TLS:
+      if (note->namesz == 6
+         && strcmp (note->namedata, "LINUX") == 0)
+       return elfcore_grok_i386_tls (abfd, note);
+      else
+       return true;
+
     case NT_ARM_HW_BREAK:
       if (note->namesz == 6
          && strcmp (note->namedata, "LINUX") == 0)
@@ -12593,6 +12611,14 @@ elfcore_write_x86_segbases (bfd *abfd, char *buf, int *bufsiz,
                             note_name, NT_FREEBSD_X86_SEGBASES, regs, size);
 }
 
+char *
+elfcore_write_i386_tls (bfd *abfd, char *buf, int *bufsiz,
+                           const void *regs, int size)
+{
+  return elfcore_write_note (abfd, buf, bufsiz, "LINUX", NT_386_TLS,
+                            regs, size);
+}
+
 char *
 elfcore_write_ppc_vmx (bfd *abfd,
                       char *buf,
@@ -13287,6 +13313,8 @@ elfcore_write_register_note (bfd *abfd,
     return elfcore_write_loongarch_lsx (abfd, buf, bufsiz, data, size);
   if (strcmp (section, ".reg-loongarch-lasx") == 0)
     return elfcore_write_loongarch_lasx (abfd, buf, bufsiz, data, size);
+  if (strcmp (section, PSEUDO_SECTION_NAME_I386_TLS) == 0)
+    return elfcore_write_i386_tls (abfd, buf, bufsiz, data, size);
   return NULL;
 }