dpaa2-mac: fix the remove path for non-MAC interfaces
authorIoana Ciornei <ioana.ciornei@nxp.com>
Mon, 11 Jan 2021 17:18:02 +0000 (19:18 +0200)
committerIoana Ciornei <ciorneiioana@gmail.com>
Mon, 26 Apr 2021 09:22:47 +0000 (12:22 +0300)
Check if the interface is indeed connected to a MAC before trying to
close the DPMAC object representing it. Without this check we end up
working with a NULL pointer.

Fixes: d87e606373f6 ("dpaa2-mac: export MAC counters even when in TYPE_FIXED")
Signed-off-by: Ioana Ciornei <ioana.ciornei@nxp.com>
Link: https://lore.kernel.org/r/20210111171802.1826324-1-ciorneiioana@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/freescale/dpaa2/dpaa2-eth.c

index 3e5ab86..7a91ffa 100644 (file)
@@ -4120,6 +4120,9 @@ static void dpaa2_eth_disconnect_mac(struct dpaa2_eth_priv *priv)
        if (dpaa2_eth_is_type_phy(priv))
                dpaa2_mac_disconnect(priv->mac);
 
+       if (!dpaa2_eth_has_mac(priv))
+               return;
+
        dpaa2_mac_close(priv->mac);
        kfree(priv->mac);
        priv->mac = NULL;