There is an ASSERT_RTNL in phylink_disconnect_phy which triggers
whenever dpaa2_switch_port_disconnect_mac is called.
To follow the pattern established by dpaa2_eth_disconnect_mac, take the
rtnl_mutex every time we call dpaa2_switch_port_disconnect_mac.
Fixes: 84cba72956fd ("dpaa2-switch: integrate the MAC endpoint support")
Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Reviewed-by: Ioana Ciornei <ioana.ciornei@nxp.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
        }
 
        if (status & DPSW_IRQ_EVENT_ENDPOINT_CHANGED) {
+               rtnl_lock();
                if (dpaa2_switch_port_has_mac(port_priv))
                        dpaa2_switch_port_disconnect_mac(port_priv);
                else
                        dpaa2_switch_port_connect_mac(port_priv);
+               rtnl_unlock();
        }
 
 out:
        for (i = 0; i < ethsw->sw_attr.num_ifs; i++) {
                port_priv = ethsw->ports[i];
                unregister_netdev(port_priv->netdev);
+               rtnl_lock();
                dpaa2_switch_port_disconnect_mac(port_priv);
+               rtnl_unlock();
                free_netdev(port_priv->netdev);
        }