diff options
author | Angelos D. Keromytis <angelos@cvs.openbsd.org> | 2001-06-03 03:31:31 +0000 |
---|---|---|
committer | Angelos D. Keromytis <angelos@cvs.openbsd.org> | 2001-06-03 03:31:31 +0000 |
commit | 5c2e1f7884b2a053fe7eb71547a0719d1dc8e17f (patch) | |
tree | bf26281faea7a3728e9e72638b04bf874f85032c /usr.bin | |
parent | 3bd1d3b194b0740e950f69630811a8c89b338e4e (diff) |
Read struct diskstats from the kernel.
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/vmstat/dkstats.c | 21 |
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); |