diff options
author | andre <andre@FreeBSD.org> | 2005-10-17 15:37:22 +0000 |
---|---|---|
committer | andre <andre@FreeBSD.org> | 2005-10-17 15:37:22 +0000 |
commit | 74d3ddeb3259da19ebc6183d77ed2e47ac50eae1 (patch) | |
tree | 9623cd1f5d463a40b1bd4dc6d6ba5383ea694375 /usr.bin/vmstat | |
parent | 58c0a29b889898bebdd9e7edd7455c798986821e (diff) | |
download | FreeBSD-src-74d3ddeb3259da19ebc6183d77ed2e47ac50eae1.zip FreeBSD-src-74d3ddeb3259da19ebc6183d77ed2e47ac50eae1.tar.gz |
Obtain true uptime through clock_gettime(CLOCK_MONOTONIC, struct *timespec)
instead of subtracting 'bootime' from 'now'.
Sponsored by: TCP/IP Optimization Fundraise 2005
Diffstat (limited to 'usr.bin/vmstat')
-rw-r--r-- | usr.bin/vmstat/vmstat.c | 20 |
1 files changed, 4 insertions, 16 deletions
diff --git a/usr.bin/vmstat/vmstat.c b/usr.bin/vmstat/vmstat.c index f52f7bf..605319c 100644 --- a/usr.bin/vmstat/vmstat.c +++ b/usr.bin/vmstat/vmstat.c @@ -396,26 +396,14 @@ getdrivedata(char **argv) static long getuptime(void) { - static struct timeval boottime; - static time_t now; + struct timespec sp; time_t uptime; - if (boottime.tv_sec == 0) { - if (kd != NULL) { - kread(X_BOOTTIME, &boottime, sizeof(boottime)); - } else { - size_t size; - - size = sizeof(boottime); - mysysctl("kern.boottime", &boottime, &size, NULL, 0); - if (size != sizeof(boottime)) - errx(1, "kern.boottime size mismatch"); - } - } - (void)time(&now); - uptime = now - boottime.tv_sec; + (void)clock_gettime(CLOCK_MONOTONIC, &sp); + uptime = sp.tv_sec; if (uptime <= 0 || uptime > 60*60*24*365*10) errx(1, "time makes no sense; namelist must be wrong"); + return(uptime); } |