Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/pci Fix the crash when ixl(4) sends Get link status ...



details:   https://anonhg.NetBSD.org/src/rev/1a52a962dca2
branches:  trunk
changeset: 969854:1a52a962dca2
user:      yamaguchi <yamaguchi%NetBSD.org@localhost>
date:      Tue Mar 03 04:19:20 2020 +0000

description:
Fix the crash when ixl(4) sends Get link status command
and receives Get link status response in parallel

sc->sc_link_state_atq.iatq_fn is used in ixl_atq_done_locked()
with sc->sc_atq_lock, but it was cleared in ixl_get_link_status()
without the lock.

diffstat:

 sys/dev/pci/if_ixl.c |  28 ++++++++++------------------
 1 files changed, 10 insertions(+), 18 deletions(-)

diffs (82 lines):

diff -r bca0c58dc940 -r 1a52a962dca2 sys/dev/pci/if_ixl.c
--- a/sys/dev/pci/if_ixl.c      Tue Mar 03 03:10:32 2020 +0000
+++ b/sys/dev/pci/if_ixl.c      Tue Mar 03 04:19:20 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_ixl.c,v 1.56 2020/02/25 08:05:24 yamaguchi Exp $    */
+/*     $NetBSD: if_ixl.c,v 1.57 2020/03/03 04:19:20 yamaguchi Exp $    */
 
 /*
  * Copyright (c) 2013-2015, Intel Corporation
@@ -74,7 +74,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_ixl.c,v 1.56 2020/02/25 08:05:24 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_ixl.c,v 1.57 2020/03/03 04:19:20 yamaguchi Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_net_mpsafe.h"
@@ -775,7 +775,6 @@
                    unsigned int);
 static void    ixl_atq_set(struct ixl_atq *,
                    void (*)(struct ixl_softc *, const struct ixl_aq_desc *));
-static int     ixl_atq_post(struct ixl_softc *, struct ixl_atq *);
 static int     ixl_atq_post_locked(struct ixl_softc *, struct ixl_atq *);
 static void    ixl_atq_done(struct ixl_softc *);
 static int     ixl_atq_exec(struct ixl_softc *, struct ixl_atq *);
@@ -798,6 +797,8 @@
 static void    ixl_set_filter_control(struct ixl_softc *);
 static void    ixl_get_link_status(void *);
 static int     ixl_get_link_status_poll(struct ixl_softc *, int *);
+static void    ixl_get_link_status_done(struct ixl_softc *,
+                   const struct ixl_aq_desc *);
 static int     ixl_set_link_status(struct ixl_softc *,
                    const struct ixl_aq_desc *);
 static uint64_t        ixl_search_link_speed(uint8_t);
@@ -1412,6 +1413,7 @@
                link = LINK_STATE_UNKNOWN;
        if_link_state_change(ifp, link);
 
+       ixl_atq_set(&sc->sc_link_state_atq, ixl_get_link_status_done);
        ixl_work_set(&sc->sc_link_state_task, ixl_get_link_status, sc);
 
        ixl_config_other_intr(sc);
@@ -3659,14 +3661,16 @@
        struct ixl_aq_desc *iaq;
        struct ixl_aq_link_param *param;
 
-       memset(&sc->sc_link_state_atq, 0, sizeof(sc->sc_link_state_atq));
+       mutex_enter(&sc->sc_atq_lock);
+
        iaq = &sc->sc_link_state_atq.iatq_desc;
+       memset(iaq, 0, sizeof(*iaq));
        iaq->iaq_opcode = htole16(IXL_AQ_OP_PHY_LINK_STATUS);
        param = (struct ixl_aq_link_param *)iaq->iaq_param;
        param->notify = IXL_AQ_LINK_NOTIFY;
 
-       ixl_atq_set(&sc->sc_link_state_atq, ixl_get_link_status_done);
-       (void)ixl_atq_post(sc, &sc->sc_link_state_atq);
+       (void)ixl_atq_post_locked(sc, &sc->sc_link_state_atq);
+       mutex_exit(&sc->sc_atq_lock);
 }
 
 static void
@@ -3818,18 +3822,6 @@
        return 0;
 }
 
-static int
-ixl_atq_post(struct ixl_softc *sc, struct ixl_atq *iatq)
-{
-       int rv;
-
-       mutex_enter(&sc->sc_atq_lock);
-       rv = ixl_atq_post_locked(sc, iatq);
-       mutex_exit(&sc->sc_atq_lock);
-
-       return rv;
-}
-
 static void
 ixl_atq_done_locked(struct ixl_softc *sc)
 {



Home | Main Index | Thread Index | Old Index