Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/share/man/man9 Redocument xc_barrier.
details: https://anonhg.NetBSD.org/src/rev/69ec0859659b
branches: trunk
changeset: 1006967:69ec0859659b
user: riastradh <riastradh%NetBSD.org@localhost>
date: Sat Feb 01 13:35:11 2020 +0000
description:
Redocument xc_barrier.
Be more clearer, and more correcter, about what it does.
diffstat:
share/man/man9/xcall.9 | 38 ++++++++++++++++++++++++++------------
1 files changed, 26 insertions(+), 12 deletions(-)
diffs (70 lines):
diff -r 29bf4970c4e3 -r 69ec0859659b share/man/man9/xcall.9
--- a/share/man/man9/xcall.9 Sat Feb 01 13:26:43 2020 +0000
+++ b/share/man/man9/xcall.9 Sat Feb 01 13:35:11 2020 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: xcall.9,v 1.16 2019/11/30 02:22:23 riastradh Exp $
+.\" $NetBSD: xcall.9,v 1.17 2020/02/01 13:35:11 riastradh Exp $
.\"
.\" Copyright (c) 2010 The NetBSD Foundation, Inc.
.\" All rights reserved.
@@ -27,7 +27,7 @@
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
.\" POSSIBILITY OF SUCH DAMAGE.
.\"
-.Dd November 29, 2019
+.Dd February 1, 2020
.Dt XCALL 9
.Os
.Sh NAME
@@ -97,7 +97,7 @@
They may block on locks, but carefully and minimally, to not interfere
with other cross calls in the system.
.Sh FUNCTIONS
-.Bl -tag -width Fn
+.Bl -tag -width abcd
.It Fn xc_broadcast "flags" "func" "arg1" "arg2"
Call
.Pf (* Fa func\| ) Ns Fo ""
@@ -147,19 +147,33 @@
.Fn xc_wait
should be called from a thread context.
.It Fn xc_barrier "flags"
-Issue a broadcast cross-call that does nothing, using
-.Fa flags ,
+Issue a broadcast cross-call that does nothing,
and wait for it to complete.
-This has two effects:
-.Bl -dash -compact
-.It
-This waits for the interrupt priority level to transition to
-.Dv IPL_NONE
-at least once on all CPUs.
-.It
+.Pp
This functions like a memory barrier that forces all prior operations
in program order to globally happen before all subsequent operations in
program order, as witnessed by every CPU.
+.Pp
+This additionally waits for all higher-priority activity on the CPU to
+complete, according to
+.Fa flags :
+.Bl -dash -compact
+.It
+.Fo xc_barrier
+.Li 0
+.Fc
+waits for any pending
+.Xr kpreempt_disable 9
+sections or activity at interrupt priority level above
+.Dv IPL_NONE
+to finish on all CPUs.
+.It
+.Fo xc_barrier
+.Dv XC_HIGHPRI_IPL\| Ns Fn "" ipl
+.Fc
+waits for any pending activity at the software interrupt priority level
+.Fa ipl
+or higher to finish on all CPUs.
.El
.Pp
.Fn xc_barrier
Home |
Main Index |
Thread Index |
Old Index