diff options
author | Steve Hodgson <shodgson@solarflare.com> | 2010-02-03 04:30:38 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-02-03 22:12:44 -0500 |
commit | 7a6b8f6f7f74085a1330b0f9765d81bcea8c58b7 (patch) | |
tree | 6358e7e8d94d3475c864c114188df2c6eb4a98ff /drivers/net/sfc/mcdi_phy.c | |
parent | 8b2103add08b79abd3ac7015b4bac744c0af534e (diff) |
sfc: Enable autonegotiated flow-control by default if supported
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc/mcdi_phy.c')
-rw-r--r-- | drivers/net/sfc/mcdi_phy.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/drivers/net/sfc/mcdi_phy.c b/drivers/net/sfc/mcdi_phy.c index eb694af7a473..d87e74d3994e 100644 --- a/drivers/net/sfc/mcdi_phy.c +++ b/drivers/net/sfc/mcdi_phy.c | |||
@@ -381,6 +381,18 @@ static int efx_mcdi_phy_probe(struct efx_nic *efx) | |||
381 | * but by convention we don't */ | 381 | * but by convention we don't */ |
382 | efx->loopback_modes &= ~(1 << LOOPBACK_NONE); | 382 | efx->loopback_modes &= ~(1 << LOOPBACK_NONE); |
383 | 383 | ||
384 | /* Set the initial link mode */ | ||
385 | efx_mcdi_phy_decode_link( | ||
386 | efx, &efx->link_state, | ||
387 | MCDI_DWORD(outbuf, GET_LINK_OUT_LINK_SPEED), | ||
388 | MCDI_DWORD(outbuf, GET_LINK_OUT_FLAGS), | ||
389 | MCDI_DWORD(outbuf, GET_LINK_OUT_FCNTL)); | ||
390 | |||
391 | /* Default to Autonegotiated flow control if the PHY supports it */ | ||
392 | efx->wanted_fc = EFX_FC_RX | EFX_FC_TX; | ||
393 | if (phy_data->supported_cap & (1 << MC_CMD_PHY_CAP_AN_LBN)) | ||
394 | efx->wanted_fc |= EFX_FC_AUTO; | ||
395 | |||
384 | return 0; | 396 | return 0; |
385 | 397 | ||
386 | fail: | 398 | fail: |
@@ -436,7 +448,7 @@ void efx_mcdi_phy_check_fcntl(struct efx_nic *efx, u32 lpa) | |||
436 | 448 | ||
437 | /* The link partner capabilities are only relevent if the | 449 | /* The link partner capabilities are only relevent if the |
438 | * link supports flow control autonegotiation */ | 450 | * link supports flow control autonegotiation */ |
439 | if (~phy_cfg->supported_cap & (1 << MC_CMD_PHY_CAP_ASYM_LBN)) | 451 | if (~phy_cfg->supported_cap & (1 << MC_CMD_PHY_CAP_AN_LBN)) |
440 | return; | 452 | return; |
441 | 453 | ||
442 | /* If flow control autoneg is supported and enabled, then fine */ | 454 | /* If flow control autoneg is supported and enabled, then fine */ |