• Vladimir Oltean's avatar
    net: dpaa2-eth: assign priv->mac after dpaa2_mac_connect() call · 02d61948
    Vladimir Oltean authored
    There are 2 requirements for correct code:
    
    - Any time the driver accesses the priv->mac pointer at runtime, it
      either holds NULL to indicate a DPNI-DPNI connection (or unconnected
      DPNI), or a struct dpaa2_mac whose phylink instance was fully
      initialized (created and connected to the PHY). No changes are made to
      priv->mac while it is being used. Currently, rtnl_lock() watches over
      the call to dpaa2_eth_connect_mac(), so it serves the purpose of
      serializing this with all readers of priv->mac.
    
    - dpaa2_mac_connect() should run unlocked, because inside it are 2
      phylink calls with incompatible locking requirements: phylink_create()
      requires that the rtnl_mutex isn't held, and phylink_fwnode_phy_connect()
      requires that the rtnl_mutex is held. The only way to solve those
      contradictory requirements is to let dpaa2_mac_connect() take
      rtnl_lock() when it needs to.
    
    To solve both requirements, we need to identify the writer side of the
    priv->mac pointer, which can be wrapped in a mutex private to the driver
    in a future patch. The dpaa2_mac_connect() cannot be part of the writer
    side critical section, because of an AB/BA deadlock with rtnl_lock().
    
    So the strategy needs to be that where we prepare the DPMAC by calling
    dpaa2_mac_connect(), and only make priv->mac point to it once it's fully
    prepared. This ensures that the writer side critical section has the
    absolute minimum surface it can.
    
    The reverse strategy is adopted in the dpaa2_eth_disconnect_mac() code
    path. This makes sure that priv->mac is NULL when we start tearing down
    the DPMAC that we disconnected from, and concurrent code will simply not
    see it.
    
    No locking changes in this patch (concurrent code is still blocked by
    the rtnl_mutex).
    Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
    Reviewed-by: default avatarIoana Ciornei <ioana.ciornei@nxp.com>
    Tested-by: default avatarIoana Ciornei <ioana.ciornei@nxp.com>
    Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
    02d61948
dpaa2-eth.c 131 KB