Fetch all registers before writing the core register notes.
authorJohn Baldwin <jhb@FreeBSD.org>
Sat, 14 Mar 2015 17:47:20 +0000 (13:47 -0400)
committerJohn Baldwin <jhb@FreeBSD.org>
Mon, 16 Mar 2015 13:48:51 +0000 (09:48 -0400)
Without this, not all registers were present in the core generated by
gcore.  For example, running 'gcore' on a program without examining
the vector registers (SSE or AVX) would store all the vector registers
as zeros because they were not pulled into the regcache.  Running
'info vector' before 'gcore' would store the correct values in the
core since it populated the regcache.  For Linux processes, a similar
operation is achieved by having the thread iterator callback invoke
target_fetch_registers on each thread before its corresponding
register notes are dumped.

gdb/ChangeLog:

* fbsd-tdep.c (fbsd_make_corefile_notes): Fetch all target registers
before writing core register notes.

gdb/ChangeLog
gdb/fbsd-tdep.c

index eb8ef879a329596a5429324bac26e489121aaa86..d984565e3f5b0ba2bb7445895ecb81cf37cd4393 100644 (file)
@@ -1,3 +1,8 @@
+2015-03-16  John Baldwin  <jhb@FreeBSD.org>
+
+       * fbsd-tdep.c (fbsd_make_corefile_notes): Fetch all target registers
+       before writing core register notes.
+
 2015-03-16  Yuanhui Zhang  <asmwarrior@gmail.com>
            Pedro Alves  <palves@redhat.com>
 
index 5d17f03caca710a3b8ac3c590ebe148b37724986..9609cd8f8e4f73e81f3f313c88db5e7e31673c94 100644 (file)
@@ -89,7 +89,7 @@ fbsd_collect_regset_section_cb (const char *sect_name, int size,
 static char *
 fbsd_make_corefile_notes (struct gdbarch *gdbarch, bfd *obfd, int *note_size)
 {
-  const struct regcache *regcache = get_current_regcache ();
+  struct regcache *regcache = get_current_regcache ();
   char *note_data;
   Elf_Internal_Ehdr *i_ehdrp;
   struct fbsd_collect_regset_section_cb_data data;
@@ -104,6 +104,7 @@ fbsd_make_corefile_notes (struct gdbarch *gdbarch, bfd *obfd, int *note_size)
   data.obfd = obfd;
   data.note_data = NULL;
   data.note_size = note_size;
+  target_fetch_registers (regcache, -1);
   gdbarch_iterate_over_regset_sections (gdbarch,
                                        fbsd_collect_regset_section_cb,
                                        &data, regcache);