diff options
| -rw-r--r-- | drivers/net/e1000e/ethtool.c | 9 | ||||
| -rw-r--r-- | drivers/net/e1000e/netdev.c | 16 |
2 files changed, 18 insertions, 7 deletions
diff --git a/drivers/net/e1000e/ethtool.c b/drivers/net/e1000e/ethtool.c index 6ff376cfe139..2c521218102b 100644 --- a/drivers/net/e1000e/ethtool.c +++ b/drivers/net/e1000e/ethtool.c | |||
| @@ -1737,6 +1737,12 @@ static void e1000_diag_test(struct net_device *netdev, | |||
| 1737 | if (if_running) | 1737 | if (if_running) |
| 1738 | dev_open(netdev); | 1738 | dev_open(netdev); |
| 1739 | } else { | 1739 | } else { |
| 1740 | if (!if_running && (adapter->flags & FLAG_HAS_AMT)) { | ||
| 1741 | clear_bit(__E1000_TESTING, &adapter->state); | ||
| 1742 | dev_open(netdev); | ||
| 1743 | set_bit(__E1000_TESTING, &adapter->state); | ||
| 1744 | } | ||
| 1745 | |||
| 1740 | e_info("online testing starting\n"); | 1746 | e_info("online testing starting\n"); |
| 1741 | /* Online tests */ | 1747 | /* Online tests */ |
| 1742 | if (e1000_link_test(adapter, &data[4])) | 1748 | if (e1000_link_test(adapter, &data[4])) |
| @@ -1748,6 +1754,9 @@ static void e1000_diag_test(struct net_device *netdev, | |||
| 1748 | data[2] = 0; | 1754 | data[2] = 0; |
| 1749 | data[3] = 0; | 1755 | data[3] = 0; |
| 1750 | 1756 | ||
| 1757 | if (!if_running && (adapter->flags & FLAG_HAS_AMT)) | ||
| 1758 | dev_close(netdev); | ||
| 1759 | |||
| 1751 | clear_bit(__E1000_TESTING, &adapter->state); | 1760 | clear_bit(__E1000_TESTING, &adapter->state); |
| 1752 | } | 1761 | } |
| 1753 | msleep_interruptible(4 * 1000); | 1762 | msleep_interruptible(4 * 1000); |
diff --git a/drivers/net/e1000e/netdev.c b/drivers/net/e1000e/netdev.c index c5f65a29865a..ab79bec082f0 100644 --- a/drivers/net/e1000e/netdev.c +++ b/drivers/net/e1000e/netdev.c | |||
| @@ -3444,6 +3444,15 @@ static int e1000_open(struct net_device *netdev) | |||
| 3444 | if (err) | 3444 | if (err) |
| 3445 | goto err_setup_rx; | 3445 | goto err_setup_rx; |
| 3446 | 3446 | ||
| 3447 | /* | ||
| 3448 | * If AMT is enabled, let the firmware know that the network | ||
| 3449 | * interface is now open and reset the part to a known state. | ||
| 3450 | */ | ||
| 3451 | if (adapter->flags & FLAG_HAS_AMT) { | ||
| 3452 | e1000_get_hw_control(adapter); | ||
| 3453 | e1000e_reset(adapter); | ||
| 3454 | } | ||
| 3455 | |||
| 3447 | e1000e_power_up_phy(adapter); | 3456 | e1000e_power_up_phy(adapter); |
| 3448 | 3457 | ||
| 3449 | adapter->mng_vlan_id = E1000_MNG_VLAN_NONE; | 3458 | adapter->mng_vlan_id = E1000_MNG_VLAN_NONE; |
| @@ -3452,13 +3461,6 @@ static int e1000_open(struct net_device *netdev) | |||
| 3452 | e1000_update_mng_vlan(adapter); | 3461 | e1000_update_mng_vlan(adapter); |
| 3453 | 3462 | ||
| 3454 | /* | 3463 | /* |
| 3455 | * If AMT is enabled, let the firmware know that the network | ||
| 3456 | * interface is now open | ||
| 3457 | */ | ||
| 3458 | if (adapter->flags & FLAG_HAS_AMT) | ||
| 3459 | e1000_get_hw_control(adapter); | ||
| 3460 | |||
| 3461 | /* | ||
| 3462 | * before we allocate an interrupt, we must be ready to handle it. | 3464 | * before we allocate an interrupt, we must be ready to handle it. |
| 3463 | * Setting DEBUG_SHIRQ in the kernel makes it fire an interrupt | 3465 | * Setting DEBUG_SHIRQ in the kernel makes it fire an interrupt |
| 3464 | * as soon as we call pci_request_irq, so we have to setup our | 3466 | * as soon as we call pci_request_irq, so we have to setup our |
