summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbde <bde@FreeBSD.org>1998-12-16 18:31:51 +0000
committerbde <bde@FreeBSD.org>1998-12-16 18:31:51 +0000
commit28d6420f45416c97f037bc61378036eaa76779f7 (patch)
tree95e3d0c6eb6ab6dc3c86170c21802f78b237ed0e
parent38464a3bbc7ca1a7686cd5fd5f56c8def4aa5ed8 (diff)
downloadFreeBSD-src-28d6420f45416c97f037bc61378036eaa76779f7.zip
FreeBSD-src-28d6420f45416c97f037bc61378036eaa76779f7.tar.gz
Adjust for kern.ps_strings and PS_STRINGS not being a pointer. This
fixes a type mismatch in the call to kvm_uread(). The bug has gone undetected for almost 3 years because kvm_uproc()'s protoype has been disabled for almost 4 years. Trust sysctlbyname() to work properly if it succeeds. Fixed style bugs in revs. 1.19 and 1.22.
-rw-r--r--lib/libkvm/kvm_proc.c29
1 files changed, 12 insertions, 17 deletions
diff --git a/lib/libkvm/kvm_proc.c b/lib/libkvm/kvm_proc.c
index c917861..9543fee 100644
--- a/lib/libkvm/kvm_proc.c
+++ b/lib/libkvm/kvm_proc.c
@@ -302,15 +302,14 @@ kvm_getprocs(kd, op, arg, cnt)
_kvm_syserr(kd, kd->program, "kvm_getprocs");
return (0);
}
- kd->procbase = 0;
do {
size += size / 10;
kd->procbase = (struct kinfo_proc *)
- _kvm_realloc(kd, kd->procbase, size);
+ _kvm_realloc(kd, kd->procbase, size);
if (kd->procbase == 0)
return (0);
st = sysctl(mib, op == KERN_PROC_ALL ? 3 : 4,
- kd->procbase, &size, NULL, 0);
+ kd->procbase, &size, NULL, 0);
} while (st == -1 && errno == ENOMEM);
if (st == -1) {
_kvm_syserr(kd, kd->program, "kvm_getprocs");
@@ -601,21 +600,18 @@ proc_verify(kd, kernp, p)
const struct proc *p;
{
struct kinfo_proc kp;
- int mib[4], st;
+ int mib[4];
size_t len;
mib[0] = CTL_KERN;
mib[1] = KERN_PROC;
mib[2] = KERN_PROC_PID;
mib[3] = p->p_pid;
-
- len = sizeof kp;
-
- st = sysctl(mib, 4, &kp, &len, NULL, 0);
- if (st < 0)
- return(0);
+ len = sizeof(kp);
+ if (sysctl(mib, 4, &kp, &len, NULL, 0) == -1)
+ return (0);
return (p->p_pid == kp.kp_proc.p_pid &&
- (kp.kp_proc.p_stat != SZOMB || p->p_stat == SZOMB));
+ (kp.kp_proc.p_stat != SZOMB || p->p_stat == SZOMB));
}
static char **
@@ -629,15 +625,14 @@ kvm_doargv(kd, kp, nchr, info)
register char **ap;
u_long addr;
int cnt;
- static struct ps_strings arginfo, *ps_strings;
+ static struct ps_strings arginfo;
+ static u_long ps_strings;
size_t len;
- int i;
if (ps_strings == NULL) {
- len = sizeof ps_strings;
- i = sysctlbyname("kern.ps_strings",
- &ps_strings, &len, 0, 0);
- if (i < 0 || ps_strings == NULL)
+ len = sizeof(ps_strings);
+ if (sysctlbyname("kern.ps_strings", &ps_strings, &len, NULL,
+ 0) == -1)
ps_strings = PS_STRINGS;
}
OpenPOWER on IntegriCloud