sfc: Fold efx_flush_all() into efx_stop_port() and update comments
efx_flush_all() is a really misleading name - it has nothing to do with e.g. flushing DMA queues. Since it's called immediately after efx_stop_port() and is highly dependent on what that does, combine the two functions. Update comments to explain what this is doing a little better. Also update an related and erroneous comment in efx_start_port(). Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
This commit is contained in:
parent
ea136ae71f
commit
d615c03937
@ -1060,18 +1060,23 @@ static void efx_start_port(struct efx_nic *efx)
|
||||
mutex_lock(&efx->mac_lock);
|
||||
efx->port_enabled = true;
|
||||
|
||||
/* efx_mac_work() might have been scheduled after efx_stop_port(),
|
||||
* and then cancelled by efx_flush_all() */
|
||||
/* Ensure MAC ingress/egress is enabled */
|
||||
efx->type->reconfigure_mac(efx);
|
||||
|
||||
mutex_unlock(&efx->mac_lock);
|
||||
}
|
||||
|
||||
/* Prevent efx_mac_work() and efx_monitor() from working */
|
||||
/* Cancel work for MAC reconfiguration, periodic hardware monitoring
|
||||
* and the async self-test, wait for them to finish and prevent them
|
||||
* being scheduled again. This doesn't cover online resets, which
|
||||
* should only be cancelled when removing the device.
|
||||
*/
|
||||
static void efx_stop_port(struct efx_nic *efx)
|
||||
{
|
||||
netif_dbg(efx, ifdown, efx->net_dev, "stop port\n");
|
||||
|
||||
EFX_ASSERT_RESET_SERIALISED(efx);
|
||||
|
||||
mutex_lock(&efx->mac_lock);
|
||||
efx->port_enabled = false;
|
||||
mutex_unlock(&efx->mac_lock);
|
||||
@ -1079,6 +1084,10 @@ static void efx_stop_port(struct efx_nic *efx)
|
||||
/* Serialise against efx_set_multicast_list() */
|
||||
netif_addr_lock_bh(efx->net_dev);
|
||||
netif_addr_unlock_bh(efx->net_dev);
|
||||
|
||||
cancel_delayed_work_sync(&efx->monitor_work);
|
||||
efx_selftest_async_cancel(efx);
|
||||
cancel_work_sync(&efx->mac_work);
|
||||
}
|
||||
|
||||
static void efx_fini_port(struct efx_nic *efx)
|
||||
@ -1690,18 +1699,6 @@ static void efx_start_all(struct efx_nic *efx)
|
||||
spin_unlock_bh(&efx->stats_lock);
|
||||
}
|
||||
|
||||
/* Flush all delayed work. Should only be called when no more delayed work
|
||||
* will be scheduled. This doesn't flush pending online resets (efx_reset),
|
||||
* since we're holding the rtnl_lock at this point. */
|
||||
static void efx_flush_all(struct efx_nic *efx)
|
||||
{
|
||||
/* Make sure the hardware monitor and event self-test are stopped */
|
||||
cancel_delayed_work_sync(&efx->monitor_work);
|
||||
efx_selftest_async_cancel(efx);
|
||||
/* Stop scheduled port reconfigurations */
|
||||
cancel_work_sync(&efx->mac_work);
|
||||
}
|
||||
|
||||
/* Quiesce the hardware and software data path, and regular activity
|
||||
* for the port without bringing the link down. Safe to call multiple
|
||||
* times with the NIC in almost any state, but interrupts should be
|
||||
@ -1725,9 +1722,6 @@ static void efx_stop_all(struct efx_nic *efx)
|
||||
efx->type->stop_stats(efx);
|
||||
efx_stop_port(efx);
|
||||
|
||||
/* Flush efx_mac_work(), refill_workqueue, monitor_work */
|
||||
efx_flush_all(efx);
|
||||
|
||||
/* Stop the kernel transmit interface. This is only valid if
|
||||
* the device is stopped or detached; otherwise the watchdog
|
||||
* may fire immediately.
|
||||
|
Loading…
x
Reference in New Issue
Block a user