Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/pci Introduce the lock for vioif_softc to avoid a ra...



details:   https://anonhg.NetBSD.org/src/rev/d4445af66f8b
branches:  trunk
changeset: 1010421:d4445af66f8b
user:      yamaguchi <yamaguchi%NetBSD.org@localhost>
date:      Mon May 25 09:36:18 2020 +0000

description:
Introduce the lock for vioif_softc to avoid a race condition
in vioif_update_link_status()

The function is called in both vioif_init() and softint.

diffstat:

 sys/dev/pci/if_vioif.c |  15 +++++++++++++--
 1 files changed, 13 insertions(+), 2 deletions(-)

diffs (71 lines):

diff -r 52ba160b948e -r d4445af66f8b sys/dev/pci/if_vioif.c
--- a/sys/dev/pci/if_vioif.c    Mon May 25 09:31:09 2020 +0000
+++ b/sys/dev/pci/if_vioif.c    Mon May 25 09:36:18 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_vioif.c,v 1.61 2020/05/25 09:31:09 yamaguchi Exp $  */
+/*     $NetBSD: if_vioif.c,v 1.62 2020/05/25 09:36:18 yamaguchi Exp $  */
 
 /*
  * Copyright (c) 2010 Minoura Makoto.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.61 2020/05/25 09:31:09 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vioif.c,v 1.62 2020/05/25 09:36:18 yamaguchi Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_net_mpsafe.h"
@@ -205,6 +205,9 @@
  * + ctrlq_inuse is protected by ctrlq_wait_lock.
  *      - other fields in vioif_ctrlqueue are protected by ctrlq_inuse
  *      - txq_lock or rxq_lock cannot be held along with ctrlq_wait_lock
+ * + fields in vioif_softc except queues are protected by
+ *   sc->sc_lock(an adaptive mutex)
+ *      - the lock is held before acquisition of other locks
  */
 
 struct vioif_work {
@@ -279,6 +282,7 @@
 
 struct vioif_softc {
        device_t                sc_dev;
+       kmutex_t                sc_lock;
        struct sysctllog        *sc_sysctllog;
 
        struct virtio_softc     *sc_virtio;
@@ -793,6 +797,8 @@
        sc->sc_rx_intr_process_limit = VIOIF_RX_INTR_PROCESS_LIMIT;
        sc->sc_rx_process_limit = VIOIF_RX_PROCESS_LIMIT;
 
+       mutex_init(&sc->sc_lock, MUTEX_DEFAULT, IPL_NONE);
+
        snprintf(xnamebuf, sizeof(xnamebuf), "%s_txrx", device_xname(self));
        sc->sc_txrx_workqueue = vioif_workq_create(xnamebuf, VIOIF_WORKQUEUE_PRI,
            IPL_NET, WQ_PERCPU | WQ_MPSAFE);
@@ -1039,6 +1045,7 @@
                virtio_free_vq(vsc, &sc->sc_vqs[--nvqs]);
 
        vioif_free_queues(sc);
+       mutex_destroy(&sc->sc_lock);
        virtio_child_attach_failed(vsc);
        config_finalize_register(self, vioif_finalize_teardown);
 
@@ -2274,6 +2281,8 @@
        bool active, changed;
        int link, i;
 
+       mutex_enter(&sc->sc_lock);
+
        active = vioif_is_link_up(sc);
        changed = false;
 
@@ -2302,6 +2311,8 @@
 
                if_link_state_change(ifp, link);
        }
+
+       mutex_exit(&sc->sc_lock);
 }
 
 static int



Home | Main Index | Thread Index | Old Index