aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/sfc
diff options
context:
space:
mode:
authorBen Hutchings <bhutchings@solarflare.com>2009-08-26 04:17:59 -0400
committerDavid S. Miller <davem@davemloft.net>2009-08-26 20:38:56 -0400
commitcc11763b3510e4942bfece052ccf329a7b086a32 (patch)
tree26a5e7a01cc798738acd5522b2a183184b5ee0ac /drivers/net/sfc
parent5afaa753d681c437419e3dd9b532c2712dd1d2ea (diff)
sfc: Work around XMAC bug causing packet loss with some peers
Received frames must be re-clocked by the local XGXS to the 156.25 MHz (DDR) clock of the XGMII. If the remote clock is slightly faster this can reduce a minimum IPG of 64 bit-times (1 cycle) to 32 bit-times (half a cycle). If the XMAC detects that a frame has reached the maximum RX frame length in the same cycle that it receives one of these reduced IPGs, it may miss the IPG, causing two valid frames to be treated as a single invalid frame (over-length with bad CRC). We work around this by increasing the maximum RX frame length so that peers with matched MTU will not provoke this bug. Signed-off-by: Ben Hutchings <bhutchings@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc')
-rw-r--r--drivers/net/sfc/net_driver.h7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/net/sfc/net_driver.h b/drivers/net/sfc/net_driver.h
index 5eabede9ac18..298566da638b 100644
--- a/drivers/net/sfc/net_driver.h
+++ b/drivers/net/sfc/net_driver.h
@@ -984,9 +984,14 @@ static inline void clear_bit_le(unsigned nr, unsigned char *addr)
984 * 984 *
985 * The 10G MAC used in Falcon requires 8-byte alignment on the frame 985 * The 10G MAC used in Falcon requires 8-byte alignment on the frame
986 * length, so we round up to the nearest 8. 986 * length, so we round up to the nearest 8.
987 *
988 * Re-clocking by the XGXS on RX can reduce an IPG to 32 bits (half an
989 * XGMII cycle). If the frame length reaches the maximum value in the
990 * same cycle, the XMAC can miss the IPG altogether. We work around
991 * this by adding a further 16 bytes.
987 */ 992 */
988#define EFX_MAX_FRAME_LEN(mtu) \ 993#define EFX_MAX_FRAME_LEN(mtu) \
989 ((((mtu) + ETH_HLEN + VLAN_HLEN + 4/* FCS */) + 7) & ~7) 994 ((((mtu) + ETH_HLEN + VLAN_HLEN + 4/* FCS */ + 7) & ~7) + 16)
990 995
991 996
992#endif /* EFX_NET_DRIVER_H */ 997#endif /* EFX_NET_DRIVER_H */