e1000e: Fix EEE in Sx implementation
authorRaanan Avargil <raanan.avargil@intel.com>
Mon, 6 Jul 2015 13:48:00 +0000 (16:48 +0300)
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>
Wed, 5 Aug 2015 23:53:47 +0000 (16:53 -0700)
This patch implements the EEE in Sx code so that it only applies to parts
that support EEE in Sx (as opposed to all parts that support EEE).
It also uses the existing eee_advert and eee_lp_abiliity to set just the
bits (100/1000) that should be set.

Signed-off-by: Raanan Avargil <raanan.avargil@intel.com>
Tested-by: Aaron Brown <aaron.f.brown@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
drivers/net/ethernet/intel/e1000e/netdev.c

index fea1601f32a3614122a75e03fd98e786cab2ac2a..b32bc4848ae32aa08c6b37dae1e98b452984478c 100644 (file)
@@ -6317,6 +6317,33 @@ static int __e1000_shutdown(struct pci_dev *pdev, bool runtime)
                        return retval;
        }
 
+       /* Ensure that the appropriate bits are set in LPI_CTRL
+        * for EEE in Sx
+        */
+       if ((hw->phy.type >= e1000_phy_i217) &&
+           adapter->eee_advert && hw->dev_spec.ich8lan.eee_lp_ability) {
+               u16 lpi_ctrl = 0;
+
+               retval = hw->phy.ops.acquire(hw);
+               if (!retval) {
+                       retval = e1e_rphy_locked(hw, I82579_LPI_CTRL,
+                                                &lpi_ctrl);
+                       if (!retval) {
+                               if (adapter->eee_advert &
+                                   hw->dev_spec.ich8lan.eee_lp_ability &
+                                   I82579_EEE_100_SUPPORTED)
+                                       lpi_ctrl |= I82579_LPI_CTRL_100_ENABLE;
+                               if (adapter->eee_advert &
+                                   hw->dev_spec.ich8lan.eee_lp_ability &
+                                   I82579_EEE_1000_SUPPORTED)
+                                       lpi_ctrl |= I82579_LPI_CTRL_1000_ENABLE;
+
+                               retval = e1e_wphy_locked(hw, I82579_LPI_CTRL,
+                                                        lpi_ctrl);
+                       }
+               }
+               hw->phy.ops.release(hw);
+       }
 
        /* Release control of h/w to f/w.  If f/w is AMT enabled, this
         * would have already happened in close and is redundant.