Module Name:    src
Committed By:   yamaguchi
Date:           Fri Mar 13 05:40:20 UTC 2020

Modified Files:
        src/sys/dev/pci: if_ixl.c

Log Message:
Fix locking against myself at ixl_link_state_update()
called by ixl_get_link_status()

Though the timing to call the function is change,
there is no order to get link status at initialization.


To generate a diff of this commit:
cvs rdiff -u -r1.62 -r1.63 src/sys/dev/pci/if_ixl.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/dev/pci/if_ixl.c
diff -u src/sys/dev/pci/if_ixl.c:1.62 src/sys/dev/pci/if_ixl.c:1.63
--- src/sys/dev/pci/if_ixl.c:1.62	Thu Mar 12 09:38:10 2020
+++ src/sys/dev/pci/if_ixl.c	Fri Mar 13 05:40:20 2020
@@ -1,4 +1,4 @@
-/*	$NetBSD: if_ixl.c,v 1.62 2020/03/12 09:38:10 yamaguchi Exp $	*/
+/*	$NetBSD: if_ixl.c,v 1.63 2020/03/13 05:40: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.62 2020/03/12 09:38:10 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_ixl.c,v 1.63 2020/03/13 05:40:20 yamaguchi Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_net_mpsafe.h"
@@ -2116,8 +2116,6 @@ ixl_init_locked(struct ixl_softc *sc)
 	SET(ifp->if_flags, IFF_RUNNING);
 	CLR(ifp->if_flags, IFF_OACTIVE);
 
-	(void)ixl_get_link_status(sc);
-
 	ixl_config_rss(sc);
 	ixl_config_queue_intr(sc);
 
@@ -2146,6 +2144,9 @@ ixl_init(struct ifnet *ifp)
 	error = ixl_init_locked(sc);
 	mutex_exit(&sc->sc_cfg_lock);
 
+	if (error == 0)
+		(void)ixl_get_link_status(sc);
+
 	return error;
 }
 
@@ -3683,7 +3684,6 @@ ixl_get_link_status(void *xsc)
 		ixl_get_link_status_done(sc, iaq);
 	}
 
-
 	mutex_exit(&sc->sc_atq_lock);
 }
 

Reply via email to