Module Name: src
Committed By: rin
Date: Mon Nov 28 08:19:23 UTC 2016
Modified Files:
src/bin/ps: extern.h nlist.c print.c
Log Message:
for donlist{,_sysctl}:
- obtain log_ccpu = log(ccpu) rather than ccpu itself
- use common default values and warn users appropriately when errors occur
ok martin
To generate a diff of this commit:
cvs rdiff -u -r1.35 -r1.36 src/bin/ps/extern.h
cvs rdiff -u -r1.26 -r1.27 src/bin/ps/nlist.c
cvs rdiff -u -r1.123 -r1.124 src/bin/ps/print.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/bin/ps/extern.h
diff -u src/bin/ps/extern.h:1.35 src/bin/ps/extern.h:1.36
--- src/bin/ps/extern.h:1.35 Sun Apr 20 22:48:59 2014
+++ src/bin/ps/extern.h Mon Nov 28 08:19:23 2016
@@ -1,4 +1,4 @@
-/* $NetBSD: extern.h,v 1.35 2014/04/20 22:48:59 dholland Exp $ */
+/* $NetBSD: extern.h,v 1.36 2016/11/28 08:19:23 rin Exp $ */
/*-
* Copyright (c) 1991, 1993, 1994
@@ -36,7 +36,7 @@
* defined the types we use.
*/
-extern double ccpu;
+extern double log_ccpu;
extern int eval, fscale, mempages, nlistread, rawcpu, maxslp, uspace;
extern int sumrusage, termwidth, totwidth;
extern int needenv, needcomm, commandonly;
@@ -49,8 +49,8 @@ extern VARLIST sortlist;
void command(void *, VARENT *, enum mode);
void cpuid(void *, VARENT *, enum mode);
void cputime(void *, VARENT *, enum mode);
-int donlist(void);
-int donlist_sysctl(void);
+void donlist(void);
+void donlist_sysctl(void);
void fmt_puts(char *, int *);
void fmt_putc(int, int *);
void elapsed(void *, VARENT *, enum mode);
Index: src/bin/ps/nlist.c
diff -u src/bin/ps/nlist.c:1.26 src/bin/ps/nlist.c:1.27
--- src/bin/ps/nlist.c:1.26 Mon Apr 28 20:22:51 2008
+++ src/bin/ps/nlist.c Mon Nov 28 08:19:23 2016
@@ -1,4 +1,4 @@
-/* $NetBSD: nlist.c,v 1.26 2008/04/28 20:22:51 martin Exp $ */
+/* $NetBSD: nlist.c,v 1.27 2016/11/28 08:19:23 rin Exp $ */
/*
* Copyright (c) 2000 The NetBSD Foundation, Inc.
@@ -63,7 +63,7 @@
#if 0
static char sccsid[] = "@(#)nlist.c 8.4 (Berkeley) 4/2/94";
#else
-__RCSID("$NetBSD: nlist.c,v 1.26 2008/04/28 20:22:51 martin Exp $");
+__RCSID("$NetBSD: nlist.c,v 1.27 2016/11/28 08:19:23 rin Exp $");
#endif
#endif /* not lint */
@@ -97,50 +97,73 @@ struct nlist psnl[] = {
{ .n_name = NULL }
};
-double ccpu; /* kernel _ccpu variable */
+double log_ccpu; /* log of kernel _ccpu variable */
int nlistread; /* if nlist already read. */
int mempages; /* number of pages of phys. memory */
int fscale; /* kernel _fscale variable */
int maxslp; /* kernel _maxslp variable */
int uspace; /* kernel USPACE value */
+/* XXX Hopefully reasonable default */
+#define MEMPAGES 0
+#ifndef FSCALE
+#define FSCALE (1 << 8)
+#endif
+#define LOG_CCPU (-1.0 / 20.0)
+#ifndef MAXSLP
+#define MAXSLP 20
+#endif
+#ifndef USPACE
+#define USPACE (getpagesize())
+#endif
+
#define kread(x, v) \
kvm_read(kd, psnl[x].n_value, (char *)&v, sizeof v) != sizeof(v)
-int
+void
donlist(void)
{
- int rval;
fixpt_t xccpu;
- rval = 0;
nlistread = 1;
+
if (kvm_nlist(kd, psnl)) {
nlisterr(psnl);
eval = 1;
- return (1);
+ fscale = FSCALE;
+ mempages = MEMPAGES;
+ log_ccpu = LOG_CCPU;
+ maxslp = MAXSLP;
+ return;
}
+
if (kread(X_FSCALE, fscale)) {
warnx("fscale: %s", kvm_geterr(kd));
- eval = rval = 1;
+ eval = 1;
+ fscale = FSCALE;
}
+
if (kread(X_PHYSMEM, mempages)) {
warnx("avail_start: %s", kvm_geterr(kd));
- eval = rval = 1;
+ eval = 1;
+ mempages = MEMPAGES;
}
+
if (kread(X_CCPU, xccpu)) {
warnx("ccpu: %s", kvm_geterr(kd));
- eval = rval = 1;
- }
+ eval = 1;
+ log_ccpu = LOG_CCPU;
+ } else
+ log_ccpu = log((double)xccpu / fscale);
+
if (kread(X_MAXSLP, maxslp)) {
warnx("maxslp: %s", kvm_geterr(kd));
- eval = rval = 1;
+ eval = 1;
+ maxslp = MAXSLP;
}
- ccpu = (double)xccpu / fscale;
- return (rval);
}
-int
+void
donlist_sysctl(void)
{
int mib[2];
@@ -149,49 +172,53 @@ donlist_sysctl(void)
uint64_t memsize;
nlistread = 1;
- mib[0] = CTL_HW;
- mib[1] = HW_PHYSMEM64;
- size = sizeof(memsize);
- if (sysctl(mib, 2, &memsize, &size, NULL, 0) == 0)
- mempages = memsize / getpagesize();
- else
- mempages = 0;
mib[0] = CTL_KERN;
mib[1] = KERN_FSCALE;
size = sizeof(fscale);
- if (sysctl(mib, 2, &fscale, &size, NULL, 0) == -1)
- fscale = (1 << 8); /* XXX Hopefully reasonable default */
+ if (sysctl(mib, 2, &fscale, &size, NULL, 0)) {
+ warn("fscale");
+ eval = 1;
+ fscale = FSCALE;
+ }
+
+ mib[0] = CTL_HW;
+ mib[1] = HW_PHYSMEM64;
+ size = sizeof(memsize);
+ if (sysctl(mib, 2, &memsize, &size, NULL, 0)) {
+ warn("avail_start");
+ eval = 1;
+ mempages = MEMPAGES;
+ } else
+ mempages = memsize / getpagesize();
mib[0] = CTL_KERN;
mib[1] = KERN_CCPU;
size = sizeof(xccpu);
- if (sysctl(mib, 2, &xccpu, &size, NULL, 0) == -1)
- ccpu = exp(-1.0 / 20.0); /* XXX Hopefully reasonable default */
- else
- ccpu = (double)xccpu / fscale;
+ if (sysctl(mib, 2, &xccpu, &size, NULL, 0)) {
+ warn("ccpu");
+ eval = 1;
+ log_ccpu = LOG_CCPU;
+ } else
+ log_ccpu = log((double)xccpu / fscale);
mib[0] = CTL_VM;
mib[1] = VM_MAXSLP;
size = sizeof(maxslp);
- if (sysctl(mib, 2, &maxslp, &size, NULL, 0) == -1)
-#ifdef MAXSLP
+ if (sysctl(mib, 2, &maxslp, &size, NULL, 0)) {
+ warn("maxslp");
+ eval = 1;
maxslp = MAXSLP;
-#else
- maxslp = 20; /* XXX Hopefully reasonable default */
-#endif
+ }
mib[0] = CTL_VM;
mib[1] = VM_USPACE;
size = sizeof(uspace);
- if (sysctl(mib, 2, &uspace, &size, NULL, 0) == -1)
-#ifdef USPACE
+ if (sysctl(mib, 2, &uspace, &size, NULL, 0)) {
+ warn("uspace");
+ eval = 1;
uspace = USPACE;
-#else
- uspace = getpagesize(); /* XXX Hopefully reasonable default */
-#endif
-
- return 0;
+ }
}
void
Index: src/bin/ps/print.c
diff -u src/bin/ps/print.c:1.123 src/bin/ps/print.c:1.124
--- src/bin/ps/print.c:1.123 Sat Nov 15 01:58:34 2014
+++ src/bin/ps/print.c Mon Nov 28 08:19:23 2016
@@ -1,4 +1,4 @@
-/* $NetBSD: print.c,v 1.123 2014/11/15 01:58:34 joerg Exp $ */
+/* $NetBSD: print.c,v 1.124 2016/11/28 08:19:23 rin Exp $ */
/*
* Copyright (c) 2000, 2007 The NetBSD Foundation, Inc.
@@ -63,7 +63,7 @@
#if 0
static char sccsid[] = "@(#)print.c 8.6 (Berkeley) 4/16/94";
#else
-__RCSID("$NetBSD: print.c,v 1.123 2014/11/15 01:58:34 joerg Exp $");
+__RCSID("$NetBSD: print.c,v 1.124 2016/11/28 08:19:23 rin Exp $");
#endif
#endif /* not lint */
@@ -1094,12 +1094,9 @@ lcputime(void *arg, VARENT *ve, enum mod
double
getpcpu(const struct kinfo_proc2 *k)
{
- static int failure;
if (!nlistread)
- failure = (kd) ? donlist() : 1;
- if (failure)
- return (0.0);
+ donlist();
#define fxtofl(fixpt) ((double)(fixpt) / fscale)
@@ -1108,7 +1105,7 @@ getpcpu(const struct kinfo_proc2 *k)
if (rawcpu)
return (100.0 * fxtofl(k->p_pctcpu));
return (100.0 * fxtofl(k->p_pctcpu) /
- (1.0 - exp(k->p_swtime * log(ccpu))));
+ (1.0 - exp(k->p_swtime * log_ccpu)));
}
void
@@ -1127,14 +1124,11 @@ pcpu(void *arg, VARENT *ve, enum mode mo
double
getpmem(const struct kinfo_proc2 *k)
{
- static int failure;
double fracmem;
int szptudot;
if (!nlistread)
- failure = (kd) ? donlist() : 1;
- if (failure)
- return (0.0);
+ donlist();
/* XXX want pmap ptpages, segtab, etc. (per architecture) */
szptudot = uspace/getpagesize();