Source-Changes-HG archive

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

[src/trunk]: src/sys Hide 'hardclock_ticks' behind a new getticks() function,...



details:   https://anonhg.NetBSD.org/src/rev/ef93d72deddb
branches:  trunk
changeset: 970734:ef93d72deddb
user:      maxv <maxv%NetBSD.org@localhost>
date:      Thu Apr 02 16:29:30 2020 +0000

description:
Hide 'hardclock_ticks' behind a new getticks() function, and use relaxed
atomics internally. Only one caller is converted for now.

Discussed with riastradh@ and ad@.

diffstat:

 sys/kern/kern_clock.c        |  15 +++++++++++----
 sys/sys/kernel.h             |   8 ++++++--
 sys/uvm/uvm_pdpolicy_clock.c |  10 +++++-----
 3 files changed, 22 insertions(+), 11 deletions(-)

diffs (117 lines):

diff -r 5395ea73f9c9 -r ef93d72deddb sys/kern/kern_clock.c
--- a/sys/kern/kern_clock.c     Thu Apr 02 16:18:51 2020 +0000
+++ b/sys/kern/kern_clock.c     Thu Apr 02 16:29:30 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: kern_clock.c,v 1.139 2019/12/01 15:34:46 ad Exp $      */
+/*     $NetBSD: kern_clock.c,v 1.140 2020/04/02 16:29:30 maxv Exp $    */
 
 /*-
  * Copyright (c) 2000, 2004, 2006, 2007, 2008 The NetBSD Foundation, Inc.
@@ -69,7 +69,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_clock.c,v 1.139 2019/12/01 15:34:46 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_clock.c,v 1.140 2020/04/02 16:29:30 maxv Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_dtrace.h"
@@ -155,7 +155,13 @@
 get_intr_timecount(struct timecounter *tc)
 {
 
-       return (u_int)hardclock_ticks;
+       return (u_int)getticks();
+}
+
+int
+getticks(void)
+{
+       return atomic_load_relaxed(&hardclock_ticks);
 }
 
 /*
@@ -242,7 +248,8 @@
                sched_tick(ci);
 
        if (CPU_IS_PRIMARY(ci)) {
-               hardclock_ticks++;
+               atomic_store_relaxed(&hardclock_ticks,
+                   atomic_load_relaxed(&hardclock_ticks) + 1);
                tc_ticktock();
        }
 
diff -r 5395ea73f9c9 -r ef93d72deddb sys/sys/kernel.h
--- a/sys/sys/kernel.h  Thu Apr 02 16:18:51 2020 +0000
+++ b/sys/sys/kernel.h  Thu Apr 02 16:29:30 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: kernel.h,v 1.32 2020/01/02 15:42:27 thorpej Exp $      */
+/*     $NetBSD: kernel.h,v 1.33 2020/04/02 16:29:30 maxv Exp $ */
 
 /*-
  * Copyright (c) 1990, 1993
@@ -56,7 +56,7 @@
 extern int shutting_down;      /* system is shutting down */
 extern int tick;               /* usec per tick (1000000 / hz) */
 extern int tickadj;            /* "standard" clock skew, us./tick */
-extern int hardclock_ticks;    /* # of hardclock ticks */
+extern int hardclock_ticks;    /* # of hardclock ticks; XXX use getticks()! */
 extern int hz;                 /* system clock's frequency */
 extern int stathz;             /* statistics clock's frequency */
 extern int profhz;             /* profiling clock's frequency */
@@ -64,6 +64,10 @@
 extern int profsrc;            /* profiling source */
 extern int psratio;            /* ratio: prof / stat */
 
+/* Accessors. */
+
+int getticks(void);
+
 #define PROFSRC_CLOCK  0
 
 #endif
diff -r 5395ea73f9c9 -r ef93d72deddb sys/uvm/uvm_pdpolicy_clock.c
--- a/sys/uvm/uvm_pdpolicy_clock.c      Thu Apr 02 16:18:51 2020 +0000
+++ b/sys/uvm/uvm_pdpolicy_clock.c      Thu Apr 02 16:29:30 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_pdpolicy_clock.c,v 1.35 2020/03/14 13:53:26 ad Exp $       */
+/*     $NetBSD: uvm_pdpolicy_clock.c,v 1.36 2020/04/02 16:29:30 maxv Exp $     */
 /*     NetBSD: uvm_pdaemon.c,v 1.72 2006/01/05 10:47:33 yamt Exp $     */
 
 /*-
@@ -98,7 +98,7 @@
 #else /* defined(PDSIM) */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_pdpolicy_clock.c,v 1.35 2020/03/14 13:53:26 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_pdpolicy_clock.c,v 1.36 2020/04/02 16:29:30 maxv Exp $");
 
 #include <sys/param.h>
 #include <sys/proc.h>
@@ -771,7 +771,7 @@
         * if no pages in the queue, we have nothing to do.
         */
        if (ucpu->pdqhead == ucpu->pdqtail) {
-               ucpu->pdqtime = hardclock_ticks;
+               ucpu->pdqtime = getticks();
                return;
        }
 
@@ -779,7 +779,7 @@
         * don't do this more than ~8 times a second as it would needlessly
         * exert pressure.
         */
-       if (hardclock_ticks - ucpu->pdqtime < (hz >> 3)) {
+       if (getticks() - ucpu->pdqtime < (hz >> 3)) {
                return;
        }
 
@@ -803,7 +803,7 @@
                        }
                }
                if (ucpu->pdqhead == ucpu->pdqtail) {
-                       ucpu->pdqtime = hardclock_ticks;
+                       ucpu->pdqtime = getticks();
                }
                mutex_exit(&s->lock);
        }



Home | Main Index | Thread Index | Old Index