diff options
author | gonzo <gonzo@FreeBSD.org> | 2010-11-07 03:26:22 +0000 |
---|---|---|
committer | gonzo <gonzo@FreeBSD.org> | 2010-11-07 03:26:22 +0000 |
commit | 9270446f7c7b3ce278eaeff10b801af559a65b09 (patch) | |
tree | 98ed4eb572986b03a6c44a0f8debce1243f56dbc /lib/libkvm/kvm_mips.c | |
parent | 4a291f4ab0ff944b9175d1c355e8aac3ba68d300 (diff) | |
download | FreeBSD-src-9270446f7c7b3ce278eaeff10b801af559a65b09.zip FreeBSD-src-9270446f7c7b3ce278eaeff10b801af559a65b09.tar.gz |
Add minidump support for MIPS
Diffstat (limited to 'lib/libkvm/kvm_mips.c')
-rw-r--r-- | lib/libkvm/kvm_mips.c | 49 |
1 files changed, 40 insertions, 9 deletions
diff --git a/lib/libkvm/kvm_mips.c b/lib/libkvm/kvm_mips.c index d311c84..d311b9e 100644 --- a/lib/libkvm/kvm_mips.c +++ b/lib/libkvm/kvm_mips.c @@ -49,29 +49,62 @@ __FBSDID("$FreeBSD$"); #include <limits.h> #include <kvm.h> #include <stdlib.h> +#include <string.h> +#include <unistd.h> #include "kvm_private.h" +/* minidump must be the first item! */ +struct vmstate { + int minidump; /* 1 = minidump mode */ + void *mmapbase; + size_t mmapsize; +}; + void _kvm_freevtop(kvm_t *kd) { - - _kvm_err(kd, 0, "Unimplemented function"); + if (kd->vmst != 0) { + if (kd->vmst->minidump) + return (_kvm_minidump_freevtop(kd)); + if (kd->vmst->mmapbase != NULL) + munmap(kd->vmst->mmapbase, kd->vmst->mmapsize); + free(kd->vmst); + kd->vmst = NULL; + } } int _kvm_initvtop(kvm_t *kd) { + char minihdr[8]; - _kvm_err(kd, 0, "Unimplemented function"); - return (0); + if (!kd->rawdump) { + if (pread(kd->pmfd, &minihdr, 8, 0) == 8) { + if (memcmp(&minihdr, "minidump", 8) == 0) + return (_kvm_minidump_initvtop(kd)); + } else { + _kvm_err(kd, kd->program, "cannot read header"); + return (-1); + } + } + + _kvm_err(kd, 0, "_kvm_initvtop: Unsupported image type"); + return (-1); } int -_kvm_kvatop(kvm_t *kd, u_long va __unused, off_t *pa __unused) +_kvm_kvatop(kvm_t *kd, u_long va , off_t *pa) { - _kvm_err(kd, 0, "Unimplemented function"); + u_long offset = va & (PAGE_SIZE - 1); + struct vmstate *vm = kd->vmst; + + if (kd->vmst->minidump) + return _kvm_minidump_kvatop(kd, va, pa); + + + _kvm_err(kd, 0, "_kvm_kvatop: Unsupported image type"); return (0); } @@ -81,10 +114,8 @@ _kvm_kvatop(kvm_t *kd, u_long va __unused, off_t *pa __unused) * have to deal with these NOT being constants! (i.e. m68k) */ int -_kvm_mdopen(kd) - kvm_t *kd; +_kvm_mdopen(kvm_t *kd __unused) { - _kvm_err(kd, 0, "Unimplemented function"); return (0); } |