Module Name:    src
Committed By:   riastradh
Date:           Mon Jul 17 15:41:06 UTC 2023

Modified Files:
        src/sys/kern: kern_tc.c

Log Message:
Revert "timecounter(9): Use an ipi barrier on time_second/uptime rollover."

Evidently rump doesn't have ipi, so this won't work unless we have an
alternate approach for rump.


To generate a diff of this commit:
cvs rdiff -u -r1.69 -r1.70 src/sys/kern/kern_tc.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/kern/kern_tc.c
diff -u src/sys/kern/kern_tc.c:1.69 src/sys/kern/kern_tc.c:1.70
--- src/sys/kern/kern_tc.c:1.69	Mon Jul 17 13:48:14 2023
+++ src/sys/kern/kern_tc.c	Mon Jul 17 15:41:05 2023
@@ -1,4 +1,4 @@
-/* $NetBSD: kern_tc.c,v 1.69 2023/07/17 13:48:14 riastradh Exp $ */
+/* $NetBSD: kern_tc.c,v 1.70 2023/07/17 15:41:05 riastradh Exp $ */
 
 /*-
  * Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -40,7 +40,7 @@
 
 #include <sys/cdefs.h>
 /* __FBSDID("$FreeBSD: src/sys/kern/kern_tc.c,v 1.166 2005/09/19 22:16:31 andre Exp $"); */
-__KERNEL_RCSID(0, "$NetBSD: kern_tc.c,v 1.69 2023/07/17 13:48:14 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_tc.c,v 1.70 2023/07/17 15:41:05 riastradh Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ntp.h"
@@ -50,7 +50,6 @@ __KERNEL_RCSID(0, "$NetBSD: kern_tc.c,v 
 
 #include <sys/atomic.h>
 #include <sys/evcnt.h>
-#include <sys/ipi.h>
 #include <sys/kauth.h>
 #include <sys/kernel.h>
 #include <sys/lock.h>
@@ -168,24 +167,6 @@ setrealuptime(time_t second, time_t upti
 
 #else
 
-static void
-nullipi(void *cookie)
-{
-}
-
-/*
- * Issue membar_release on this CPU, and force membar_acquire on all
- * CPUs.
- */
-static void
-ipi_barrier(void)
-{
-	ipi_msg_t msg = { .func = nullipi };
-
-	ipi_broadcast(&msg, /*skip_self*/true);
-	ipi_wait(&msg);
-}
-
 static inline void
 setrealuptime(time_t second, time_t uptime)
 {
@@ -207,10 +188,10 @@ setrealuptime(time_t second, time_t upti
 
 	atomic_store_relaxed(&time__second32.hi, 0xffffffff);
 	atomic_store_relaxed(&time__uptime32.hi, 0xffffffff);
-	ipi_barrier();
+	membar_producer();
 	atomic_store_relaxed(&time__second32.lo, seclo);
 	atomic_store_relaxed(&time__uptime32.lo, uplo);
-	ipi_barrier();
+	membar_producer();
 	atomic_store_relaxed(&time__second32.hi, sechi);
 	atomic_store_relaxed(&time__uptime32.hi, uphi);
 }
@@ -227,9 +208,9 @@ getrealtime(void)
 				break;
 			SPINLOCK_BACKOFF_HOOK;
 		}
-		__insn_barrier();
+		membar_consumer();
 		lo = atomic_load_relaxed(&time__second32.lo);
-		__insn_barrier();
+		membar_consumer();
 	} while (hi != atomic_load_relaxed(&time__second32.hi));
 
 	return ((time_t)hi << 32) | lo;
@@ -247,9 +228,9 @@ getuptime(void)
 				break;
 			SPINLOCK_BACKOFF_HOOK;
 		}
-		__insn_barrier();
+		membar_consumer();
 		lo = atomic_load_relaxed(&time__uptime32.lo);
-		__insn_barrier();
+		membar_consumer();
 	} while (hi != atomic_load_relaxed(&time__uptime32.hi));
 
 	return ((time_t)hi << 32) | lo;

Reply via email to