Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/libexec/rpc.rstatd sysctl(KERN_BOOTTIME) is a struct timespe...



details:   https://anonhg.NetBSD.org/src/rev/fbaebf8bfdae
branches:  trunk
changeset: 994300:fbaebf8bfdae
user:      kre <kre%NetBSD.org@localhost>
date:      Tue Oct 30 21:18:39 2018 +0000

description:
sysctl(KERN_BOOTTIME) is a struct timespec, not struct timeval
and has eben since 2009.    Adapt.

NFCI - while the tv_usec (now tv_nsec) field is used, we will
keep its uses to microsecond precision to avoid any compat issues.

diffstat:

 libexec/rpc.rstatd/rstat_proc.c |  11 ++++++-----
 1 files changed, 6 insertions(+), 5 deletions(-)

diffs (46 lines):

diff -r 6058127c18dc -r fbaebf8bfdae libexec/rpc.rstatd/rstat_proc.c
--- a/libexec/rpc.rstatd/rstat_proc.c   Tue Oct 30 21:15:09 2018 +0000
+++ b/libexec/rpc.rstatd/rstat_proc.c   Tue Oct 30 21:18:39 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rstat_proc.c,v 1.52 2014/06/26 03:24:51 dholland Exp $ */
+/*     $NetBSD: rstat_proc.c,v 1.53 2018/10/30 21:18:39 kre Exp $      */
 
 /*
  * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
@@ -36,7 +36,7 @@
 static char sccsid[] =
        "from: @(#)rstat_proc.c 2.2 88/08/01 4.0 RPCSRC";
 #endif
-__RCSID("$NetBSD: rstat_proc.c,v 1.52 2014/06/26 03:24:51 dholland Exp $");
+__RCSID("$NetBSD: rstat_proc.c,v 1.53 2018/10/30 21:18:39 kre Exp $");
 
 /*
  * rstat service:  built with rstat.x and derived from rpc.rstatd.c
@@ -180,7 +180,8 @@
        int mib[2], s;
        struct uvmexp_sysctl uvmexp;
        double avrun[3];
-       struct timeval tm, btm;
+       struct timeval tm;
+       struct timespec btm;
 
 #ifdef DEBUG
        syslog(LOG_DEBUG, "entering updatestat");
@@ -221,7 +222,7 @@
                exit(1);
        }
        stats_all.s3.boottime.tv_sec = btm.tv_sec;
-       stats_all.s3.boottime.tv_usec = btm.tv_usec;
+       stats_all.s3.boottime.tv_usec = (suseconds_t)(btm.tv_nsec / 1000L);
 
 
 #ifdef DEBUG
@@ -245,7 +246,7 @@
        stats_all.s3.v_swtch = uvmexp.swtch;
        gettimeofday(&tm, (struct timezone *) 0);
        stats_all.s3.v_intr -= hz*(tm.tv_sec - btm.tv_sec) +
-           hz*(tm.tv_usec - btm.tv_usec)/1000000;
+           hz*(tm.tv_usec - (suseconds_t)(btm.tv_nsec / 1000))/1000000;
        
        stats_all.s3.if_ipackets = 0;
        stats_all.s3.if_opackets = 0;



Home | Main Index | Thread Index | Old Index