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();

Reply via email to