]> git.baikalelectronics.ru Git - kernel.git/commitdiff
dpaa2-eth: unregister the netdev before disconnecting from the PHY
authorRobert-Ionut Alexa <robert-ionut.alexa@nxp.com>
Wed, 9 Feb 2022 15:57:43 +0000 (17:57 +0200)
committerDavid S. Miller <davem@davemloft.net>
Thu, 10 Feb 2022 15:21:53 +0000 (15:21 +0000)
The netdev should be unregistered before we are disconnecting from the
MAC/PHY so that the dev_close callback is called and the PHY and the
phylink workqueues are actually stopped before we are disconnecting and
destroying the phylink instance.

Fixes: b96dc6eb861b ("dpaa2-eth: add MAC/PHY support through phylink")
Signed-off-by: Robert-Ionut Alexa <robert-ionut.alexa@nxp.com>
Signed-off-by: Ioana Ciornei <ioana.ciornei@nxp.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/freescale/dpaa2/dpaa2-eth.c

index e985ae008a979585c3c0776a085b0788cd79a177..dd9385d15f6bdf1ed8382570bd970fb03e9bc484 100644 (file)
@@ -4523,12 +4523,12 @@ static int dpaa2_eth_remove(struct fsl_mc_device *ls_dev)
 #ifdef CONFIG_DEBUG_FS
        dpaa2_dbg_remove(priv);
 #endif
+
+       unregister_netdev(net_dev);
        rtnl_lock();
        dpaa2_eth_disconnect_mac(priv);
        rtnl_unlock();
 
-       unregister_netdev(net_dev);
-
        dpaa2_eth_dl_port_del(priv);
        dpaa2_eth_dl_traps_unregister(priv);
        dpaa2_eth_dl_free(priv);