diff options
author | Ben Hutchings <bhutchings@solarflare.com> | 2010-09-22 06:00:11 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-09-22 16:26:45 -0400 |
commit | 8fbca791309b5a57bec53e5fd7da912c16416ed3 (patch) | |
tree | 3561892d5b36142e45ef028b175f66825b9d4ee9 /drivers/net/sfc/mdio_10g.c | |
parent | a0741ca949692904646c310573754859cba09bf1 (diff) |
sfc: Remove support for SFN4111T, SFT9001 and Falcon GMAC
SFN4111T never reached production and is not being used for internal
or customer testing.
Since we have no production Falcon boards using the SFT9001 or the
GMAC, remove support for them as well.
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc/mdio_10g.c')
-rw-r--r-- | drivers/net/sfc/mdio_10g.c | 30 |
1 files changed, 4 insertions, 26 deletions
diff --git a/drivers/net/sfc/mdio_10g.c b/drivers/net/sfc/mdio_10g.c index eeaf0bd64bd3..98d946020429 100644 --- a/drivers/net/sfc/mdio_10g.c +++ b/drivers/net/sfc/mdio_10g.c | |||
@@ -286,46 +286,24 @@ int efx_mdio_set_settings(struct efx_nic *efx, struct ethtool_cmd *ecmd) | |||
286 | */ | 286 | */ |
287 | void efx_mdio_an_reconfigure(struct efx_nic *efx) | 287 | void efx_mdio_an_reconfigure(struct efx_nic *efx) |
288 | { | 288 | { |
289 | bool xnp = (efx->link_advertising & ADVERTISED_10000baseT_Full | ||
290 | || EFX_WORKAROUND_13204(efx)); | ||
291 | int reg; | 289 | int reg; |
292 | 290 | ||
293 | WARN_ON(!(efx->mdio.mmds & MDIO_DEVS_AN)); | 291 | WARN_ON(!(efx->mdio.mmds & MDIO_DEVS_AN)); |
294 | 292 | ||
295 | /* Set up the base page */ | 293 | /* Set up the base page */ |
296 | reg = ADVERTISE_CSMA; | 294 | reg = ADVERTISE_CSMA | ADVERTISE_RESV; |
297 | if (efx->link_advertising & ADVERTISED_10baseT_Half) | ||
298 | reg |= ADVERTISE_10HALF; | ||
299 | if (efx->link_advertising & ADVERTISED_10baseT_Full) | ||
300 | reg |= ADVERTISE_10FULL; | ||
301 | if (efx->link_advertising & ADVERTISED_100baseT_Half) | ||
302 | reg |= ADVERTISE_100HALF; | ||
303 | if (efx->link_advertising & ADVERTISED_100baseT_Full) | ||
304 | reg |= ADVERTISE_100FULL; | ||
305 | if (xnp) | ||
306 | reg |= ADVERTISE_RESV; | ||
307 | else if (efx->link_advertising & (ADVERTISED_1000baseT_Half | | ||
308 | ADVERTISED_1000baseT_Full)) | ||
309 | reg |= ADVERTISE_NPAGE; | ||
310 | if (efx->link_advertising & ADVERTISED_Pause) | 295 | if (efx->link_advertising & ADVERTISED_Pause) |
311 | reg |= ADVERTISE_PAUSE_CAP; | 296 | reg |= ADVERTISE_PAUSE_CAP; |
312 | if (efx->link_advertising & ADVERTISED_Asym_Pause) | 297 | if (efx->link_advertising & ADVERTISED_Asym_Pause) |
313 | reg |= ADVERTISE_PAUSE_ASYM; | 298 | reg |= ADVERTISE_PAUSE_ASYM; |
314 | efx_mdio_write(efx, MDIO_MMD_AN, MDIO_AN_ADVERTISE, reg); | 299 | efx_mdio_write(efx, MDIO_MMD_AN, MDIO_AN_ADVERTISE, reg); |
315 | 300 | ||
316 | /* Set up the (extended) next page if necessary */ | 301 | /* Set up the (extended) next page */ |
317 | if (efx->phy_op->set_npage_adv) | 302 | efx->phy_op->set_npage_adv(efx, efx->link_advertising); |
318 | efx->phy_op->set_npage_adv(efx, efx->link_advertising); | ||
319 | 303 | ||
320 | /* Enable and restart AN */ | 304 | /* Enable and restart AN */ |
321 | reg = efx_mdio_read(efx, MDIO_MMD_AN, MDIO_CTRL1); | 305 | reg = efx_mdio_read(efx, MDIO_MMD_AN, MDIO_CTRL1); |
322 | reg |= MDIO_AN_CTRL1_ENABLE; | 306 | reg |= MDIO_AN_CTRL1_ENABLE | MDIO_AN_CTRL1_RESTART | MDIO_AN_CTRL1_XNP; |
323 | if (!(EFX_WORKAROUND_15195(efx) && LOOPBACK_EXTERNAL(efx))) | ||
324 | reg |= MDIO_AN_CTRL1_RESTART; | ||
325 | if (xnp) | ||
326 | reg |= MDIO_AN_CTRL1_XNP; | ||
327 | else | ||
328 | reg &= ~MDIO_AN_CTRL1_XNP; | ||
329 | efx_mdio_write(efx, MDIO_MMD_AN, MDIO_CTRL1, reg); | 307 | efx_mdio_write(efx, MDIO_MMD_AN, MDIO_CTRL1, reg); |
330 | } | 308 | } |
331 | 309 | ||