* elf.c (elfcore_grok_nto_status): Only set lwpid for the active or

signalled thread.
	(elfcore_grok_nto_gregs): Only make .reg section for the active thread.
This commit is contained in:
Alan Modra 2003-05-29 23:50:04 +00:00
parent d2427a719b
commit f8843e8713
2 changed files with 28 additions and 6 deletions

View file

@ -1,3 +1,9 @@
2003-05-30 Kris Warkentin <kewarken@qnx.com>
* elf.c (elfcore_grok_nto_status): Only set lwpid for the active or
signalled thread.
(elfcore_grok_nto_gregs): Only make .reg section for the active thread.
2003-05-29 Nick Clifton <nickc@redhat.com> 2003-05-29 Nick Clifton <nickc@redhat.com>
* pef.c: Include "safe-ctype.h" instead of <ctype.h>. * pef.c: Include "safe-ctype.h" instead of <ctype.h>.

View file

@ -7015,18 +7015,30 @@ elfcore_grok_nto_status (abfd, note, tid)
char buf[100]; char buf[100];
char *name; char *name;
asection *sect; asection *sect;
short sig;
unsigned flags;
/* nto_procfs_status 'pid' field is at offset 0. */ /* nto_procfs_status 'pid' field is at offset 0. */
elf_tdata (abfd)->core_pid = bfd_get_32 (abfd, (bfd_byte *) ddata); elf_tdata (abfd)->core_pid = bfd_get_32 (abfd, (bfd_byte *) ddata);
/* nto_procfs_status 'tid' field is at offset 4. */ /* nto_procfs_status 'tid' field is at offset 4. Pass it back. */
elf_tdata (abfd)->core_lwpid = bfd_get_32 (abfd, (bfd_byte *) ddata + 4); *tid = bfd_get_32 (abfd, (bfd_byte *) ddata + 4);
/* nto_procfs_status 'flags' field is at offset 8. */
flags = bfd_get_32 (abfd, (bfd_byte *) ddata + 8);
/* nto_procfs_status 'what' field is at offset 14. */ /* nto_procfs_status 'what' field is at offset 14. */
elf_tdata (abfd)->core_signal = bfd_get_16 (abfd, (bfd_byte *) ddata + 14); if ((sig = bfd_get_16 (abfd, (bfd_byte *) ddata + 14)) > 0)
{
elf_tdata (abfd)->core_signal = sig;
elf_tdata (abfd)->core_lwpid = *tid;
}
/* Pass tid back. */ /* _DEBUG_FLAG_CURTID (current thread) is 0x80. Some cores
*tid = elf_tdata (abfd)->core_lwpid; do not come from signals so we make sure we set the current
thread just in case. */
if (flags & 0x00000080)
elf_tdata (abfd)->core_lwpid = *tid;
/* Make a ".qnx_core_status/%d" section. */ /* Make a ".qnx_core_status/%d" section. */
sprintf (buf, ".qnx_core_status/%d", *tid); sprintf (buf, ".qnx_core_status/%d", *tid);
@ -7075,7 +7087,11 @@ elfcore_grok_nto_gregs (abfd, note, tid)
sect->flags = SEC_HAS_CONTENTS; sect->flags = SEC_HAS_CONTENTS;
sect->alignment_power = 2; sect->alignment_power = 2;
/* This is the current thread. */
if (elf_tdata (abfd)->core_lwpid == tid)
return elfcore_maybe_make_sect (abfd, ".reg", sect); return elfcore_maybe_make_sect (abfd, ".reg", sect);
return TRUE;
} }
#define BFD_QNT_CORE_INFO 7 #define BFD_QNT_CORE_INFO 7