summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
authormarcel <marcel@FreeBSD.org>2004-04-08 06:37:00 +0000
committermarcel <marcel@FreeBSD.org>2004-04-08 06:37:00 +0000
commit9584da2d1fe1984c53c4fe82ce894cee2046919b (patch)
treef00e6d3c5abb6f309ea25538b3927ce7f48847c6 /sys/kern
parent72bca63fd4d3b1be1b8b39d1701949506ba338d8 (diff)
downloadFreeBSD-src-9584da2d1fe1984c53c4fe82ce894cee2046919b.zip
FreeBSD-src-9584da2d1fe1984c53c4fe82ce894cee2046919b.tar.gz
Do not assume that the initial thread (i.e. the thread with the ID
equal to the process ID) is still present when we dump a core. It already may have been destroyed. In that case we would end up dereferencing a NULL pointer, so specifically test for that as well. Reported & tested by: Dan Nelson <dnelson@allantgroup.com>
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/imgact_elf.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/sys/kern/imgact_elf.c b/sys/kern/imgact_elf.c
index 7728469..46c2477 100644
--- a/sys/kern/imgact_elf.c
+++ b/sys/kern/imgact_elf.c
@@ -1178,18 +1178,21 @@ __elfN(puthdr)(struct proc *p, void *dst, size_t *off, int numsegs)
sizeof *psinfo);
/*
- * We want to start with the registers of the first thread in the
+ * We want to start with the registers of the initial thread in the
* process so that the .reg and .reg2 pseudo-sections created by bfd
* will be identical to the .reg/$PID and .reg2/$PID pseudo-sections.
* This makes sure that any tool that only looks for .reg and .reg2
* and not for .reg/$PID and .reg2/$PID will behave the same as
- * before. The first thread is the thread with an ID equal to the
+ * before. The first thread is the thread with an ID equal to the
* process' ID.
+ * Note that the initial thread may already be gone. In that case
+ * 'first' is NULL.
*/
- first = TAILQ_FIRST(&p->p_threads);
- while (first->td_tid > PID_MAX)
+ thr = first = TAILQ_FIRST(&p->p_threads);
+ while (first != NULL && first->td_tid > PID_MAX)
first = TAILQ_NEXT(first, td_plist);
- thr = first;
+ if (first != NULL)
+ thr = first;
do {
if (dst != NULL) {
status->pr_version = PRSTATUS_VERSION;
@@ -1209,7 +1212,7 @@ __elfN(puthdr)(struct proc *p, void *dst, size_t *off, int numsegs)
/* XXX allow for MD specific notes. */
thr = (thr == first) ? TAILQ_FIRST(&p->p_threads) :
TAILQ_NEXT(thr, td_plist);
- if (thr == first)
+ if (thr == first && thr != NULL)
thr = TAILQ_NEXT(thr, td_plist);
} while (thr != NULL);
OpenPOWER on IntegriCloud