aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYaniv Rosner <yanivr@broadcom.com>2013-03-07 08:27:33 -0500
committerDavid S. Miller <davem@davemloft.net>2013-03-08 00:35:44 -0500
commit5f3347e6e75768985a088d959c49fb66263087b6 (patch)
tree4c78b24ff9b1ee3efcdf20c1d458c70ca14a54b2
parent87ab7f6f2874f1115817e394a7ed2dea1c72549e (diff)
bnx2x: Fix intermittent long KR2 link up time
When a KR2 device is connected to a KR link-partner, sometimes it requires disabling KR2 for the link to come up. To get a KR2 link up later, in case no base pages are seen, the KR2 is restored. The problem was that some link partners cleared their advertised BP/NP after around two seconds, causing the driver to disable/enable KR2 link all the time. The fix was to wait at least 5 seconds before checking KR2 recovery. Signed-off-by: Yaniv Rosner <yanivr@broadcom.com> Signed-off-by: Eilon Greenstein <eilong@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c11
-rw-r--r--drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.h3
2 files changed, 13 insertions, 1 deletions
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c
index 31c5787970db..00ac4932f4c4 100644
--- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c
+++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c
@@ -12527,6 +12527,7 @@ int bnx2x_phy_init(struct link_params *params, struct link_vars *vars)
12527 vars->flow_ctrl = BNX2X_FLOW_CTRL_NONE; 12527 vars->flow_ctrl = BNX2X_FLOW_CTRL_NONE;
12528 vars->mac_type = MAC_TYPE_NONE; 12528 vars->mac_type = MAC_TYPE_NONE;
12529 vars->phy_flags = 0; 12529 vars->phy_flags = 0;
12530 vars->check_kr2_recovery_cnt = 0;
12530 /* Driver opens NIG-BRB filters */ 12531 /* Driver opens NIG-BRB filters */
12531 bnx2x_set_rx_filter(params, 1); 12532 bnx2x_set_rx_filter(params, 1);
12532 /* Check if link flap can be avoided */ 12533 /* Check if link flap can be avoided */
@@ -13411,6 +13412,7 @@ static void bnx2x_disable_kr2(struct link_params *params,
13411 vars->link_attr_sync &= ~LINK_ATTR_SYNC_KR2_ENABLE; 13412 vars->link_attr_sync &= ~LINK_ATTR_SYNC_KR2_ENABLE;
13412 bnx2x_update_link_attr(params, vars->link_attr_sync); 13413 bnx2x_update_link_attr(params, vars->link_attr_sync);
13413 13414
13415 vars->check_kr2_recovery_cnt = CHECK_KR2_RECOVERY_CNT;
13414 /* Restart AN on leading lane */ 13416 /* Restart AN on leading lane */
13415 bnx2x_warpcore_restart_AN_KR(phy, params); 13417 bnx2x_warpcore_restart_AN_KR(phy, params);
13416} 13418}
@@ -13439,6 +13441,15 @@ static void bnx2x_check_kr2_wa(struct link_params *params,
13439 return; 13441 return;
13440 } 13442 }
13441 13443
13444 /* Once KR2 was disabled, wait 5 seconds before checking KR2 recovery
13445 * since some switches tend to reinit the AN process and clear the
13446 * advertised BP/NP after ~2 seconds causing the KR2 to be disabled
13447 * and recovered many times
13448 */
13449 if (vars->check_kr2_recovery_cnt > 0) {
13450 vars->check_kr2_recovery_cnt--;
13451 return;
13452 }
13442 lane = bnx2x_get_warpcore_lane(phy, params); 13453 lane = bnx2x_get_warpcore_lane(phy, params);
13443 CL22_WR_OVER_CL45(bp, phy, MDIO_REG_BANK_AER_BLOCK, 13454 CL22_WR_OVER_CL45(bp, phy, MDIO_REG_BANK_AER_BLOCK,
13444 MDIO_AER_BLOCK_AER_REG, lane); 13455 MDIO_AER_BLOCK_AER_REG, lane);
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.h b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.h
index be5c195d03dd..f92fcf71be04 100644
--- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.h
+++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.h
@@ -342,7 +342,8 @@ struct link_vars {
342 u32 link_status; 342 u32 link_status;
343 u32 eee_status; 343 u32 eee_status;
344 u8 fault_detected; 344 u8 fault_detected;
345 u8 rsrv1; 345 u8 check_kr2_recovery_cnt;
346#define CHECK_KR2_RECOVERY_CNT 5
346 u16 periodic_flags; 347 u16 periodic_flags;
347#define PERIODIC_FLAGS_LINK_EVENT 0x0001 348#define PERIODIC_FLAGS_LINK_EVENT 0x0001
348 349