summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libexec/rpc.rstatd/Makefile7
-rw-r--r--libexec/rpc.rstatd/rstat_proc.c53
2 files changed, 50 insertions, 10 deletions
diff --git a/libexec/rpc.rstatd/Makefile b/libexec/rpc.rstatd/Makefile
index ae53e7263c1..e724e739b66 100644
--- a/libexec/rpc.rstatd/Makefile
+++ b/libexec/rpc.rstatd/Makefile
@@ -1,4 +1,4 @@
-# $Id: Makefile,v 1.2 1997/02/20 06:42:59 tholo Exp $
+# $Id: Makefile,v 1.3 1999/11/30 07:39:26 art Exp $
PROG = rpc.rstatd
.PATH: ${.CURDIR}/../../usr.bin/vmstat
@@ -12,3 +12,8 @@ DPADD= ${LIBRPCSVC} ${LIBKVM}
LDADD= -lrpcsvc -lkvm
.include <bsd.prog.mk>
+
+.if (${UVM} == "yes")
+CFLAGS+=-DUVM
+.endif
+
diff --git a/libexec/rpc.rstatd/rstat_proc.c b/libexec/rpc.rstatd/rstat_proc.c
index 68e3decd6e6..0f9bbc056c2 100644
--- a/libexec/rpc.rstatd/rstat_proc.c
+++ b/libexec/rpc.rstatd/rstat_proc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rstat_proc.c,v 1.10 1998/07/10 08:06:10 deraadt Exp $ */
+/* $OpenBSD: rstat_proc.c,v 1.11 1999/11/30 07:39:26 art Exp $ */
/*
* Sun RPC is a product of Sun Microsystems, Inc. and is provided for
@@ -31,7 +31,7 @@
#ifndef lint
/*static char sccsid[] = "from: @(#)rpc.rstatd.c 1.1 86/09/25 Copyr 1984 Sun Micro";*/
/*static char sccsid[] = "from: @(#)rstat_proc.c 2.2 88/08/01 4.0 RPCSRC";*/
-static char rcsid[] = "$OpenBSD: rstat_proc.c,v 1.10 1998/07/10 08:06:10 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: rstat_proc.c,v 1.11 1999/11/30 07:39:26 art Exp $";
#endif
/*
@@ -62,6 +62,12 @@ static char rcsid[] = "$OpenBSD: rstat_proc.c,v 1.10 1998/07/10 08:06:10 deraadt
#endif
#include <net/if.h>
+#if defined(UVM)
+#include <vm/vm.h>
+#include <sys/sysctl.h>
+#include <uvm/uvm_extern.h>
+#endif
+
#undef FSHIFT /* Use protocol's shift and scale values */
#undef FSCALE
#undef DK_NDRIVE
@@ -79,19 +85,24 @@ int cp_xlat[CPUSTATES] = { CP_USER, CP_NICE, CP_SYS, CP_IDLE };
#endif
struct nlist nl[] = {
-#define X_CNT 0
- { "_cnt" },
-#define X_IFNET 1
+#define X_IFNET 0
{ "_ifnet" },
-#define X_BOOTTIME 2
+#define X_BOOTTIME 1
{ "_boottime" },
#ifndef BSD
-#define X_HZ 3
+#define X_HZ 2
{ "_hz" },
-#define X_CPTIME 4
+#define X_CPTIME 3
{ "_cp_time" },
-#define X_DKXFER 5
+#define X_DKXFER 4
{ "_dk_xfer" },
+#define X_CNT 5
+ { "_cnt" },
+#else
+#ifndef UVM
+#define X_CNT 2
+ { "_cnt" },
+#endif
#endif
{ NULL },
};
@@ -203,7 +214,12 @@ updatestat()
{
long off;
int i, save_errno = errno;
+#ifdef UVM
+ struct uvmexp uvmexp;
+ int mib[2], len;
+#else
struct vmmeter cnt;
+#endif
struct ifnet ifnet;
double avrun[3];
struct timeval tm, btm;
@@ -274,6 +290,24 @@ updatestat()
stats_all.s1.cp_time[3]);
#endif
+#ifdef UVM
+ mib[0] = CTL_VM;
+ mib[1] = VM_UVMEXP;
+ len = sizeof(uvmexp);
+ if (sysctl(mib, 2, &uvmexp, &len, NULL, 0) < 0) {
+ syslog(LOG_ERR, "can't sysctl vm.uvmexp");
+ exit(1);
+ }
+ stats_all.s1.v_pgpgin = uvmexp.fltanget;
+ stats_all.s1.v_pgpgout = uvmexp.pdpageouts;
+ stats_all.s1.v_pswpin = uvmexp.swapins;
+ stats_all.s1.v_pswpout = uvmexp.swapouts;
+ stats_all.s1.v_intr = uvmexp.intrs;
+ stats_all.s2.v_swtch = uvmexp.swtch;
+ gettimeofday(&tm, (struct timezone *) 0);
+ stats_all.s1.v_intr -= hz*(tm.tv_sec - btm.tv_sec) +
+ hz*(tm.tv_usec - btm.tv_usec)/1000000;
+#else
if (kvm_read(kfd, (long)nl[X_CNT].n_value, (char *)&cnt, sizeof cnt) !=
sizeof cnt) {
syslog(LOG_ERR, "can't read cnt from kmem");
@@ -288,6 +322,7 @@ updatestat()
stats_all.s1.v_intr -= hz*(tm.tv_sec - btm.tv_sec) +
hz*(tm.tv_usec - btm.tv_usec)/1000000;
stats_all.s2.v_swtch = cnt.v_swtch;
+#endif
#ifndef BSD
if (kvm_read(kfd, (long)nl[X_DKXFER].n_value,