aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/e1000/e1000_hw.c89
1 files changed, 53 insertions, 36 deletions
diff --git a/drivers/net/e1000/e1000_hw.c b/drivers/net/e1000/e1000_hw.c
index b3e95c1a1dab..8a7d7da4cd61 100644
--- a/drivers/net/e1000/e1000_hw.c
+++ b/drivers/net/e1000/e1000_hw.c
@@ -71,7 +71,7 @@ static int32_t e1000_host_if_read_cookie(struct e1000_hw *hw, uint8_t *buffer);
71static uint8_t e1000_calculate_mng_checksum(char *buffer, uint32_t length); 71static uint8_t e1000_calculate_mng_checksum(char *buffer, uint32_t length);
72static uint8_t e1000_arc_subsystem_valid(struct e1000_hw *hw); 72static uint8_t e1000_arc_subsystem_valid(struct e1000_hw *hw);
73static int32_t e1000_check_downshift(struct e1000_hw *hw); 73static int32_t e1000_check_downshift(struct e1000_hw *hw);
74static int32_t e1000_check_polarity(struct e1000_hw *hw, uint16_t *polarity); 74static int32_t e1000_check_polarity(struct e1000_hw *hw, e1000_rev_polarity *polarity);
75static void e1000_clear_hw_cntrs(struct e1000_hw *hw); 75static void e1000_clear_hw_cntrs(struct e1000_hw *hw);
76static void e1000_clear_vfta(struct e1000_hw *hw); 76static void e1000_clear_vfta(struct e1000_hw *hw);
77static int32_t e1000_commit_shadow_ram(struct e1000_hw *hw); 77static int32_t e1000_commit_shadow_ram(struct e1000_hw *hw);
@@ -4060,7 +4060,8 @@ e1000_phy_igp_get_info(struct e1000_hw *hw,
4060 struct e1000_phy_info *phy_info) 4060 struct e1000_phy_info *phy_info)
4061{ 4061{
4062 int32_t ret_val; 4062 int32_t ret_val;
4063 uint16_t phy_data, polarity, min_length, max_length, average; 4063 uint16_t phy_data, min_length, max_length, average;
4064 e1000_rev_polarity polarity;
4064 4065
4065 DEBUGFUNC("e1000_phy_igp_get_info"); 4066 DEBUGFUNC("e1000_phy_igp_get_info");
4066 4067
@@ -4085,8 +4086,8 @@ e1000_phy_igp_get_info(struct e1000_hw *hw,
4085 if (ret_val) 4086 if (ret_val)
4086 return ret_val; 4087 return ret_val;
4087 4088
4088 phy_info->mdix_mode = (phy_data & IGP01E1000_PSSR_MDIX) >> 4089 phy_info->mdix_mode = (e1000_auto_x_mode)((phy_data & IGP01E1000_PSSR_MDIX) >>
4089 IGP01E1000_PSSR_MDIX_SHIFT; 4090 IGP01E1000_PSSR_MDIX_SHIFT);
4090 4091
4091 if ((phy_data & IGP01E1000_PSSR_SPEED_MASK) == 4092 if ((phy_data & IGP01E1000_PSSR_SPEED_MASK) ==
4092 IGP01E1000_PSSR_SPEED_1000MBPS) { 4093 IGP01E1000_PSSR_SPEED_1000MBPS) {
@@ -4095,10 +4096,12 @@ e1000_phy_igp_get_info(struct e1000_hw *hw,
4095 if (ret_val) 4096 if (ret_val)
4096 return ret_val; 4097 return ret_val;
4097 4098
4098 phy_info->local_rx = (phy_data & SR_1000T_LOCAL_RX_STATUS) >> 4099 phy_info->local_rx = ((phy_data & SR_1000T_LOCAL_RX_STATUS) >>
4099 SR_1000T_LOCAL_RX_STATUS_SHIFT; 4100 SR_1000T_LOCAL_RX_STATUS_SHIFT) ?
4100 phy_info->remote_rx = (phy_data & SR_1000T_REMOTE_RX_STATUS) >> 4101 e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
4101 SR_1000T_REMOTE_RX_STATUS_SHIFT; 4102 phy_info->remote_rx = ((phy_data & SR_1000T_REMOTE_RX_STATUS) >>
4103 SR_1000T_REMOTE_RX_STATUS_SHIFT) ?
4104 e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
4102 4105
4103 /* Get cable length */ 4106 /* Get cable length */
4104 ret_val = e1000_get_cable_length(hw, &min_length, &max_length); 4107 ret_val = e1000_get_cable_length(hw, &min_length, &max_length);
@@ -4134,7 +4137,8 @@ e1000_phy_ife_get_info(struct e1000_hw *hw,
4134 struct e1000_phy_info *phy_info) 4137 struct e1000_phy_info *phy_info)
4135{ 4138{
4136 int32_t ret_val; 4139 int32_t ret_val;
4137 uint16_t phy_data, polarity; 4140 uint16_t phy_data;
4141 e1000_rev_polarity polarity;
4138 4142
4139 DEBUGFUNC("e1000_phy_ife_get_info"); 4143 DEBUGFUNC("e1000_phy_ife_get_info");
4140 4144
@@ -4145,8 +4149,9 @@ e1000_phy_ife_get_info(struct e1000_hw *hw,
4145 if (ret_val) 4149 if (ret_val)
4146 return ret_val; 4150 return ret_val;
4147 phy_info->polarity_correction = 4151 phy_info->polarity_correction =
4148 (phy_data & IFE_PSC_AUTO_POLARITY_DISABLE) >> 4152 ((phy_data & IFE_PSC_AUTO_POLARITY_DISABLE) >>
4149 IFE_PSC_AUTO_POLARITY_DISABLE_SHIFT; 4153 IFE_PSC_AUTO_POLARITY_DISABLE_SHIFT) ?
4154 e1000_polarity_reversal_disabled : e1000_polarity_reversal_enabled;
4150 4155
4151 if (phy_info->polarity_correction == e1000_polarity_reversal_enabled) { 4156 if (phy_info->polarity_correction == e1000_polarity_reversal_enabled) {
4152 ret_val = e1000_check_polarity(hw, &polarity); 4157 ret_val = e1000_check_polarity(hw, &polarity);
@@ -4154,8 +4159,9 @@ e1000_phy_ife_get_info(struct e1000_hw *hw,
4154 return ret_val; 4159 return ret_val;
4155 } else { 4160 } else {
4156 /* Polarity is forced. */ 4161 /* Polarity is forced. */
4157 polarity = (phy_data & IFE_PSC_FORCE_POLARITY) >> 4162 polarity = ((phy_data & IFE_PSC_FORCE_POLARITY) >>
4158 IFE_PSC_FORCE_POLARITY_SHIFT; 4163 IFE_PSC_FORCE_POLARITY_SHIFT) ?
4164 e1000_rev_polarity_reversed : e1000_rev_polarity_normal;
4159 } 4165 }
4160 phy_info->cable_polarity = polarity; 4166 phy_info->cable_polarity = polarity;
4161 4167
@@ -4163,9 +4169,9 @@ e1000_phy_ife_get_info(struct e1000_hw *hw,
4163 if (ret_val) 4169 if (ret_val)
4164 return ret_val; 4170 return ret_val;
4165 4171
4166 phy_info->mdix_mode = 4172 phy_info->mdix_mode = (e1000_auto_x_mode)
4167 (phy_data & (IFE_PMC_AUTO_MDIX | IFE_PMC_FORCE_MDIX)) >> 4173 ((phy_data & (IFE_PMC_AUTO_MDIX | IFE_PMC_FORCE_MDIX)) >>
4168 IFE_PMC_MDIX_MODE_SHIFT; 4174 IFE_PMC_MDIX_MODE_SHIFT);
4169 4175
4170 return E1000_SUCCESS; 4176 return E1000_SUCCESS;
4171} 4177}
@@ -4181,7 +4187,8 @@ e1000_phy_m88_get_info(struct e1000_hw *hw,
4181 struct e1000_phy_info *phy_info) 4187 struct e1000_phy_info *phy_info)
4182{ 4188{
4183 int32_t ret_val; 4189 int32_t ret_val;
4184 uint16_t phy_data, polarity; 4190 uint16_t phy_data;
4191 e1000_rev_polarity polarity;
4185 4192
4186 DEBUGFUNC("e1000_phy_m88_get_info"); 4193 DEBUGFUNC("e1000_phy_m88_get_info");
4187 4194
@@ -4194,11 +4201,14 @@ e1000_phy_m88_get_info(struct e1000_hw *hw,
4194 return ret_val; 4201 return ret_val;
4195 4202
4196 phy_info->extended_10bt_distance = 4203 phy_info->extended_10bt_distance =
4197 (phy_data & M88E1000_PSCR_10BT_EXT_DIST_ENABLE) >> 4204 ((phy_data & M88E1000_PSCR_10BT_EXT_DIST_ENABLE) >>
4198 M88E1000_PSCR_10BT_EXT_DIST_ENABLE_SHIFT; 4205 M88E1000_PSCR_10BT_EXT_DIST_ENABLE_SHIFT) ?
4206 e1000_10bt_ext_dist_enable_lower : e1000_10bt_ext_dist_enable_normal;
4207
4199 phy_info->polarity_correction = 4208 phy_info->polarity_correction =
4200 (phy_data & M88E1000_PSCR_POLARITY_REVERSAL) >> 4209 ((phy_data & M88E1000_PSCR_POLARITY_REVERSAL) >>
4201 M88E1000_PSCR_POLARITY_REVERSAL_SHIFT; 4210 M88E1000_PSCR_POLARITY_REVERSAL_SHIFT) ?
4211 e1000_polarity_reversal_disabled : e1000_polarity_reversal_enabled;
4202 4212
4203 /* Check polarity status */ 4213 /* Check polarity status */
4204 ret_val = e1000_check_polarity(hw, &polarity); 4214 ret_val = e1000_check_polarity(hw, &polarity);
@@ -4210,15 +4220,15 @@ e1000_phy_m88_get_info(struct e1000_hw *hw,
4210 if (ret_val) 4220 if (ret_val)
4211 return ret_val; 4221 return ret_val;
4212 4222
4213 phy_info->mdix_mode = (phy_data & M88E1000_PSSR_MDIX) >> 4223 phy_info->mdix_mode = (e1000_auto_x_mode)((phy_data & M88E1000_PSSR_MDIX) >>
4214 M88E1000_PSSR_MDIX_SHIFT; 4224 M88E1000_PSSR_MDIX_SHIFT);
4215 4225
4216 if ((phy_data & M88E1000_PSSR_SPEED) == M88E1000_PSSR_1000MBS) { 4226 if ((phy_data & M88E1000_PSSR_SPEED) == M88E1000_PSSR_1000MBS) {
4217 /* Cable Length Estimation and Local/Remote Receiver Information 4227 /* Cable Length Estimation and Local/Remote Receiver Information
4218 * are only valid at 1000 Mbps. 4228 * are only valid at 1000 Mbps.
4219 */ 4229 */
4220 if (hw->phy_type != e1000_phy_gg82563) { 4230 if (hw->phy_type != e1000_phy_gg82563) {
4221 phy_info->cable_length = ((phy_data & M88E1000_PSSR_CABLE_LENGTH) >> 4231 phy_info->cable_length = (e1000_cable_length)((phy_data & M88E1000_PSSR_CABLE_LENGTH) >>
4222 M88E1000_PSSR_CABLE_LENGTH_SHIFT); 4232 M88E1000_PSSR_CABLE_LENGTH_SHIFT);
4223 } else { 4233 } else {
4224 ret_val = e1000_read_phy_reg(hw, GG82563_PHY_DSP_DISTANCE, 4234 ret_val = e1000_read_phy_reg(hw, GG82563_PHY_DSP_DISTANCE,
@@ -4226,18 +4236,20 @@ e1000_phy_m88_get_info(struct e1000_hw *hw,
4226 if (ret_val) 4236 if (ret_val)
4227 return ret_val; 4237 return ret_val;
4228 4238
4229 phy_info->cable_length = phy_data & GG82563_DSPD_CABLE_LENGTH; 4239 phy_info->cable_length = (e1000_cable_length)(phy_data & GG82563_DSPD_CABLE_LENGTH);
4230 } 4240 }
4231 4241
4232 ret_val = e1000_read_phy_reg(hw, PHY_1000T_STATUS, &phy_data); 4242 ret_val = e1000_read_phy_reg(hw, PHY_1000T_STATUS, &phy_data);
4233 if (ret_val) 4243 if (ret_val)
4234 return ret_val; 4244 return ret_val;
4235 4245
4236 phy_info->local_rx = (phy_data & SR_1000T_LOCAL_RX_STATUS) >> 4246 phy_info->local_rx = ((phy_data & SR_1000T_LOCAL_RX_STATUS) >>
4237 SR_1000T_LOCAL_RX_STATUS_SHIFT; 4247 SR_1000T_LOCAL_RX_STATUS_SHIFT) ?
4248 e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
4249 phy_info->remote_rx = ((phy_data & SR_1000T_REMOTE_RX_STATUS) >>
4250 SR_1000T_REMOTE_RX_STATUS_SHIFT) ?
4251 e1000_1000t_rx_status_ok : e1000_1000t_rx_status_not_ok;
4238 4252
4239 phy_info->remote_rx = (phy_data & SR_1000T_REMOTE_RX_STATUS) >>
4240 SR_1000T_REMOTE_RX_STATUS_SHIFT;
4241 } 4253 }
4242 4254
4243 return E1000_SUCCESS; 4255 return E1000_SUCCESS;
@@ -6841,7 +6853,7 @@ e1000_get_cable_length(struct e1000_hw *hw,
6841 *****************************************************************************/ 6853 *****************************************************************************/
6842static int32_t 6854static int32_t
6843e1000_check_polarity(struct e1000_hw *hw, 6855e1000_check_polarity(struct e1000_hw *hw,
6844 uint16_t *polarity) 6856 e1000_rev_polarity *polarity)
6845{ 6857{
6846 int32_t ret_val; 6858 int32_t ret_val;
6847 uint16_t phy_data; 6859 uint16_t phy_data;
@@ -6855,8 +6867,10 @@ e1000_check_polarity(struct e1000_hw *hw,
6855 &phy_data); 6867 &phy_data);
6856 if (ret_val) 6868 if (ret_val)
6857 return ret_val; 6869 return ret_val;
6858 *polarity = (phy_data & M88E1000_PSSR_REV_POLARITY) >> 6870 *polarity = ((phy_data & M88E1000_PSSR_REV_POLARITY) >>
6859 M88E1000_PSSR_REV_POLARITY_SHIFT; 6871 M88E1000_PSSR_REV_POLARITY_SHIFT) ?
6872 e1000_rev_polarity_reversed : e1000_rev_polarity_normal;
6873
6860 } else if (hw->phy_type == e1000_phy_igp || 6874 } else if (hw->phy_type == e1000_phy_igp ||
6861 hw->phy_type == e1000_phy_igp_3 || 6875 hw->phy_type == e1000_phy_igp_3 ||
6862 hw->phy_type == e1000_phy_igp_2) { 6876 hw->phy_type == e1000_phy_igp_2) {
@@ -6878,19 +6892,22 @@ e1000_check_polarity(struct e1000_hw *hw,
6878 return ret_val; 6892 return ret_val;
6879 6893
6880 /* Check the polarity bits */ 6894 /* Check the polarity bits */
6881 *polarity = (phy_data & IGP01E1000_PHY_POLARITY_MASK) ? 1 : 0; 6895 *polarity = (phy_data & IGP01E1000_PHY_POLARITY_MASK) ?
6896 e1000_rev_polarity_reversed : e1000_rev_polarity_normal;
6882 } else { 6897 } else {
6883 /* For 10 Mbps, read the polarity bit in the status register. (for 6898 /* For 10 Mbps, read the polarity bit in the status register. (for
6884 * 100 Mbps this bit is always 0) */ 6899 * 100 Mbps this bit is always 0) */
6885 *polarity = phy_data & IGP01E1000_PSSR_POLARITY_REVERSED; 6900 *polarity = (phy_data & IGP01E1000_PSSR_POLARITY_REVERSED) ?
6901 e1000_rev_polarity_reversed : e1000_rev_polarity_normal;
6886 } 6902 }
6887 } else if (hw->phy_type == e1000_phy_ife) { 6903 } else if (hw->phy_type == e1000_phy_ife) {
6888 ret_val = e1000_read_phy_reg(hw, IFE_PHY_EXTENDED_STATUS_CONTROL, 6904 ret_val = e1000_read_phy_reg(hw, IFE_PHY_EXTENDED_STATUS_CONTROL,
6889 &phy_data); 6905 &phy_data);
6890 if (ret_val) 6906 if (ret_val)
6891 return ret_val; 6907 return ret_val;
6892 *polarity = (phy_data & IFE_PESC_POLARITY_REVERSED) >> 6908 *polarity = ((phy_data & IFE_PESC_POLARITY_REVERSED) >>
6893 IFE_PESC_POLARITY_REVERSED_SHIFT; 6909 IFE_PESC_POLARITY_REVERSED_SHIFT) ?
6910 e1000_rev_polarity_reversed : e1000_rev_polarity_normal;
6894 } 6911 }
6895 return E1000_SUCCESS; 6912 return E1000_SUCCESS;
6896} 6913}