diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-12-09 01:14:38 -0500 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-12-09 01:14:38 -0500 |
commit | bcd6acd51f3d4d1ada201e9bc5c40a31d6d80c71 (patch) | |
tree | 2f6dffd2d3e4dd67355a224de7e7a960335a92fd /drivers/net/mdio.c | |
parent | 11c34c7deaeeebcee342cbc35e1bb2a6711b2431 (diff) | |
parent | 3ff6a468b45b5dfeb0e903e56f4eb27d34b2437c (diff) |
Merge commit 'origin/master' into next
Conflicts:
include/linux/kvm.h
Diffstat (limited to 'drivers/net/mdio.c')
-rw-r--r-- | drivers/net/mdio.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/net/mdio.c b/drivers/net/mdio.c index 21f8754fcf4c..e85bf04cf813 100644 --- a/drivers/net/mdio.c +++ b/drivers/net/mdio.c | |||
@@ -162,6 +162,10 @@ static u32 mdio45_get_an(const struct mdio_if_info *mdio, u16 addr) | |||
162 | result |= ADVERTISED_100baseT_Half; | 162 | result |= ADVERTISED_100baseT_Half; |
163 | if (reg & ADVERTISE_100FULL) | 163 | if (reg & ADVERTISE_100FULL) |
164 | result |= ADVERTISED_100baseT_Full; | 164 | result |= ADVERTISED_100baseT_Full; |
165 | if (reg & ADVERTISE_PAUSE_CAP) | ||
166 | result |= ADVERTISED_Pause; | ||
167 | if (reg & ADVERTISE_PAUSE_ASYM) | ||
168 | result |= ADVERTISED_Asym_Pause; | ||
165 | return result; | 169 | return result; |
166 | } | 170 | } |
167 | 171 | ||
@@ -344,11 +348,9 @@ void mdio45_ethtool_spauseparam_an(const struct mdio_if_info *mdio, | |||
344 | 348 | ||
345 | old_adv = mdio->mdio_read(mdio->dev, mdio->prtad, MDIO_MMD_AN, | 349 | old_adv = mdio->mdio_read(mdio->dev, mdio->prtad, MDIO_MMD_AN, |
346 | MDIO_AN_ADVERTISE); | 350 | MDIO_AN_ADVERTISE); |
347 | adv = old_adv & ~(ADVERTISE_PAUSE_CAP | ADVERTISE_PAUSE_ASYM); | 351 | adv = ((old_adv & ~(ADVERTISE_PAUSE_CAP | ADVERTISE_PAUSE_ASYM)) | |
348 | if (ecmd->autoneg) | 352 | mii_advertise_flowctrl((ecmd->rx_pause ? FLOW_CTRL_RX : 0) | |
349 | adv |= mii_advertise_flowctrl( | 353 | (ecmd->tx_pause ? FLOW_CTRL_TX : 0))); |
350 | (ecmd->rx_pause ? FLOW_CTRL_RX : 0) | | ||
351 | (ecmd->tx_pause ? FLOW_CTRL_TX : 0)); | ||
352 | if (adv != old_adv) { | 354 | if (adv != old_adv) { |
353 | mdio->mdio_write(mdio->dev, mdio->prtad, MDIO_MMD_AN, | 355 | mdio->mdio_write(mdio->dev, mdio->prtad, MDIO_MMD_AN, |
354 | MDIO_AN_ADVERTISE, adv); | 356 | MDIO_AN_ADVERTISE, adv); |