|
@@ -3220,7 +3220,11 @@ int e1000e_up(struct e1000_adapter *adapter)
|
|
|
netif_wake_queue(adapter->netdev);
|
|
|
|
|
|
/* fire a link change interrupt to start the watchdog */
|
|
|
- ew32(ICS, E1000_ICS_LSC);
|
|
|
+ if (adapter->msix_entries)
|
|
|
+ ew32(ICS, E1000_ICS_LSC | E1000_ICR_OTHER);
|
|
|
+ else
|
|
|
+ ew32(ICS, E1000_ICS_LSC);
|
|
|
+
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
@@ -3537,7 +3541,10 @@ static int e1000_open(struct net_device *netdev)
|
|
|
pm_runtime_put(&pdev->dev);
|
|
|
|
|
|
/* fire a link status change interrupt to start the watchdog */
|
|
|
- ew32(ICS, E1000_ICS_LSC);
|
|
|
+ if (adapter->msix_entries)
|
|
|
+ ew32(ICS, E1000_ICS_LSC | E1000_ICR_OTHER);
|
|
|
+ else
|
|
|
+ ew32(ICS, E1000_ICS_LSC);
|
|
|
|
|
|
return 0;
|
|
|
|