summaryrefslogtreecommitdiff
path: root/usr.bin
diff options
context:
space:
mode:
authorAngelos D. Keromytis <angelos@cvs.openbsd.org>2001-06-03 03:31:31 +0000
committerAngelos D. Keromytis <angelos@cvs.openbsd.org>2001-06-03 03:31:31 +0000
commit5c2e1f7884b2a053fe7eb71547a0719d1dc8e17f (patch)
treebf26281faea7a3728e9e72638b04bf874f85032c /usr.bin
parent3bd1d3b194b0740e950f69630811a8c89b338e4e (diff)
Read struct diskstats from the kernel.
Diffstat (limited to 'usr.bin')
-rw-r--r--usr.bin/vmstat/dkstats.c21
1 files changed, 11 insertions, 10 deletions
diff --git a/usr.bin/vmstat/dkstats.c b/usr.bin/vmstat/dkstats.c
index d315ec1af2a..fb81d8020f0 100644
--- a/usr.bin/vmstat/dkstats.c
+++ b/usr.bin/vmstat/dkstats.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dkstats.c,v 1.12 2001/05/14 07:40:39 angelos Exp $ */
+/* $OpenBSD: dkstats.c,v 1.13 2001/06/03 03:31:30 angelos Exp $ */
/* $NetBSD: dkstats.c,v 1.1 1996/05/10 23:19:27 thorpej Exp $ */
/*
@@ -153,24 +153,25 @@ dkreadstats()
struct disk cur_disk, *p;
int i, mib[3];
size_t size;
+ struct diskstats *q;
if (nlistf == NULL && memf == NULL) {
- size = dk_ndrive * sizeof(struct disk);
+ size = dk_ndrive * sizeof(struct diskstats);
mib[0] = CTL_HW;
mib[1] = HW_DISKSTATS;
- p = malloc(size);
- if (p == NULL)
+ q = malloc(size);
+ if (q == NULL)
err(1, NULL);
- if (sysctl(mib, 2, p, &size, NULL, 0) < 0) {
+ if (sysctl(mib, 2, q, &size, NULL, 0) < 0) {
warn("could not read hw.diskstats");
- bzero(p, dk_ndrive * sizeof(struct disk));
+ bzero(q, dk_ndrive * sizeof(struct disk));
}
for (i = 0; i < dk_ndrive; i++) {
- cur.dk_xfer[i] = p[i].dk_xfer;
- cur.dk_seek[i] = p[i].dk_seek;
- cur.dk_bytes[i] = p[i].dk_bytes;
- timerset(&(p[i].dk_time), &(cur.dk_time[i]));
+ cur.dk_xfer[i] = q[i].ds_xfer;
+ cur.dk_seek[i] = q[i].ds_seek;
+ cur.dk_bytes[i] = q[i].ds_bytes;
+ timerset(&(q[i].ds_time), &(cur.dk_time[i]));
}
size = sizeof(cur.cp_time);