Source-Changes-HG archive

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

[src/trunk]: src/sys/kern If the system is not up and running yet, just run t...



details:   https://anonhg.NetBSD.org/src/rev/014599e9582f
branches:  trunk
changeset: 1005175:014599e9582f
user:      ad <ad%NetBSD.org@localhost>
date:      Sun Dec 01 14:20:00 2019 +0000

description:
If the system is not up and running yet, just run the function locally.

diffstat:

 sys/kern/subr_xcall.c |  37 ++++++++++++++++++++++++++++++-------
 1 files changed, 30 insertions(+), 7 deletions(-)

diffs (94 lines):

diff -r 4bc165d597e1 -r 014599e9582f sys/kern/subr_xcall.c
--- a/sys/kern/subr_xcall.c     Sun Dec 01 14:18:51 2019 +0000
+++ b/sys/kern/subr_xcall.c     Sun Dec 01 14:20:00 2019 +0000
@@ -1,7 +1,7 @@
-/*     $NetBSD: subr_xcall.c,v 1.28 2019/11/11 09:50:11 maxv Exp $     */
+/*     $NetBSD: subr_xcall.c,v 1.29 2019/12/01 14:20:00 ad Exp $       */
 
 /*-
- * Copyright (c) 2007-2010 The NetBSD Foundation, Inc.
+ * Copyright (c) 2007-2010, 2019 The NetBSD Foundation, Inc.
  * All rights reserved.
  *
  * This code is derived from software contributed to The NetBSD Foundation
@@ -74,7 +74,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_xcall.c,v 1.28 2019/11/11 09:50:11 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_xcall.c,v 1.29 2019/12/01 14:20:00 ad Exp $");
 
 #include <sys/types.h>
 #include <sys/param.h>
@@ -84,6 +84,7 @@
 #include <sys/evcnt.h>
 #include <sys/kthread.h>
 #include <sys/cpu.h>
+#include <sys/atomic.h>
 
 #ifdef _RUMPKERNEL
 #include "rump_private.h"
@@ -259,6 +260,11 @@
        KASSERT(!cpu_intr_p() && !cpu_softintr_p());
        ASSERT_SLEEPABLE();
 
+       if (__predict_false(!mp_online)) {
+               (*func)(arg1, arg2);
+               return 0;
+       }
+
        if ((flags & XC_HIGHPRI) != 0) {
                int ipl = xc_extract_ipl(flags);
                return xc_highpri(func, arg1, arg2, NULL, ipl);
@@ -300,11 +306,20 @@
 xc_unicast(unsigned int flags, xcfunc_t func, void *arg1, void *arg2,
           struct cpu_info *ci)
 {
+       int s;
 
        KASSERT(ci != NULL);
        KASSERT(!cpu_intr_p() && !cpu_softintr_p());
        ASSERT_SLEEPABLE();
 
+       if (__predict_false(!mp_online)) {
+               KASSERT(ci == curcpu());
+               s = splsoftserial();
+               (*func)(arg1, arg2);
+               splx(s);
+               return 0;
+       }
+
        if ((flags & XC_HIGHPRI) != 0) {
                int ipl = xc_extract_ipl(flags);
                return xc_highpri(func, arg1, arg2, ci, ipl);
@@ -326,6 +341,10 @@
        KASSERT(!cpu_intr_p() && !cpu_softintr_p());
        ASSERT_SLEEPABLE();
 
+       if (__predict_false(!mp_online)) {
+               return;
+       }
+
        /* Determine whether it is high or low priority cross-call. */
        if ((where & XC_PRI_BIT) != 0) {
                xc = &xc_high_pri;
@@ -335,11 +354,15 @@
        }
 
        /* Block until awoken. */
-       mutex_enter(&xc->xc_lock);
-       while (xc->xc_donep < where) {
-               cv_wait(&xc->xc_busy, &xc->xc_lock);
+       if (xc->xc_donep < where) {
+               mutex_enter(&xc->xc_lock);
+               while (xc->xc_donep < where) {
+                       cv_wait(&xc->xc_busy, &xc->xc_lock);
+               }
+               mutex_exit(&xc->xc_lock);
+       } else {
+               membar_enter();
        }
-       mutex_exit(&xc->xc_lock);
 }
 
 /*



Home | Main Index | Thread Index | Old Index