diff options
author | Steve Hodgson <shodgson@solarflare.com> | 2011-05-23 07:18:45 -0400 |
---|---|---|
committer | Ben Hutchings <bhutchings@solarflare.com> | 2012-02-15 19:25:07 -0500 |
commit | a606f4325dca6950996abbae452d33f2af095f39 (patch) | |
tree | 5d39056ca66b6be3190ff9df902eb404acc17eda /drivers/net/ethernet/sfc/mcdi_mac.c | |
parent | 90893000e21e2d52a0a9d5aa0c4234c90bcd9470 (diff) |
sfc: Disable flow control during flushes
The TX DMA engine issues upstream read requests when there is room in
the TX FIFO for the completion. However, the fetches for the rest of
the packet might be delayed by any back pressure. Since a flush must
wait for an EOP, the entire flush may be delayed by back pressure.
Mitigate this by disabling flow control before the flushes are
started. Since PF and VF flushes run in parallel introduce
fc_disable, a reference count of the number of flushes outstanding.
The same principle could be applied to Falcon, but that
would bring with it its own testing.
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Diffstat (limited to 'drivers/net/ethernet/sfc/mcdi_mac.c')
-rw-r--r-- | drivers/net/ethernet/sfc/mcdi_mac.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/net/ethernet/sfc/mcdi_mac.c b/drivers/net/ethernet/sfc/mcdi_mac.c index f67cf921bd1b..98afe1c1165d 100644 --- a/drivers/net/ethernet/sfc/mcdi_mac.c +++ b/drivers/net/ethernet/sfc/mcdi_mac.c | |||
@@ -44,6 +44,8 @@ static int efx_mcdi_set_mac(struct efx_nic *efx) | |||
44 | } | 44 | } |
45 | if (efx->wanted_fc & EFX_FC_AUTO) | 45 | if (efx->wanted_fc & EFX_FC_AUTO) |
46 | fcntl = MC_CMD_FCNTL_AUTO; | 46 | fcntl = MC_CMD_FCNTL_AUTO; |
47 | if (efx->fc_disable) | ||
48 | fcntl = MC_CMD_FCNTL_OFF; | ||
47 | 49 | ||
48 | MCDI_SET_DWORD(cmdbytes, SET_MAC_IN_FCNTL, fcntl); | 50 | MCDI_SET_DWORD(cmdbytes, SET_MAC_IN_FCNTL, fcntl); |
49 | 51 | ||