diff options
author | Yaniv Rosner <yanivr@broadcom.com> | 2013-03-07 08:27:33 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-03-08 00:35:44 -0500 |
commit | 5f3347e6e75768985a088d959c49fb66263087b6 (patch) | |
tree | 4c78b24ff9b1ee3efcdf20c1d458c70ca14a54b2 | |
parent | 87ab7f6f2874f1115817e394a7ed2dea1c72549e (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.c | 11 | ||||
-rw-r--r-- | drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.h | 3 |
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 | ||