diff options
Diffstat (limited to 'drivers/net/ethernet/intel/i40e/i40e_ethtool.c')
| -rw-r--r-- | drivers/net/ethernet/intel/i40e/i40e_ethtool.c | 41 | 
1 files changed, 21 insertions, 20 deletions
| diff --git a/drivers/net/ethernet/intel/i40e/i40e_ethtool.c b/drivers/net/ethernet/intel/i40e/i40e_ethtool.c index 41e1240acaea..d24d8731bef0 100644 --- a/drivers/net/ethernet/intel/i40e/i40e_ethtool.c +++ b/drivers/net/ethernet/intel/i40e/i40e_ethtool.c @@ -722,7 +722,14 @@ static void i40e_get_settings_link_up_fec(u8 req_fec_info,  	ethtool_link_ksettings_add_link_mode(ks, supported, FEC_RS);  	ethtool_link_ksettings_add_link_mode(ks, supported, FEC_BASER); -	if (I40E_AQ_SET_FEC_REQUEST_RS & req_fec_info) { +	if ((I40E_AQ_SET_FEC_REQUEST_RS & req_fec_info) && +	    (I40E_AQ_SET_FEC_REQUEST_KR & req_fec_info)) { +		ethtool_link_ksettings_add_link_mode(ks, advertising, +						     FEC_NONE); +		ethtool_link_ksettings_add_link_mode(ks, advertising, +						     FEC_BASER); +		ethtool_link_ksettings_add_link_mode(ks, advertising, FEC_RS); +	} else if (I40E_AQ_SET_FEC_REQUEST_RS & req_fec_info) {  		ethtool_link_ksettings_add_link_mode(ks, advertising, FEC_RS);  	} else if (I40E_AQ_SET_FEC_REQUEST_KR & req_fec_info) {  		ethtool_link_ksettings_add_link_mode(ks, advertising, @@ -730,12 +737,6 @@ static void i40e_get_settings_link_up_fec(u8 req_fec_info,  	} else {  		ethtool_link_ksettings_add_link_mode(ks, advertising,  						     FEC_NONE); -		if (I40E_AQ_SET_FEC_AUTO & req_fec_info) { -			ethtool_link_ksettings_add_link_mode(ks, advertising, -							     FEC_RS); -			ethtool_link_ksettings_add_link_mode(ks, advertising, -							     FEC_BASER); -		}  	}  } @@ -1437,6 +1438,7 @@ static int i40e_get_fec_param(struct net_device *netdev,  	struct i40e_hw *hw = &pf->hw;  	i40e_status status = 0;  	int err = 0; +	u8 fec_cfg;  	/* Get the current phy config */  	memset(&abilities, 0, sizeof(abilities)); @@ -1448,18 +1450,16 @@ static int i40e_get_fec_param(struct net_device *netdev,  	}  	fecparam->fec = 0; -	if (abilities.fec_cfg_curr_mod_ext_info & I40E_AQ_SET_FEC_AUTO) +	fec_cfg = abilities.fec_cfg_curr_mod_ext_info; +	if (fec_cfg & I40E_AQ_SET_FEC_AUTO)  		fecparam->fec |= ETHTOOL_FEC_AUTO; -	if ((abilities.fec_cfg_curr_mod_ext_info & -	     I40E_AQ_SET_FEC_REQUEST_RS) || -	    (abilities.fec_cfg_curr_mod_ext_info & -	     I40E_AQ_SET_FEC_ABILITY_RS)) +	else if (fec_cfg & (I40E_AQ_SET_FEC_REQUEST_RS | +		 I40E_AQ_SET_FEC_ABILITY_RS))  		fecparam->fec |= ETHTOOL_FEC_RS; -	if ((abilities.fec_cfg_curr_mod_ext_info & -	     I40E_AQ_SET_FEC_REQUEST_KR) || -	    (abilities.fec_cfg_curr_mod_ext_info & I40E_AQ_SET_FEC_ABILITY_KR)) +	else if (fec_cfg & (I40E_AQ_SET_FEC_REQUEST_KR | +		 I40E_AQ_SET_FEC_ABILITY_KR))  		fecparam->fec |= ETHTOOL_FEC_BASER; -	if (abilities.fec_cfg_curr_mod_ext_info == 0) +	if (fec_cfg == 0)  		fecparam->fec |= ETHTOOL_FEC_OFF;  	if (hw->phy.link_info.fec_info & I40E_AQ_CONFIG_FEC_KR_ENA) @@ -5112,7 +5112,7 @@ static int i40e_get_module_info(struct net_device *netdev,  	case I40E_MODULE_TYPE_SFP:  		status = i40e_aq_get_phy_register(hw,  				I40E_AQ_PHY_REG_ACCESS_EXTERNAL_MODULE, -				I40E_I2C_EEPROM_DEV_ADDR, +				I40E_I2C_EEPROM_DEV_ADDR, true,  				I40E_MODULE_SFF_8472_COMP,  				&sff8472_comp, NULL);  		if (status) @@ -5120,7 +5120,7 @@ static int i40e_get_module_info(struct net_device *netdev,  		status = i40e_aq_get_phy_register(hw,  				I40E_AQ_PHY_REG_ACCESS_EXTERNAL_MODULE, -				I40E_I2C_EEPROM_DEV_ADDR, +				I40E_I2C_EEPROM_DEV_ADDR, true,  				I40E_MODULE_SFF_8472_SWAP,  				&sff8472_swap, NULL);  		if (status) @@ -5152,7 +5152,7 @@ static int i40e_get_module_info(struct net_device *netdev,  		/* Read from memory page 0. */  		status = i40e_aq_get_phy_register(hw,  				I40E_AQ_PHY_REG_ACCESS_EXTERNAL_MODULE, -				0, +				0, true,  				I40E_MODULE_REVISION_ADDR,  				&sff8636_rev, NULL);  		if (status) @@ -5223,7 +5223,7 @@ static int i40e_get_module_eeprom(struct net_device *netdev,  		status = i40e_aq_get_phy_register(hw,  				I40E_AQ_PHY_REG_ACCESS_EXTERNAL_MODULE, -				addr, offset, &value, NULL); +				true, addr, offset, &value, NULL);  		if (status)  			return -EIO;  		data[i] = value; @@ -5242,6 +5242,7 @@ static int i40e_set_eee(struct net_device *netdev, struct ethtool_eee *edata)  }  static const struct ethtool_ops i40e_ethtool_recovery_mode_ops = { +	.get_drvinfo		= i40e_get_drvinfo,  	.set_eeprom		= i40e_set_eeprom,  	.get_eeprom_len		= i40e_get_eeprom_len,  	.get_eeprom		= i40e_get_eeprom, | 

