diff options
author | Steve Hodgson <shodgson@solarflare.com> | 2009-01-29 12:48:43 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-01-30 17:06:27 -0500 |
commit | 2d18835d65b7433e7e6583f65395f8c01e7874af (patch) | |
tree | 2bc1e1ade74236a763c8894c0e048039af6bbf31 /drivers/net/sfc/tenxpress.c | |
parent | 869b5b3888fbd2024af632e3648c00860ba3cca6 (diff) |
sfc: SFX7101: Remove workaround for bad link training
Early versions of the SFX7101 firmware could complete link training in
a state where it would not adequately cancel noise (Solarflare bug
10750). We previously worked around this by resetting the PHY after
seeing many Ethernet CRC errors. This workaround is unsafe since it
takes no account of the interval between errors; it also appears to
be unnecessary with production firmware. Therefore remove it.
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc/tenxpress.c')
-rw-r--r-- | drivers/net/sfc/tenxpress.c | 20 |
1 files changed, 0 insertions, 20 deletions
diff --git a/drivers/net/sfc/tenxpress.c b/drivers/net/sfc/tenxpress.c index 19cfc318954c..80c8d6e3131e 100644 --- a/drivers/net/sfc/tenxpress.c +++ b/drivers/net/sfc/tenxpress.c | |||
@@ -189,25 +189,12 @@ | |||
189 | * rails */ | 189 | * rails */ |
190 | #define LNPGA_PDOWN_WAIT (HZ / 5) | 190 | #define LNPGA_PDOWN_WAIT (HZ / 5) |
191 | 191 | ||
192 | static int crc_error_reset_threshold = 100; | ||
193 | module_param(crc_error_reset_threshold, int, 0644); | ||
194 | MODULE_PARM_DESC(crc_error_reset_threshold, | ||
195 | "Max number of CRC errors before XAUI reset"); | ||
196 | |||
197 | struct tenxpress_phy_data { | 192 | struct tenxpress_phy_data { |
198 | enum efx_loopback_mode loopback_mode; | 193 | enum efx_loopback_mode loopback_mode; |
199 | atomic_t bad_crc_count; | ||
200 | enum efx_phy_mode phy_mode; | 194 | enum efx_phy_mode phy_mode; |
201 | int bad_lp_tries; | 195 | int bad_lp_tries; |
202 | }; | 196 | }; |
203 | 197 | ||
204 | void tenxpress_crc_err(struct efx_nic *efx) | ||
205 | { | ||
206 | struct tenxpress_phy_data *phy_data = efx->phy_data; | ||
207 | if (phy_data != NULL) | ||
208 | atomic_inc(&phy_data->bad_crc_count); | ||
209 | } | ||
210 | |||
211 | static ssize_t show_phy_short_reach(struct device *dev, | 198 | static ssize_t show_phy_short_reach(struct device *dev, |
212 | struct device_attribute *attr, char *buf) | 199 | struct device_attribute *attr, char *buf) |
213 | { | 200 | { |
@@ -627,13 +614,6 @@ static void tenxpress_phy_poll(struct efx_nic *efx) | |||
627 | 614 | ||
628 | if (phy_data->phy_mode != PHY_MODE_NORMAL) | 615 | if (phy_data->phy_mode != PHY_MODE_NORMAL) |
629 | return; | 616 | return; |
630 | |||
631 | if (EFX_WORKAROUND_10750(efx) && | ||
632 | atomic_read(&phy_data->bad_crc_count) > crc_error_reset_threshold) { | ||
633 | EFX_ERR(efx, "Resetting XAUI due to too many CRC errors\n"); | ||
634 | falcon_reset_xaui(efx); | ||
635 | atomic_set(&phy_data->bad_crc_count, 0); | ||
636 | } | ||
637 | } | 617 | } |
638 | 618 | ||
639 | static void tenxpress_phy_fini(struct efx_nic *efx) | 619 | static void tenxpress_phy_fini(struct efx_nic *efx) |