aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/e1000
diff options
context:
space:
mode:
authorBruce Allan <bruce.w.allan@intel.com>2006-09-27 15:53:54 -0400
committerAuke Kok <juke-jan.h.kok@intel.com>2006-09-27 15:53:54 -0400
commit61c2505fd5044d9e108acc6b469d3caa02522043 (patch)
treed9dda9a38eb72df8c55f02dfccfbd120a3d05a75 /drivers/net/e1000
parent09ae3e88662478c014617291e5a2115e6b2f65eb (diff)
e1000: handle manageability for pci-e adapters at PHY powerdown
When powering down the PHY (if WoL is disabled) we should only check copper PHY's and handle PCI-E adapters differently. Signed-off-by: Bruce Allan <bruce.w.allan@intel.com> Signed-off-by: Auke Kok <auke-jan.h.kok@intel.com>
Diffstat (limited to 'drivers/net/e1000')
-rw-r--r--drivers/net/e1000/e1000_main.c41
1 files changed, 32 insertions, 9 deletions
diff --git a/drivers/net/e1000/e1000_main.c b/drivers/net/e1000/e1000_main.c
index aaadb2bb0763..fd30161d2f12 100644
--- a/drivers/net/e1000/e1000_main.c
+++ b/drivers/net/e1000/e1000_main.c
@@ -512,25 +512,48 @@ void e1000_power_up_phy(struct e1000_adapter *adapter)
512 512
513static void e1000_power_down_phy(struct e1000_adapter *adapter) 513static void e1000_power_down_phy(struct e1000_adapter *adapter)
514{ 514{
515 boolean_t mng_mode_enabled = (adapter->hw.mac_type >= e1000_82571) && 515 /* Power down the PHY so no link is implied when interface is down *
516 e1000_check_mng_mode(&adapter->hw); 516 * The PHY cannot be powered down if any of the following is TRUE *
517 /* Power down the PHY so no link is implied when interface is down
518 * The PHY cannot be powered down if any of the following is TRUE
519 * (a) WoL is enabled 517 * (a) WoL is enabled
520 * (b) AMT is active 518 * (b) AMT is active
521 * (c) SoL/IDER session is active */ 519 * (c) SoL/IDER session is active */
522 if (!adapter->wol && adapter->hw.mac_type >= e1000_82540 && 520 if (!adapter->wol && adapter->hw.mac_type >= e1000_82540 &&
523 adapter->hw.mac_type != e1000_ich8lan && 521 adapter->hw.media_type == e1000_media_type_copper) {
524 adapter->hw.media_type == e1000_media_type_copper &&
525 !(E1000_READ_REG(&adapter->hw, MANC) & E1000_MANC_SMBUS_EN) &&
526 !mng_mode_enabled &&
527 !e1000_check_phy_reset_block(&adapter->hw)) {
528 uint16_t mii_reg = 0; 522 uint16_t mii_reg = 0;
523
524 switch (adapter->hw.mac_type) {
525 case e1000_82540:
526 case e1000_82545:
527 case e1000_82545_rev_3:
528 case e1000_82546:
529 case e1000_82546_rev_3:
530 case e1000_82541:
531 case e1000_82541_rev_2:
532 case e1000_82547:
533 case e1000_82547_rev_2:
534 if (E1000_READ_REG(&adapter->hw, MANC) &
535 E1000_MANC_SMBUS_EN)
536 goto out;
537 break;
538 case e1000_82571:
539 case e1000_82572:
540 case e1000_82573:
541 case e1000_80003es2lan:
542 case e1000_ich8lan:
543 if (e1000_check_mng_mode(&adapter->hw) ||
544 e1000_check_phy_reset_block(&adapter->hw))
545 goto out;
546 break;
547 default:
548 goto out;
549 }
529 e1000_read_phy_reg(&adapter->hw, PHY_CTRL, &mii_reg); 550 e1000_read_phy_reg(&adapter->hw, PHY_CTRL, &mii_reg);
530 mii_reg |= MII_CR_POWER_DOWN; 551 mii_reg |= MII_CR_POWER_DOWN;
531 e1000_write_phy_reg(&adapter->hw, PHY_CTRL, mii_reg); 552 e1000_write_phy_reg(&adapter->hw, PHY_CTRL, mii_reg);
532 mdelay(1); 553 mdelay(1);
533 } 554 }
555out:
556 return;
534} 557}
535 558
536void 559void