mirror of
https://github.com/adulau/aha.git
synced 2024-12-31 21:26:18 +00:00
e1000e: WoL does not work on 82577/82578 with manageability enabled
With manageability (Intel AMT) enabled via BIOS, PHY wakeup does not get configured on newer parts which use PHY wakeup vs. MAC wakeup which causes WoL to not work. The driver should configure PHY wakeup whether or not manageability is enabled. Signed-off-by: Bruce Allan <bruce.w.allan@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
7fc1ece407
commit
82776a4bcd
1 changed files with 3 additions and 3 deletions
|
@ -4538,8 +4538,7 @@ static int __e1000_shutdown(struct pci_dev *pdev, bool *enable_wake)
|
||||||
/* Allow time for pending master requests to run */
|
/* Allow time for pending master requests to run */
|
||||||
e1000e_disable_pcie_master(&adapter->hw);
|
e1000e_disable_pcie_master(&adapter->hw);
|
||||||
|
|
||||||
if ((adapter->flags2 & FLAG2_HAS_PHY_WAKEUP) &&
|
if (adapter->flags2 & FLAG2_HAS_PHY_WAKEUP) {
|
||||||
!(hw->mac.ops.check_mng_mode(hw))) {
|
|
||||||
/* enable wakeup by the PHY */
|
/* enable wakeup by the PHY */
|
||||||
retval = e1000_init_phy_wakeup(adapter, wufc);
|
retval = e1000_init_phy_wakeup(adapter, wufc);
|
||||||
if (retval)
|
if (retval)
|
||||||
|
@ -4557,7 +4556,8 @@ static int __e1000_shutdown(struct pci_dev *pdev, bool *enable_wake)
|
||||||
*enable_wake = !!wufc;
|
*enable_wake = !!wufc;
|
||||||
|
|
||||||
/* make sure adapter isn't asleep if manageability is enabled */
|
/* make sure adapter isn't asleep if manageability is enabled */
|
||||||
if (adapter->flags & FLAG_MNG_PT_ENABLED)
|
if ((adapter->flags & FLAG_MNG_PT_ENABLED) ||
|
||||||
|
(hw->mac.ops.check_mng_mode(hw)))
|
||||||
*enable_wake = true;
|
*enable_wake = true;
|
||||||
|
|
||||||
if (adapter->hw.phy.type == e1000_phy_igp_3)
|
if (adapter->hw.phy.type == e1000_phy_igp_3)
|
||||||
|
|
Loading…
Reference in a new issue