aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/ethernet/intel/e1000e/defines.h10
-rw-r--r--drivers/net/ethernet/intel/e1000e/e1000.h2
-rw-r--r--drivers/net/ethernet/intel/e1000e/ethtool.c1
-rw-r--r--drivers/net/ethernet/intel/e1000e/hw.h4
-rw-r--r--drivers/net/ethernet/intel/e1000e/ich8lan.c213
-rw-r--r--drivers/net/ethernet/intel/e1000e/mac.c125
-rw-r--r--drivers/net/ethernet/intel/e1000e/netdev.c66
-rw-r--r--drivers/net/ethernet/intel/e1000e/nvm.c26
-rw-r--r--drivers/net/ethernet/intel/e1000e/param.c3
9 files changed, 339 insertions, 111 deletions
diff --git a/drivers/net/ethernet/intel/e1000e/defines.h b/drivers/net/ethernet/intel/e1000e/defines.h
index 02a12b69555f..7326ea2fef8f 100644
--- a/drivers/net/ethernet/intel/e1000e/defines.h
+++ b/drivers/net/ethernet/intel/e1000e/defines.h
@@ -241,9 +241,9 @@
241#define E1000_CTRL_VME 0x40000000 /* IEEE VLAN mode enable */ 241#define E1000_CTRL_VME 0x40000000 /* IEEE VLAN mode enable */
242#define E1000_CTRL_PHY_RST 0x80000000 /* PHY Reset */ 242#define E1000_CTRL_PHY_RST 0x80000000 /* PHY Reset */
243 243
244/* Bit definitions for the Management Data IO (MDIO) and Management Data 244#define E1000_PCS_LCTL_FORCE_FCTRL 0x80
245 * Clock (MDC) pins in the Device Control Register. 245
246 */ 246#define E1000_PCS_LSTS_AN_COMPLETE 0x10000
247 247
248/* Device Status */ 248/* Device Status */
249#define E1000_STATUS_FD 0x00000001 /* Full duplex.0=half,1=full */ 249#define E1000_STATUS_FD 0x00000001 /* Full duplex.0=half,1=full */
@@ -639,6 +639,10 @@
639/* NVM Word Offsets */ 639/* NVM Word Offsets */
640#define NVM_COMPAT 0x0003 640#define NVM_COMPAT 0x0003
641#define NVM_ID_LED_SETTINGS 0x0004 641#define NVM_ID_LED_SETTINGS 0x0004
642#define NVM_FUTURE_INIT_WORD1 0x0019
643#define NVM_COMPAT_VALID_CSUM 0x0001
644#define NVM_FUTURE_INIT_WORD1_VALID_CSUM 0x0040
645
642#define NVM_INIT_CONTROL2_REG 0x000F 646#define NVM_INIT_CONTROL2_REG 0x000F
643#define NVM_INIT_CONTROL3_PORT_B 0x0014 647#define NVM_INIT_CONTROL3_PORT_B 0x0014
644#define NVM_INIT_3GIO_3 0x001A 648#define NVM_INIT_3GIO_3 0x001A
diff --git a/drivers/net/ethernet/intel/e1000e/e1000.h b/drivers/net/ethernet/intel/e1000e/e1000.h
index 6782a2eea1bc..3f8bbc31795c 100644
--- a/drivers/net/ethernet/intel/e1000e/e1000.h
+++ b/drivers/net/ethernet/intel/e1000e/e1000.h
@@ -447,7 +447,7 @@ struct e1000_info {
447#define FLAG_MSI_ENABLED (1 << 27) 447#define FLAG_MSI_ENABLED (1 << 27)
448/* reserved (1 << 28) */ 448/* reserved (1 << 28) */
449#define FLAG_TSO_FORCE (1 << 29) 449#define FLAG_TSO_FORCE (1 << 29)
450#define FLAG_RX_RESTART_NOW (1 << 30) 450#define FLAG_RESTART_NOW (1 << 30)
451#define FLAG_MSI_TEST_FAILED (1 << 31) 451#define FLAG_MSI_TEST_FAILED (1 << 31)
452 452
453#define FLAG2_CRC_STRIPPING (1 << 0) 453#define FLAG2_CRC_STRIPPING (1 << 0)
diff --git a/drivers/net/ethernet/intel/e1000e/ethtool.c b/drivers/net/ethernet/intel/e1000e/ethtool.c
index f95bc6ee1c22..2225603a8a28 100644
--- a/drivers/net/ethernet/intel/e1000e/ethtool.c
+++ b/drivers/net/ethernet/intel/e1000e/ethtool.c
@@ -98,7 +98,6 @@ static const struct e1000_stats e1000_gstrings_stats[] = {
98 E1000_STAT("rx_flow_control_xoff", stats.xoffrxc), 98 E1000_STAT("rx_flow_control_xoff", stats.xoffrxc),
99 E1000_STAT("tx_flow_control_xon", stats.xontxc), 99 E1000_STAT("tx_flow_control_xon", stats.xontxc),
100 E1000_STAT("tx_flow_control_xoff", stats.xofftxc), 100 E1000_STAT("tx_flow_control_xoff", stats.xofftxc),
101 E1000_STAT("rx_long_byte_count", stats.gorc),
102 E1000_STAT("rx_csum_offload_good", hw_csum_good), 101 E1000_STAT("rx_csum_offload_good", hw_csum_good),
103 E1000_STAT("rx_csum_offload_errors", hw_csum_err), 102 E1000_STAT("rx_csum_offload_errors", hw_csum_err),
104 E1000_STAT("rx_header_split", rx_hdr_split), 103 E1000_STAT("rx_header_split", rx_hdr_split),
diff --git a/drivers/net/ethernet/intel/e1000e/hw.h b/drivers/net/ethernet/intel/e1000e/hw.h
index cf217777586c..06239fe47db1 100644
--- a/drivers/net/ethernet/intel/e1000e/hw.h
+++ b/drivers/net/ethernet/intel/e1000e/hw.h
@@ -191,6 +191,10 @@ enum e1e_registers {
191 E1000_ICTXQMTC = 0x0411C, /* Irq Cause Tx Queue MinThreshold Count */ 191 E1000_ICTXQMTC = 0x0411C, /* Irq Cause Tx Queue MinThreshold Count */
192 E1000_ICRXDMTC = 0x04120, /* Irq Cause Rx Desc MinThreshold Count */ 192 E1000_ICRXDMTC = 0x04120, /* Irq Cause Rx Desc MinThreshold Count */
193 E1000_ICRXOC = 0x04124, /* Irq Cause Receiver Overrun Count */ 193 E1000_ICRXOC = 0x04124, /* Irq Cause Receiver Overrun Count */
194 E1000_PCS_LCTL = 0x04208, /* PCS Link Control - RW */
195 E1000_PCS_LSTAT = 0x0420C, /* PCS Link Status - RO */
196 E1000_PCS_ANADV = 0x04218, /* AN advertisement - RW */
197 E1000_PCS_LPAB = 0x0421C, /* Link Partner Ability - RW */
194 E1000_RXCSUM = 0x05000, /* Rx Checksum Control - RW */ 198 E1000_RXCSUM = 0x05000, /* Rx Checksum Control - RW */
195 E1000_RFCTL = 0x05008, /* Receive Filter Control */ 199 E1000_RFCTL = 0x05008, /* Receive Filter Control */
196 E1000_MTA = 0x05200, /* Multicast Table Array - RW Array */ 200 E1000_MTA = 0x05200, /* Multicast Table Array - RW Array */
diff --git a/drivers/net/ethernet/intel/e1000e/ich8lan.c b/drivers/net/ethernet/intel/e1000e/ich8lan.c
index 976336547607..051dfda75fc0 100644
--- a/drivers/net/ethernet/intel/e1000e/ich8lan.c
+++ b/drivers/net/ethernet/intel/e1000e/ich8lan.c
@@ -150,18 +150,25 @@
150 150
151/* PHY Low Power Idle Control */ 151/* PHY Low Power Idle Control */
152#define I82579_LPI_CTRL PHY_REG(772, 20) 152#define I82579_LPI_CTRL PHY_REG(772, 20)
153#define I82579_LPI_CTRL_100_ENABLE 0x2000
154#define I82579_LPI_CTRL_1000_ENABLE 0x4000
153#define I82579_LPI_CTRL_ENABLE_MASK 0x6000 155#define I82579_LPI_CTRL_ENABLE_MASK 0x6000
154#define I82579_LPI_CTRL_FORCE_PLL_LOCK_COUNT 0x80 156#define I82579_LPI_CTRL_FORCE_PLL_LOCK_COUNT 0x80
155 157
156/* EMI Registers */ 158/* Extended Management Interface (EMI) Registers */
157#define I82579_EMI_ADDR 0x10 159#define I82579_EMI_ADDR 0x10
158#define I82579_EMI_DATA 0x11 160#define I82579_EMI_DATA 0x11
159#define I82579_LPI_UPDATE_TIMER 0x4805 /* in 40ns units + 40 ns base value */ 161#define I82579_LPI_UPDATE_TIMER 0x4805 /* in 40ns units + 40 ns base value */
160#define I82579_MSE_THRESHOLD 0x084F /* Mean Square Error Threshold */ 162#define I82579_MSE_THRESHOLD 0x084F /* 82579 Mean Square Error Threshold */
163#define I82577_MSE_THRESHOLD 0x0887 /* 82577 Mean Square Error Threshold */
161#define I82579_MSE_LINK_DOWN 0x2411 /* MSE count before dropping link */ 164#define I82579_MSE_LINK_DOWN 0x2411 /* MSE count before dropping link */
165#define I82579_EEE_PCS_STATUS 0x182D /* IEEE MMD Register 3.1 >> 8 */
166#define I82579_EEE_LP_ABILITY 0x040F /* IEEE MMD Register 7.61 */
167#define I82579_EEE_100_SUPPORTED (1 << 1) /* 100BaseTx EEE supported */
168#define I82579_EEE_1000_SUPPORTED (1 << 2) /* 1000BaseTx EEE supported */
169#define I217_EEE_PCS_STATUS 0x9401 /* IEEE MMD Register 3.1 */
162#define I217_EEE_ADVERTISEMENT 0x8001 /* IEEE MMD Register 7.60 */ 170#define I217_EEE_ADVERTISEMENT 0x8001 /* IEEE MMD Register 7.60 */
163#define I217_EEE_LP_ABILITY 0x8002 /* IEEE MMD Register 7.61 */ 171#define I217_EEE_LP_ABILITY 0x8002 /* IEEE MMD Register 7.61 */
164#define I217_EEE_100_SUPPORTED (1 << 1) /* 100BaseTx EEE supported */
165 172
166/* Intel Rapid Start Technology Support */ 173/* Intel Rapid Start Technology Support */
167#define I217_PROXY_CTRL BM_PHY_REG(BM_WUC_PAGE, 70) 174#define I217_PROXY_CTRL BM_PHY_REG(BM_WUC_PAGE, 70)
@@ -789,57 +796,139 @@ static s32 e1000_init_mac_params_ich8lan(struct e1000_hw *hw)
789} 796}
790 797
791/** 798/**
799 * __e1000_access_emi_reg_locked - Read/write EMI register
800 * @hw: pointer to the HW structure
801 * @addr: EMI address to program
802 * @data: pointer to value to read/write from/to the EMI address
803 * @read: boolean flag to indicate read or write
804 *
805 * This helper function assumes the SW/FW/HW Semaphore is already acquired.
806 **/
807static s32 __e1000_access_emi_reg_locked(struct e1000_hw *hw, u16 address,
808 u16 *data, bool read)
809{
810 s32 ret_val = 0;
811
812 ret_val = e1e_wphy_locked(hw, I82579_EMI_ADDR, address);
813 if (ret_val)
814 return ret_val;
815
816 if (read)
817 ret_val = e1e_rphy_locked(hw, I82579_EMI_DATA, data);
818 else
819 ret_val = e1e_wphy_locked(hw, I82579_EMI_DATA, *data);
820
821 return ret_val;
822}
823
824/**
825 * e1000_read_emi_reg_locked - Read Extended Management Interface register
826 * @hw: pointer to the HW structure
827 * @addr: EMI address to program
828 * @data: value to be read from the EMI address
829 *
830 * Assumes the SW/FW/HW Semaphore is already acquired.
831 **/
832static s32 e1000_read_emi_reg_locked(struct e1000_hw *hw, u16 addr, u16 *data)
833{
834 return __e1000_access_emi_reg_locked(hw, addr, data, true);
835}
836
837/**
838 * e1000_write_emi_reg_locked - Write Extended Management Interface register
839 * @hw: pointer to the HW structure
840 * @addr: EMI address to program
841 * @data: value to be written to the EMI address
842 *
843 * Assumes the SW/FW/HW Semaphore is already acquired.
844 **/
845static s32 e1000_write_emi_reg_locked(struct e1000_hw *hw, u16 addr, u16 data)
846{
847 return __e1000_access_emi_reg_locked(hw, addr, &data, false);
848}
849
850/**
792 * e1000_set_eee_pchlan - Enable/disable EEE support 851 * e1000_set_eee_pchlan - Enable/disable EEE support
793 * @hw: pointer to the HW structure 852 * @hw: pointer to the HW structure
794 * 853 *
795 * Enable/disable EEE based on setting in dev_spec structure. The bits in 854 * Enable/disable EEE based on setting in dev_spec structure, the duplex of
796 * the LPI Control register will remain set only if/when link is up. 855 * the link and the EEE capabilities of the link partner. The LPI Control
856 * register bits will remain set only if/when link is up.
797 **/ 857 **/
798static s32 e1000_set_eee_pchlan(struct e1000_hw *hw) 858static s32 e1000_set_eee_pchlan(struct e1000_hw *hw)
799{ 859{
800 struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan; 860 struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan;
801 s32 ret_val = 0; 861 s32 ret_val;
802 u16 phy_reg; 862 u16 lpi_ctrl;
803 863
804 if ((hw->phy.type != e1000_phy_82579) && 864 if ((hw->phy.type != e1000_phy_82579) &&
805 (hw->phy.type != e1000_phy_i217)) 865 (hw->phy.type != e1000_phy_i217))
806 return 0; 866 return 0;
807 867
808 ret_val = e1e_rphy(hw, I82579_LPI_CTRL, &phy_reg); 868 ret_val = hw->phy.ops.acquire(hw);
809 if (ret_val) 869 if (ret_val)
810 return ret_val; 870 return ret_val;
811 871
812 if (dev_spec->eee_disable) 872 ret_val = e1e_rphy_locked(hw, I82579_LPI_CTRL, &lpi_ctrl);
813 phy_reg &= ~I82579_LPI_CTRL_ENABLE_MASK;
814 else
815 phy_reg |= I82579_LPI_CTRL_ENABLE_MASK;
816
817 ret_val = e1e_wphy(hw, I82579_LPI_CTRL, phy_reg);
818 if (ret_val) 873 if (ret_val)
819 return ret_val; 874 goto release;
875
876 /* Clear bits that enable EEE in various speeds */
877 lpi_ctrl &= ~I82579_LPI_CTRL_ENABLE_MASK;
878
879 /* Enable EEE if not disabled by user */
880 if (!dev_spec->eee_disable) {
881 u16 lpa, pcs_status, data;
820 882
821 if ((hw->phy.type == e1000_phy_i217) && !dev_spec->eee_disable) {
822 /* Save off link partner's EEE ability */ 883 /* Save off link partner's EEE ability */
823 ret_val = hw->phy.ops.acquire(hw); 884 switch (hw->phy.type) {
824 if (ret_val) 885 case e1000_phy_82579:
825 return ret_val; 886 lpa = I82579_EEE_LP_ABILITY;
826 ret_val = e1e_wphy_locked(hw, I82579_EMI_ADDR, 887 pcs_status = I82579_EEE_PCS_STATUS;
827 I217_EEE_LP_ABILITY); 888 break;
889 case e1000_phy_i217:
890 lpa = I217_EEE_LP_ABILITY;
891 pcs_status = I217_EEE_PCS_STATUS;
892 break;
893 default:
894 ret_val = -E1000_ERR_PHY;
895 goto release;
896 }
897 ret_val = e1000_read_emi_reg_locked(hw, lpa,
898 &dev_spec->eee_lp_ability);
828 if (ret_val) 899 if (ret_val)
829 goto release; 900 goto release;
830 e1e_rphy_locked(hw, I82579_EMI_DATA, &dev_spec->eee_lp_ability);
831 901
832 /* EEE is not supported in 100Half, so ignore partner's EEE 902 /* Enable EEE only for speeds in which the link partner is
833 * in 100 ability if full-duplex is not advertised. 903 * EEE capable.
834 */ 904 */
835 e1e_rphy_locked(hw, PHY_LP_ABILITY, &phy_reg); 905 if (dev_spec->eee_lp_ability & I82579_EEE_1000_SUPPORTED)
836 if (!(phy_reg & NWAY_LPAR_100TX_FD_CAPS)) 906 lpi_ctrl |= I82579_LPI_CTRL_1000_ENABLE;
837 dev_spec->eee_lp_ability &= ~I217_EEE_100_SUPPORTED; 907
838release: 908 if (dev_spec->eee_lp_ability & I82579_EEE_100_SUPPORTED) {
839 hw->phy.ops.release(hw); 909 e1e_rphy_locked(hw, PHY_LP_ABILITY, &data);
910 if (data & NWAY_LPAR_100TX_FD_CAPS)
911 lpi_ctrl |= I82579_LPI_CTRL_100_ENABLE;
912 else
913 /* EEE is not supported in 100Half, so ignore
914 * partner's EEE in 100 ability if full-duplex
915 * is not advertised.
916 */
917 dev_spec->eee_lp_ability &=
918 ~I82579_EEE_100_SUPPORTED;
919 }
920
921 /* R/Clr IEEE MMD 3.1 bits 11:10 - Tx/Rx LPI Received */
922 ret_val = e1000_read_emi_reg_locked(hw, pcs_status, &data);
923 if (ret_val)
924 goto release;
840 } 925 }
841 926
842 return 0; 927 ret_val = e1e_wphy_locked(hw, I82579_LPI_CTRL, lpi_ctrl);
928release:
929 hw->phy.ops.release(hw);
930
931 return ret_val;
843} 932}
844 933
845/** 934/**
@@ -1757,6 +1846,11 @@ static s32 e1000_hv_phy_workarounds_ich8lan(struct e1000_hw *hw)
1757 if (ret_val) 1846 if (ret_val)
1758 goto release; 1847 goto release;
1759 ret_val = e1e_wphy_locked(hw, BM_PORT_GEN_CFG, phy_data & 0x00FF); 1848 ret_val = e1e_wphy_locked(hw, BM_PORT_GEN_CFG, phy_data & 0x00FF);
1849 if (ret_val)
1850 goto release;
1851
1852 /* set MSE higher to enable link to stay up when noise is high */
1853 ret_val = e1000_write_emi_reg_locked(hw, I82577_MSE_THRESHOLD, 0x0034);
1760release: 1854release:
1761 hw->phy.ops.release(hw); 1855 hw->phy.ops.release(hw);
1762 1856
@@ -1983,22 +2077,18 @@ static s32 e1000_lv_phy_workarounds_ich8lan(struct e1000_hw *hw)
1983 2077
1984 /* Set MDIO slow mode before any other MDIO access */ 2078 /* Set MDIO slow mode before any other MDIO access */
1985 ret_val = e1000_set_mdio_slow_mode_hv(hw); 2079 ret_val = e1000_set_mdio_slow_mode_hv(hw);
2080 if (ret_val)
2081 return ret_val;
1986 2082
1987 ret_val = hw->phy.ops.acquire(hw); 2083 ret_val = hw->phy.ops.acquire(hw);
1988 if (ret_val) 2084 if (ret_val)
1989 return ret_val; 2085 return ret_val;
1990 ret_val = e1e_wphy_locked(hw, I82579_EMI_ADDR, I82579_MSE_THRESHOLD);
1991 if (ret_val)
1992 goto release;
1993 /* set MSE higher to enable link to stay up when noise is high */ 2086 /* set MSE higher to enable link to stay up when noise is high */
1994 ret_val = e1e_wphy_locked(hw, I82579_EMI_DATA, 0x0034); 2087 ret_val = e1000_write_emi_reg_locked(hw, I82579_MSE_THRESHOLD, 0x0034);
1995 if (ret_val)
1996 goto release;
1997 ret_val = e1e_wphy_locked(hw, I82579_EMI_ADDR, I82579_MSE_LINK_DOWN);
1998 if (ret_val) 2088 if (ret_val)
1999 goto release; 2089 goto release;
2000 /* drop link after 5 times MSE threshold was reached */ 2090 /* drop link after 5 times MSE threshold was reached */
2001 ret_val = e1e_wphy_locked(hw, I82579_EMI_DATA, 0x0005); 2091 ret_val = e1000_write_emi_reg_locked(hw, I82579_MSE_LINK_DOWN, 0x0005);
2002release: 2092release:
2003 hw->phy.ops.release(hw); 2093 hw->phy.ops.release(hw);
2004 2094
@@ -2172,10 +2262,9 @@ static s32 e1000_post_phy_reset_ich8lan(struct e1000_hw *hw)
2172 ret_val = hw->phy.ops.acquire(hw); 2262 ret_val = hw->phy.ops.acquire(hw);
2173 if (ret_val) 2263 if (ret_val)
2174 return ret_val; 2264 return ret_val;
2175 ret_val = e1e_wphy_locked(hw, I82579_EMI_ADDR, 2265 ret_val = e1000_write_emi_reg_locked(hw,
2176 I82579_LPI_UPDATE_TIMER); 2266 I82579_LPI_UPDATE_TIMER,
2177 if (!ret_val) 2267 0x1387);
2178 ret_val = e1e_wphy_locked(hw, I82579_EMI_DATA, 0x1387);
2179 hw->phy.ops.release(hw); 2268 hw->phy.ops.release(hw);
2180 } 2269 }
2181 2270
@@ -2949,19 +3038,32 @@ static s32 e1000_validate_nvm_checksum_ich8lan(struct e1000_hw *hw)
2949{ 3038{
2950 s32 ret_val; 3039 s32 ret_val;
2951 u16 data; 3040 u16 data;
3041 u16 word;
3042 u16 valid_csum_mask;
2952 3043
2953 /* Read 0x19 and check bit 6. If this bit is 0, the checksum 3044 /* Read NVM and check Invalid Image CSUM bit. If this bit is 0,
2954 * needs to be fixed. This bit is an indication that the NVM 3045 * the checksum needs to be fixed. This bit is an indication that
2955 * was prepared by OEM software and did not calculate the 3046 * the NVM was prepared by OEM software and did not calculate
2956 * checksum...a likely scenario. 3047 * the checksum...a likely scenario.
2957 */ 3048 */
2958 ret_val = e1000_read_nvm(hw, 0x19, 1, &data); 3049 switch (hw->mac.type) {
3050 case e1000_pch_lpt:
3051 word = NVM_COMPAT;
3052 valid_csum_mask = NVM_COMPAT_VALID_CSUM;
3053 break;
3054 default:
3055 word = NVM_FUTURE_INIT_WORD1;
3056 valid_csum_mask = NVM_FUTURE_INIT_WORD1_VALID_CSUM;
3057 break;
3058 }
3059
3060 ret_val = e1000_read_nvm(hw, word, 1, &data);
2959 if (ret_val) 3061 if (ret_val)
2960 return ret_val; 3062 return ret_val;
2961 3063
2962 if (!(data & 0x40)) { 3064 if (!(data & valid_csum_mask)) {
2963 data |= 0x40; 3065 data |= valid_csum_mask;
2964 ret_val = e1000_write_nvm(hw, 0x19, 1, &data); 3066 ret_val = e1000_write_nvm(hw, word, 1, &data);
2965 if (ret_val) 3067 if (ret_val)
2966 return ret_val; 3068 return ret_val;
2967 ret_val = e1000e_update_nvm_checksum(hw); 3069 ret_val = e1000e_update_nvm_checksum(hw);
@@ -4000,19 +4102,20 @@ void e1000_suspend_workarounds_ich8lan(struct e1000_hw *hw)
4000 if (!dev_spec->eee_disable) { 4102 if (!dev_spec->eee_disable) {
4001 u16 eee_advert; 4103 u16 eee_advert;
4002 4104
4003 ret_val = e1e_wphy_locked(hw, I82579_EMI_ADDR, 4105 ret_val =
4004 I217_EEE_ADVERTISEMENT); 4106 e1000_read_emi_reg_locked(hw,
4107 I217_EEE_ADVERTISEMENT,
4108 &eee_advert);
4005 if (ret_val) 4109 if (ret_val)
4006 goto release; 4110 goto release;
4007 e1e_rphy_locked(hw, I82579_EMI_DATA, &eee_advert);
4008 4111
4009 /* Disable LPLU if both link partners support 100BaseT 4112 /* Disable LPLU if both link partners support 100BaseT
4010 * EEE and 100Full is advertised on both ends of the 4113 * EEE and 100Full is advertised on both ends of the
4011 * link. 4114 * link.
4012 */ 4115 */
4013 if ((eee_advert & I217_EEE_100_SUPPORTED) && 4116 if ((eee_advert & I82579_EEE_100_SUPPORTED) &&
4014 (dev_spec->eee_lp_ability & 4117 (dev_spec->eee_lp_ability &
4015 I217_EEE_100_SUPPORTED) && 4118 I82579_EEE_100_SUPPORTED) &&
4016 (hw->phy.autoneg_advertised & ADVERTISE_100_FULL)) 4119 (hw->phy.autoneg_advertised & ADVERTISE_100_FULL))
4017 phy_ctrl &= ~(E1000_PHY_CTRL_D0A_LPLU | 4120 phy_ctrl &= ~(E1000_PHY_CTRL_D0A_LPLU |
4018 E1000_PHY_CTRL_NOND0A_LPLU); 4121 E1000_PHY_CTRL_NOND0A_LPLU);
diff --git a/drivers/net/ethernet/intel/e1000e/mac.c b/drivers/net/ethernet/intel/e1000e/mac.c
index 54d9dafaf126..0fa4c0656e09 100644
--- a/drivers/net/ethernet/intel/e1000e/mac.c
+++ b/drivers/net/ethernet/intel/e1000e/mac.c
@@ -1021,6 +1021,7 @@ s32 e1000e_config_fc_after_link_up(struct e1000_hw *hw)
1021{ 1021{
1022 struct e1000_mac_info *mac = &hw->mac; 1022 struct e1000_mac_info *mac = &hw->mac;
1023 s32 ret_val = 0; 1023 s32 ret_val = 0;
1024 u32 pcs_status_reg, pcs_adv_reg, pcs_lp_ability_reg, pcs_ctrl_reg;
1024 u16 mii_status_reg, mii_nway_adv_reg, mii_nway_lp_ability_reg; 1025 u16 mii_status_reg, mii_nway_adv_reg, mii_nway_lp_ability_reg;
1025 u16 speed, duplex; 1026 u16 speed, duplex;
1026 1027
@@ -1185,6 +1186,130 @@ s32 e1000e_config_fc_after_link_up(struct e1000_hw *hw)
1185 } 1186 }
1186 } 1187 }
1187 1188
1189 /* Check for the case where we have SerDes media and auto-neg is
1190 * enabled. In this case, we need to check and see if Auto-Neg
1191 * has completed, and if so, how the PHY and link partner has
1192 * flow control configured.
1193 */
1194 if ((hw->phy.media_type == e1000_media_type_internal_serdes) &&
1195 mac->autoneg) {
1196 /* Read the PCS_LSTS and check to see if AutoNeg
1197 * has completed.
1198 */
1199 pcs_status_reg = er32(PCS_LSTAT);
1200
1201 if (!(pcs_status_reg & E1000_PCS_LSTS_AN_COMPLETE)) {
1202 e_dbg("PCS Auto Neg has not completed.\n");
1203 return ret_val;
1204 }
1205
1206 /* The AutoNeg process has completed, so we now need to
1207 * read both the Auto Negotiation Advertisement
1208 * Register (PCS_ANADV) and the Auto_Negotiation Base
1209 * Page Ability Register (PCS_LPAB) to determine how
1210 * flow control was negotiated.
1211 */
1212 pcs_adv_reg = er32(PCS_ANADV);
1213 pcs_lp_ability_reg = er32(PCS_LPAB);
1214
1215 /* Two bits in the Auto Negotiation Advertisement Register
1216 * (PCS_ANADV) and two bits in the Auto Negotiation Base
1217 * Page Ability Register (PCS_LPAB) determine flow control
1218 * for both the PHY and the link partner. The following
1219 * table, taken out of the IEEE 802.3ab/D6.0 dated March 25,
1220 * 1999, describes these PAUSE resolution bits and how flow
1221 * control is determined based upon these settings.
1222 * NOTE: DC = Don't Care
1223 *
1224 * LOCAL DEVICE | LINK PARTNER
1225 * PAUSE | ASM_DIR | PAUSE | ASM_DIR | NIC Resolution
1226 *-------|---------|-------|---------|--------------------
1227 * 0 | 0 | DC | DC | e1000_fc_none
1228 * 0 | 1 | 0 | DC | e1000_fc_none
1229 * 0 | 1 | 1 | 0 | e1000_fc_none
1230 * 0 | 1 | 1 | 1 | e1000_fc_tx_pause
1231 * 1 | 0 | 0 | DC | e1000_fc_none
1232 * 1 | DC | 1 | DC | e1000_fc_full
1233 * 1 | 1 | 0 | 0 | e1000_fc_none
1234 * 1 | 1 | 0 | 1 | e1000_fc_rx_pause
1235 *
1236 * Are both PAUSE bits set to 1? If so, this implies
1237 * Symmetric Flow Control is enabled at both ends. The
1238 * ASM_DIR bits are irrelevant per the spec.
1239 *
1240 * For Symmetric Flow Control:
1241 *
1242 * LOCAL DEVICE | LINK PARTNER
1243 * PAUSE | ASM_DIR | PAUSE | ASM_DIR | Result
1244 *-------|---------|-------|---------|--------------------
1245 * 1 | DC | 1 | DC | e1000_fc_full
1246 *
1247 */
1248 if ((pcs_adv_reg & E1000_TXCW_PAUSE) &&
1249 (pcs_lp_ability_reg & E1000_TXCW_PAUSE)) {
1250 /* Now we need to check if the user selected Rx ONLY
1251 * of pause frames. In this case, we had to advertise
1252 * FULL flow control because we could not advertise Rx
1253 * ONLY. Hence, we must now check to see if we need to
1254 * turn OFF the TRANSMISSION of PAUSE frames.
1255 */
1256 if (hw->fc.requested_mode == e1000_fc_full) {
1257 hw->fc.current_mode = e1000_fc_full;
1258 e_dbg("Flow Control = FULL.\n");
1259 } else {
1260 hw->fc.current_mode = e1000_fc_rx_pause;
1261 e_dbg("Flow Control = Rx PAUSE frames only.\n");
1262 }
1263 }
1264 /* For receiving PAUSE frames ONLY.
1265 *
1266 * LOCAL DEVICE | LINK PARTNER
1267 * PAUSE | ASM_DIR | PAUSE | ASM_DIR | Result
1268 *-------|---------|-------|---------|--------------------
1269 * 0 | 1 | 1 | 1 | e1000_fc_tx_pause
1270 */
1271 else if (!(pcs_adv_reg & E1000_TXCW_PAUSE) &&
1272 (pcs_adv_reg & E1000_TXCW_ASM_DIR) &&
1273 (pcs_lp_ability_reg & E1000_TXCW_PAUSE) &&
1274 (pcs_lp_ability_reg & E1000_TXCW_ASM_DIR)) {
1275 hw->fc.current_mode = e1000_fc_tx_pause;
1276 e_dbg("Flow Control = Tx PAUSE frames only.\n");
1277 }
1278 /* For transmitting PAUSE frames ONLY.
1279 *
1280 * LOCAL DEVICE | LINK PARTNER
1281 * PAUSE | ASM_DIR | PAUSE | ASM_DIR | Result
1282 *-------|---------|-------|---------|--------------------
1283 * 1 | 1 | 0 | 1 | e1000_fc_rx_pause
1284 */
1285 else if ((pcs_adv_reg & E1000_TXCW_PAUSE) &&
1286 (pcs_adv_reg & E1000_TXCW_ASM_DIR) &&
1287 !(pcs_lp_ability_reg & E1000_TXCW_PAUSE) &&
1288 (pcs_lp_ability_reg & E1000_TXCW_ASM_DIR)) {
1289 hw->fc.current_mode = e1000_fc_rx_pause;
1290 e_dbg("Flow Control = Rx PAUSE frames only.\n");
1291 } else {
1292 /* Per the IEEE spec, at this point flow control
1293 * should be disabled.
1294 */
1295 hw->fc.current_mode = e1000_fc_none;
1296 e_dbg("Flow Control = NONE.\n");
1297 }
1298
1299 /* Now we call a subroutine to actually force the MAC
1300 * controller to use the correct flow control settings.
1301 */
1302 pcs_ctrl_reg = er32(PCS_LCTL);
1303 pcs_ctrl_reg |= E1000_PCS_LCTL_FORCE_FCTRL;
1304 ew32(PCS_LCTL, pcs_ctrl_reg);
1305
1306 ret_val = e1000e_force_mac_fc(hw);
1307 if (ret_val) {
1308 e_dbg("Error forcing flow control settings\n");
1309 return ret_val;
1310 }
1311 }
1312
1188 return 0; 1313 return 0;
1189} 1314}
1190 1315
diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c
index 337644dda14d..05538e66c809 100644
--- a/drivers/net/ethernet/intel/e1000e/netdev.c
+++ b/drivers/net/ethernet/intel/e1000e/netdev.c
@@ -765,7 +765,7 @@ static void e1000_alloc_jumbo_rx_buffers(struct e1000_ring *rx_ring,
765 struct e1000_buffer *buffer_info; 765 struct e1000_buffer *buffer_info;
766 struct sk_buff *skb; 766 struct sk_buff *skb;
767 unsigned int i; 767 unsigned int i;
768 unsigned int bufsz = 256 - 16 /* for skb_reserve */; 768 unsigned int bufsz = 256 - 16; /* for skb_reserve */
769 769
770 i = rx_ring->next_to_use; 770 i = rx_ring->next_to_use;
771 buffer_info = &rx_ring->buffer_info[i]; 771 buffer_info = &rx_ring->buffer_info[i];
@@ -1671,7 +1671,7 @@ static irqreturn_t e1000_intr_msi(int irq, void *data)
1671 /* disable receives */ 1671 /* disable receives */
1672 u32 rctl = er32(RCTL); 1672 u32 rctl = er32(RCTL);
1673 ew32(RCTL, rctl & ~E1000_RCTL_EN); 1673 ew32(RCTL, rctl & ~E1000_RCTL_EN);
1674 adapter->flags |= FLAG_RX_RESTART_NOW; 1674 adapter->flags |= FLAG_RESTART_NOW;
1675 } 1675 }
1676 /* guard against interrupt when we're going down */ 1676 /* guard against interrupt when we're going down */
1677 if (!test_bit(__E1000_DOWN, &adapter->state)) 1677 if (!test_bit(__E1000_DOWN, &adapter->state))
@@ -1734,7 +1734,7 @@ static irqreturn_t e1000_intr(int irq, void *data)
1734 /* disable receives */ 1734 /* disable receives */
1735 rctl = er32(RCTL); 1735 rctl = er32(RCTL);
1736 ew32(RCTL, rctl & ~E1000_RCTL_EN); 1736 ew32(RCTL, rctl & ~E1000_RCTL_EN);
1737 adapter->flags |= FLAG_RX_RESTART_NOW; 1737 adapter->flags |= FLAG_RESTART_NOW;
1738 } 1738 }
1739 /* guard against interrupt when we're going down */ 1739 /* guard against interrupt when we're going down */
1740 if (!test_bit(__E1000_DOWN, &adapter->state)) 1740 if (!test_bit(__E1000_DOWN, &adapter->state))
@@ -2405,7 +2405,6 @@ static unsigned int e1000_update_itr(struct e1000_adapter *adapter,
2405 2405
2406static void e1000_set_itr(struct e1000_adapter *adapter) 2406static void e1000_set_itr(struct e1000_adapter *adapter)
2407{ 2407{
2408 struct e1000_hw *hw = &adapter->hw;
2409 u16 current_itr; 2408 u16 current_itr;
2410 u32 new_itr = adapter->itr; 2409 u32 new_itr = adapter->itr;
2411 2410
@@ -2468,10 +2467,7 @@ set_itr_now:
2468 if (adapter->msix_entries) 2467 if (adapter->msix_entries)
2469 adapter->rx_ring->set_itr = 1; 2468 adapter->rx_ring->set_itr = 1;
2470 else 2469 else
2471 if (new_itr) 2470 e1000e_write_itr(adapter, new_itr);
2472 ew32(ITR, 1000000000 / (new_itr * 256));
2473 else
2474 ew32(ITR, 0);
2475 } 2471 }
2476} 2472}
2477 2473
@@ -3013,7 +3009,7 @@ static void e1000_setup_rctl(struct e1000_adapter *adapter)
3013 3009
3014 ew32(RCTL, rctl); 3010 ew32(RCTL, rctl);
3015 /* just started the receive unit, no need to restart */ 3011 /* just started the receive unit, no need to restart */
3016 adapter->flags &= ~FLAG_RX_RESTART_NOW; 3012 adapter->flags &= ~FLAG_RESTART_NOW;
3017} 3013}
3018 3014
3019/** 3015/**
@@ -4300,9 +4296,8 @@ static void e1000_print_link_info(struct e1000_adapter *adapter)
4300 u32 ctrl = er32(CTRL); 4296 u32 ctrl = er32(CTRL);
4301 4297
4302 /* Link status message must follow this format for user tools */ 4298 /* Link status message must follow this format for user tools */
4303 printk(KERN_INFO "e1000e: %s NIC Link is Up %d Mbps %s Duplex, Flow Control: %s\n", 4299 pr_info("%s NIC Link is Up %d Mbps %s Duplex, Flow Control: %s\n",
4304 adapter->netdev->name, 4300 adapter->netdev->name, adapter->link_speed,
4305 adapter->link_speed,
4306 adapter->link_duplex == FULL_DUPLEX ? "Full" : "Half", 4301 adapter->link_duplex == FULL_DUPLEX ? "Full" : "Half",
4307 (ctrl & E1000_CTRL_TFCE) && (ctrl & E1000_CTRL_RFCE) ? "Rx/Tx" : 4302 (ctrl & E1000_CTRL_TFCE) && (ctrl & E1000_CTRL_RFCE) ? "Rx/Tx" :
4308 (ctrl & E1000_CTRL_RFCE) ? "Rx" : 4303 (ctrl & E1000_CTRL_RFCE) ? "Rx" :
@@ -4355,11 +4350,11 @@ static void e1000e_enable_receives(struct e1000_adapter *adapter)
4355{ 4350{
4356 /* make sure the receive unit is started */ 4351 /* make sure the receive unit is started */
4357 if ((adapter->flags & FLAG_RX_NEEDS_RESTART) && 4352 if ((adapter->flags & FLAG_RX_NEEDS_RESTART) &&
4358 (adapter->flags & FLAG_RX_RESTART_NOW)) { 4353 (adapter->flags & FLAG_RESTART_NOW)) {
4359 struct e1000_hw *hw = &adapter->hw; 4354 struct e1000_hw *hw = &adapter->hw;
4360 u32 rctl = er32(RCTL); 4355 u32 rctl = er32(RCTL);
4361 ew32(RCTL, rctl | E1000_RCTL_EN); 4356 ew32(RCTL, rctl | E1000_RCTL_EN);
4362 adapter->flags &= ~FLAG_RX_RESTART_NOW; 4357 adapter->flags &= ~FLAG_RESTART_NOW;
4363 } 4358 }
4364} 4359}
4365 4360
@@ -4521,15 +4516,22 @@ static void e1000_watchdog_task(struct work_struct *work)
4521 adapter->link_speed = 0; 4516 adapter->link_speed = 0;
4522 adapter->link_duplex = 0; 4517 adapter->link_duplex = 0;
4523 /* Link status message must follow this format */ 4518 /* Link status message must follow this format */
4524 printk(KERN_INFO "e1000e: %s NIC Link is Down\n", 4519 pr_info("%s NIC Link is Down\n", adapter->netdev->name);
4525 adapter->netdev->name);
4526 netif_carrier_off(netdev); 4520 netif_carrier_off(netdev);
4527 if (!test_bit(__E1000_DOWN, &adapter->state)) 4521 if (!test_bit(__E1000_DOWN, &adapter->state))
4528 mod_timer(&adapter->phy_info_timer, 4522 mod_timer(&adapter->phy_info_timer,
4529 round_jiffies(jiffies + 2 * HZ)); 4523 round_jiffies(jiffies + 2 * HZ));
4530 4524
4531 if (adapter->flags & FLAG_RX_NEEDS_RESTART) 4525 /* The link is lost so the controller stops DMA.
4532 schedule_work(&adapter->reset_task); 4526 * If there is queued Tx work that cannot be done
4527 * or if on an 8000ES2LAN which requires a Rx packet
4528 * buffer work-around on link down event, reset the
4529 * controller to flush the Tx/Rx packet buffers.
4530 * (Do the reset outside of interrupt context).
4531 */
4532 if ((adapter->flags & FLAG_RX_NEEDS_RESTART) ||
4533 (e1000_desc_unused(tx_ring) + 1 < tx_ring->count))
4534 adapter->flags |= FLAG_RESTART_NOW;
4533 else 4535 else
4534 pm_schedule_suspend(netdev->dev.parent, 4536 pm_schedule_suspend(netdev->dev.parent,
4535 LINK_TIMEOUT); 4537 LINK_TIMEOUT);
@@ -4551,20 +4553,14 @@ link_up:
4551 adapter->gotc_old = adapter->stats.gotc; 4553 adapter->gotc_old = adapter->stats.gotc;
4552 spin_unlock(&adapter->stats64_lock); 4554 spin_unlock(&adapter->stats64_lock);
4553 4555
4554 e1000e_update_adaptive(&adapter->hw); 4556 if (adapter->flags & FLAG_RESTART_NOW) {
4555
4556 if (!netif_carrier_ok(netdev) &&
4557 (e1000_desc_unused(tx_ring) + 1 < tx_ring->count)) {
4558 /* We've lost link, so the controller stops DMA,
4559 * but we've got queued Tx work that's never going
4560 * to get done, so reset controller to flush Tx.
4561 * (Do the reset outside of interrupt context).
4562 */
4563 schedule_work(&adapter->reset_task); 4557 schedule_work(&adapter->reset_task);
4564 /* return immediately since reset is imminent */ 4558 /* return immediately since reset is imminent */
4565 return; 4559 return;
4566 } 4560 }
4567 4561
4562 e1000e_update_adaptive(&adapter->hw);
4563
4568 /* Simple mode for Interrupt Throttle Rate (ITR) */ 4564 /* Simple mode for Interrupt Throttle Rate (ITR) */
4569 if (adapter->itr_setting == 4) { 4565 if (adapter->itr_setting == 4) {
4570 /* Symmetric Tx/Rx gets a reduced ITR=2000; 4566 /* Symmetric Tx/Rx gets a reduced ITR=2000;
@@ -4918,12 +4914,11 @@ static int e1000_transfer_dhcp_info(struct e1000_adapter *adapter,
4918 struct e1000_hw *hw = &adapter->hw; 4914 struct e1000_hw *hw = &adapter->hw;
4919 u16 length, offset; 4915 u16 length, offset;
4920 4916
4921 if (vlan_tx_tag_present(skb)) { 4917 if (vlan_tx_tag_present(skb) &&
4922 if (!((vlan_tx_tag_get(skb) == adapter->hw.mng_cookie.vlan_id) && 4918 !((vlan_tx_tag_get(skb) == adapter->hw.mng_cookie.vlan_id) &&
4923 (adapter->hw.mng_cookie.status & 4919 (adapter->hw.mng_cookie.status &
4924 E1000_MNG_DHCP_COOKIE_STATUS_VLAN))) 4920 E1000_MNG_DHCP_COOKIE_STATUS_VLAN)))
4925 return 0; 4921 return 0;
4926 }
4927 4922
4928 if (skb->len <= MINIMUM_DHCP_PACKET_SIZE) 4923 if (skb->len <= MINIMUM_DHCP_PACKET_SIZE)
4929 return 0; 4924 return 0;
@@ -5134,10 +5129,9 @@ static void e1000_reset_task(struct work_struct *work)
5134 if (test_bit(__E1000_DOWN, &adapter->state)) 5129 if (test_bit(__E1000_DOWN, &adapter->state))
5135 return; 5130 return;
5136 5131
5137 if (!((adapter->flags & FLAG_RX_NEEDS_RESTART) && 5132 if (!(adapter->flags & FLAG_RESTART_NOW)) {
5138 (adapter->flags & FLAG_RX_RESTART_NOW))) {
5139 e1000e_dump(adapter); 5133 e1000e_dump(adapter);
5140 e_err("Reset adapter\n"); 5134 e_err("Reset adapter unexpectedly\n");
5141 } 5135 }
5142 e1000e_reinit_locked(adapter); 5136 e1000e_reinit_locked(adapter);
5143} 5137}
diff --git a/drivers/net/ethernet/intel/e1000e/nvm.c b/drivers/net/ethernet/intel/e1000e/nvm.c
index b6468804cb2e..1e7882c7d6d4 100644
--- a/drivers/net/ethernet/intel/e1000e/nvm.c
+++ b/drivers/net/ethernet/intel/e1000e/nvm.c
@@ -359,7 +359,7 @@ s32 e1000e_read_nvm_eerd(struct e1000_hw *hw, u16 offset, u16 words, u16 *data)
359s32 e1000e_write_nvm_spi(struct e1000_hw *hw, u16 offset, u16 words, u16 *data) 359s32 e1000e_write_nvm_spi(struct e1000_hw *hw, u16 offset, u16 words, u16 *data)
360{ 360{
361 struct e1000_nvm_info *nvm = &hw->nvm; 361 struct e1000_nvm_info *nvm = &hw->nvm;
362 s32 ret_val; 362 s32 ret_val = -E1000_ERR_NVM;
363 u16 widx = 0; 363 u16 widx = 0;
364 364
365 /* A check for invalid values: offset too large, too many words, 365 /* A check for invalid values: offset too large, too many words,
@@ -371,16 +371,18 @@ s32 e1000e_write_nvm_spi(struct e1000_hw *hw, u16 offset, u16 words, u16 *data)
371 return -E1000_ERR_NVM; 371 return -E1000_ERR_NVM;
372 } 372 }
373 373
374 ret_val = nvm->ops.acquire(hw);
375 if (ret_val)
376 return ret_val;
377
378 while (widx < words) { 374 while (widx < words) {
379 u8 write_opcode = NVM_WRITE_OPCODE_SPI; 375 u8 write_opcode = NVM_WRITE_OPCODE_SPI;
380 376
381 ret_val = e1000_ready_nvm_eeprom(hw); 377 ret_val = nvm->ops.acquire(hw);
382 if (ret_val) 378 if (ret_val)
383 goto release; 379 return ret_val;
380
381 ret_val = e1000_ready_nvm_eeprom(hw);
382 if (ret_val) {
383 nvm->ops.release(hw);
384 return ret_val;
385 }
384 386
385 e1000_standby_nvm(hw); 387 e1000_standby_nvm(hw);
386 388
@@ -413,12 +415,10 @@ s32 e1000e_write_nvm_spi(struct e1000_hw *hw, u16 offset, u16 words, u16 *data)
413 break; 415 break;
414 } 416 }
415 } 417 }
418 usleep_range(10000, 20000);
419 nvm->ops.release(hw);
416 } 420 }
417 421
418 usleep_range(10000, 20000);
419release:
420 nvm->ops.release(hw);
421
422 return ret_val; 422 return ret_val;
423} 423}
424 424
@@ -464,8 +464,8 @@ s32 e1000_read_pba_string_generic(struct e1000_hw *hw, u8 *pba_num,
464 if (nvm_data != NVM_PBA_PTR_GUARD) { 464 if (nvm_data != NVM_PBA_PTR_GUARD) {
465 e_dbg("NVM PBA number is not stored as string\n"); 465 e_dbg("NVM PBA number is not stored as string\n");
466 466
467 /* we will need 11 characters to store the PBA */ 467 /* make sure callers buffer is big enough to store the PBA */
468 if (pba_num_size < 11) { 468 if (pba_num_size < E1000_PBANUM_LENGTH) {
469 e_dbg("PBA string buffer too small\n"); 469 e_dbg("PBA string buffer too small\n");
470 return E1000_ERR_NO_SPACE; 470 return E1000_ERR_NO_SPACE;
471 } 471 }
diff --git a/drivers/net/ethernet/intel/e1000e/param.c b/drivers/net/ethernet/intel/e1000e/param.c
index 89d536dd7ff5..b29a8a5116a8 100644
--- a/drivers/net/ethernet/intel/e1000e/param.c
+++ b/drivers/net/ethernet/intel/e1000e/param.c
@@ -447,8 +447,7 @@ void e1000e_check_options(struct e1000_adapter *adapter)
447 if (num_SmartPowerDownEnable > bd) { 447 if (num_SmartPowerDownEnable > bd) {
448 unsigned int spd = SmartPowerDownEnable[bd]; 448 unsigned int spd = SmartPowerDownEnable[bd];
449 e1000_validate_option(&spd, &opt, adapter); 449 e1000_validate_option(&spd, &opt, adapter);
450 if ((adapter->flags & FLAG_HAS_SMART_POWER_DOWN) 450 if ((adapter->flags & FLAG_HAS_SMART_POWER_DOWN) && spd)
451 && spd)
452 adapter->flags |= FLAG_SMART_POWER_DOWN; 451 adapter->flags |= FLAG_SMART_POWER_DOWN;
453 } 452 }
454 } 453 }