diff options
author | dg <dg@FreeBSD.org> | 1994-08-11 13:38:23 +0000 |
---|---|---|
committer | dg <dg@FreeBSD.org> | 1994-08-11 13:38:23 +0000 |
commit | 89be8c23d32d180b95b71eaba7d359a86d39aa79 (patch) | |
tree | 64018b9445e968e3e3d7eda6a743f9698b886b39 | |
parent | 0dbbd21c057fe64594e4a00eab4a6b2a58930eb7 (diff) | |
download | FreeBSD-src-89be8c23d32d180b95b71eaba7d359a86d39aa79.zip FreeBSD-src-89be8c23d32d180b95b71eaba7d359a86d39aa79.tar.gz |
Made kvm routines use procfs to get out process data such as argument
strings.
-rw-r--r-- | lib/libkvm/kvm_amd64.c | 13 | ||||
-rw-r--r-- | lib/libkvm/kvm_i386.c | 13 | ||||
-rw-r--r-- | lib/libkvm/kvm_proc.c | 162 |
3 files changed, 33 insertions, 155 deletions
diff --git a/lib/libkvm/kvm_amd64.c b/lib/libkvm/kvm_amd64.c index 3dbc9ca..18f9f4d 100644 --- a/lib/libkvm/kvm_amd64.c +++ b/lib/libkvm/kvm_amd64.c @@ -132,16 +132,3 @@ int _kvm_kvatop(kvm_t *kd, u_long va, u_long *pa) { return (_kvm_vatop(kd, va, pa)); } - -/* - * Translate a user virtual address to a physical address. - */ -int -_kvm_uvatop(kvm_t *kd, const struct proc *p, u_long va, u_long *pa) { - if (ISALIVE(kd)) { - /* Not done yet */ - } else { - /* Not done yet */ - } - return ((off_t)(0)); -} diff --git a/lib/libkvm/kvm_i386.c b/lib/libkvm/kvm_i386.c index 3dbc9ca..18f9f4d 100644 --- a/lib/libkvm/kvm_i386.c +++ b/lib/libkvm/kvm_i386.c @@ -132,16 +132,3 @@ int _kvm_kvatop(kvm_t *kd, u_long va, u_long *pa) { return (_kvm_vatop(kd, va, pa)); } - -/* - * Translate a user virtual address to a physical address. - */ -int -_kvm_uvatop(kvm_t *kd, const struct proc *p, u_long va, u_long *pa) { - if (ISALIVE(kd)) { - /* Not done yet */ - } else { - /* Not done yet */ - } - return ((off_t)(0)); -} diff --git a/lib/libkvm/kvm_proc.c b/lib/libkvm/kvm_proc.c index a634da8..5483ca4 100644 --- a/lib/libkvm/kvm_proc.c +++ b/lib/libkvm/kvm_proc.c @@ -53,6 +53,7 @@ static char sccsid[] = "@(#)kvm_proc.c 8.3 (Berkeley) 9/23/93"; #include <sys/stat.h> #include <sys/ioctl.h> #include <sys/tty.h> +#include <sys/file.h> #include <unistd.h> #include <nlist.h> #include <kvm.h> @@ -80,97 +81,6 @@ kvm_readswap(kd, p, va, cnt) /* XXX Stubbed out, our vm system is differnet */ _kvm_err(kd, kd->program, "kvm_readswap not implemented"); return(0); -#else - register int ix; - register u_long addr, head; - register u_long offset, pagestart, sbstart, pgoff; - register off_t seekpoint; - struct vm_map_entry vme; - struct vm_object vmo; - struct pager_struct pager; - struct swpager swap; - struct swblock swb; - static char page[NBPG]; - - head = (u_long)&p->p_vmspace->vm_map.header; - /* - * Look through the address map for the memory object - * that corresponds to the given virtual address. - * The header just has the entire valid range. - */ - addr = head; - while (1) { - if (kvm_read(kd, addr, (char *)&vme, sizeof(vme)) != - sizeof(vme)) - return (0); - - if (va >= vme.start && va <= vme.end && - vme.object.vm_object != 0) - break; - - addr = (u_long)vme.next; - if (addr == 0 || addr == head) - return (0); - } - /* - * We found the right object -- follow shadow links. - */ - offset = va - vme.start + vme.offset; - addr = (u_long)vme.object.vm_object; - while (1) { - if (kvm_read(kd, addr, (char *)&vmo, sizeof(vmo)) != - sizeof(vmo)) - return (0); - addr = (u_long)vmo.shadow; - if (addr == 0) - break; - offset += vmo.shadow_offset; - } - if (vmo.pager == 0) - return (0); - - offset += vmo.paging_offset; - /* - * Read in the pager info and make sure it's a swap device. - */ - addr = (u_long)vmo.pager; - if (kvm_read(kd, addr, (char *)&pager, sizeof(pager)) != sizeof(pager) - || pager.pg_type != PG_SWAP) - return (0); - - /* - * Read in the swap_pager private data, and compute the - * swap offset. - */ - addr = (u_long)pager.pg_data; - if (kvm_read(kd, addr, (char *)&swap, sizeof(swap)) != sizeof(swap)) - return (0); - ix = offset / dbtob(swap.sw_bsize); - if (swap.sw_blocks == 0 || ix >= swap.sw_nblocks) - return (0); - - addr = (u_long)&swap.sw_blocks[ix]; - if (kvm_read(kd, addr, (char *)&swb, sizeof(swb)) != sizeof(swb)) - return (0); - - sbstart = (offset / dbtob(swap.sw_bsize)) * dbtob(swap.sw_bsize); - sbstart /= NBPG; - pagestart = offset / NBPG; - pgoff = pagestart - sbstart; - - if (swb.swb_block == 0 || (swb.swb_mask & (1 << pgoff)) == 0) - return (0); - - seekpoint = dbtob(swb.swb_block) + ctob(pgoff); - errno = 0; - if (lseek(kd->swfd, seekpoint, 0) == -1 && errno != 0) - return (0); - if (read(kd->swfd, page, sizeof(page)) != sizeof(page)) - return (0); - - offset %= NBPG; - *cnt = NBPG - offset; - return (&page[offset]); #endif /* __FreeBSD__ */ } @@ -451,7 +361,7 @@ _kvm_realloc(kd, p, n) /* * Read in an argument vector from the user address space of process p. - * addr if the user-space base address of narg null-terminated contiguous + * addr is the user-space base address of narg null-terminated contiguous * strings. This is used to read in both the command arguments and * environment strings. Read at most maxcnt characters of strings. */ @@ -538,7 +448,7 @@ kvm_argv(kd, p, addr, narg, maxcnt) while (--cc >= 0) { if (*cp++ == 0) { - if (--narg <= 0) { + if (--narg <= 0 || (struct ps_strings *)(addr - cc) >= PS_STRINGS) { *++argv = 0; return (kd->argv); } else @@ -666,46 +576,40 @@ kvm_uread(kd, p, uva, buf, len) register size_t len; { register char *cp; + char procfile[MAXPATHLEN]; + ssize_t amount; + int fd; + u_long tmpuva = uva; + int i; + char *chr; cp = buf; + + sprintf(procfile, "/proc/%d/mem", p->p_pid); + fd = open(procfile, O_RDONLY, 0); + + if (fd < 0) { + _kvm_err(kd, kd->program, "cannot open %s", procfile); + close(fd); + return (0); + } + + while (len > 0) { - u_long pa; - register int cc; - - cc = _kvm_uvatop(kd, p, uva, &pa); - if (cc > 0) { - if (cc > len) - cc = len; - errno = 0; - if (lseek(kd->pmfd, (off_t)pa, 0) == -1 && errno != 0) { - _kvm_err(kd, 0, "invalid address (%x)", uva); - break; - } - cc = read(kd->pmfd, cp, cc); - if (cc < 0) { - _kvm_syserr(kd, 0, _PATH_MEM); - break; - } else if (cc < len) { - _kvm_err(kd, kd->program, "short read"); - break; - } - } else if (ISALIVE(kd)) { - /* try swap */ - register char *dp; - int cnt; - - dp = kvm_readswap(kd, p, uva, &cnt); - if (dp == 0) { - _kvm_err(kd, 0, "invalid address (%x)", uva); - return (0); - } - cc = MIN(cnt, len); - bcopy(dp, cp, cc); - } else + if (lseek(fd, uva, 0) == -1 && errno != 0) { + _kvm_err(kd, kd->program, "invalid address (%x) in %s", uva, procfile); + break; + } + amount = read(fd, buf, len); + if (amount < 0) { + _kvm_err(kd, kd->program, "error reading %s", procfile); break; - cp += cc; - uva += cc; - len -= cc; + } + cp += amount; + uva += amount; + len -= amount; } + + close(fd); return (ssize_t)(cp - buf); } |