diff options
Diffstat (limited to 'drivers/net/ethernet/intel')
| -rw-r--r-- | drivers/net/ethernet/intel/e1000e/netdev.c | 10 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/i40e/i40e_main.c | 48 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/i40e/i40e_txrx.c | 30 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/i40evf/i40e_txrx.c | 30 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/ixgbe/ixgbe_main.c | 2 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/ixgbevf/mbx.c | 4 | 
6 files changed, 77 insertions, 47 deletions
| diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c index 75e60897b7e7..2b2e2f8c6369 100644 --- a/drivers/net/ethernet/intel/e1000e/netdev.c +++ b/drivers/net/ethernet/intel/e1000e/netdev.c @@ -2789,7 +2789,7 @@ static void e1000e_vlan_filter_enable(struct e1000_adapter *adapter)  }  /** - * e1000e_vlan_strip_enable - helper to disable HW VLAN stripping + * e1000e_vlan_strip_disable - helper to disable HW VLAN stripping   * @adapter: board private structure to initialize   **/  static void e1000e_vlan_strip_disable(struct e1000_adapter *adapter) @@ -6915,6 +6915,14 @@ static netdev_features_t e1000_fix_features(struct net_device *netdev,  	if ((hw->mac.type >= e1000_pch2lan) && (netdev->mtu > ETH_DATA_LEN))  		features &= ~NETIF_F_RXFCS; +	/* Since there is no support for separate Rx/Tx vlan accel +	 * enable/disable make sure Tx flag is always in same state as Rx. +	 */ +	if (features & NETIF_F_HW_VLAN_CTAG_RX) +		features |= NETIF_F_HW_VLAN_CTAG_TX; +	else +		features &= ~NETIF_F_HW_VLAN_CTAG_TX; +  	return features;  } diff --git a/drivers/net/ethernet/intel/i40e/i40e_main.c b/drivers/net/ethernet/intel/i40e/i40e_main.c index 5ea22008d721..501f15d9f4d6 100644 --- a/drivers/net/ethernet/intel/i40e/i40e_main.c +++ b/drivers/net/ethernet/intel/i40e/i40e_main.c @@ -1344,6 +1344,13 @@ struct i40e_mac_filter *i40e_add_filter(struct i40e_vsi *vsi,  	if (!vsi || !macaddr)  		return NULL; +	/* Do not allow broadcast filter to be added since broadcast filter +	 * is added as part of add VSI for any newly created VSI except +	 * FDIR VSI +	 */ +	if (is_broadcast_ether_addr(macaddr)) +		return NULL; +  	f = i40e_find_filter(vsi, macaddr, vlan, is_vf, is_netdev);  	if (!f) {  		f = kzalloc(sizeof(*f), GFP_ATOMIC); @@ -2151,18 +2158,6 @@ int i40e_sync_vsi_filters(struct i40e_vsi *vsi)  					 aq_ret, pf->hw.aq.asq_last_status);  			}  		} -		aq_ret = i40e_aq_set_vsi_broadcast(&vsi->back->hw, -						   vsi->seid, -						   cur_promisc, NULL); -		if (aq_ret) { -			retval = i40e_aq_rc_to_posix(aq_ret, -						     pf->hw.aq.asq_last_status); -			dev_info(&pf->pdev->dev, -				 "set brdcast promisc failed, err %s, aq_err %s\n", -				 i40e_stat_str(&pf->hw, aq_ret), -				 i40e_aq_str(&pf->hw, -					     pf->hw.aq.asq_last_status)); -		}  	}  out:  	/* if something went wrong then set the changed flag so we try again */ @@ -7726,10 +7721,11 @@ static int i40e_init_msix(struct i40e_pf *pf)   * i40e_vsi_alloc_q_vector - Allocate memory for a single interrupt vector   * @vsi: the VSI being configured   * @v_idx: index of the vector in the vsi struct + * @cpu: cpu to be used on affinity_mask   *   * We allocate one q_vector.  If allocation fails we return -ENOMEM.   **/ -static int i40e_vsi_alloc_q_vector(struct i40e_vsi *vsi, int v_idx) +static int i40e_vsi_alloc_q_vector(struct i40e_vsi *vsi, int v_idx, int cpu)  {  	struct i40e_q_vector *q_vector; @@ -7740,7 +7736,8 @@ static int i40e_vsi_alloc_q_vector(struct i40e_vsi *vsi, int v_idx)  	q_vector->vsi = vsi;  	q_vector->v_idx = v_idx; -	cpumask_set_cpu(v_idx, &q_vector->affinity_mask); +	cpumask_set_cpu(cpu, &q_vector->affinity_mask); +  	if (vsi->netdev)  		netif_napi_add(vsi->netdev, &q_vector->napi,  			       i40e_napi_poll, NAPI_POLL_WEIGHT); @@ -7764,8 +7761,7 @@ static int i40e_vsi_alloc_q_vector(struct i40e_vsi *vsi, int v_idx)  static int i40e_vsi_alloc_q_vectors(struct i40e_vsi *vsi)  {  	struct i40e_pf *pf = vsi->back; -	int v_idx, num_q_vectors; -	int err; +	int err, v_idx, num_q_vectors, current_cpu;  	/* if not MSIX, give the one vector only to the LAN VSI */  	if (pf->flags & I40E_FLAG_MSIX_ENABLED) @@ -7775,10 +7771,15 @@ static int i40e_vsi_alloc_q_vectors(struct i40e_vsi *vsi)  	else  		return -EINVAL; +	current_cpu = cpumask_first(cpu_online_mask); +  	for (v_idx = 0; v_idx < num_q_vectors; v_idx++) { -		err = i40e_vsi_alloc_q_vector(vsi, v_idx); +		err = i40e_vsi_alloc_q_vector(vsi, v_idx, current_cpu);  		if (err)  			goto err_out; +		current_cpu = cpumask_next(current_cpu, cpu_online_mask); +		if (unlikely(current_cpu >= nr_cpu_ids)) +			current_cpu = cpumask_first(cpu_online_mask);  	}  	return 0; @@ -9224,6 +9225,7 @@ int i40e_is_vsi_uplink_mode_veb(struct i40e_vsi *vsi)  static int i40e_add_vsi(struct i40e_vsi *vsi)  {  	int ret = -ENODEV; +	i40e_status aq_ret = 0;  	u8 laa_macaddr[ETH_ALEN];  	bool found_laa_mac_filter = false;  	struct i40e_pf *pf = vsi->back; @@ -9413,6 +9415,18 @@ static int i40e_add_vsi(struct i40e_vsi *vsi)  		vsi->seid = ctxt.seid;  		vsi->id = ctxt.vsi_number;  	} +	/* Except FDIR VSI, for all othet VSI set the broadcast filter */ +	if (vsi->type != I40E_VSI_FDIR) { +		aq_ret = i40e_aq_set_vsi_broadcast(hw, vsi->seid, true, NULL); +		if (aq_ret) { +			ret = i40e_aq_rc_to_posix(aq_ret, +						  hw->aq.asq_last_status); +			dev_info(&pf->pdev->dev, +				 "set brdcast promisc failed, err %s, aq_err %s\n", +				 i40e_stat_str(hw, aq_ret), +				 i40e_aq_str(hw, hw->aq.asq_last_status)); +		} +	}  	spin_lock_bh(&vsi->mac_filter_list_lock);  	/* If macvlan filters already exist, force them to get loaded */ diff --git a/drivers/net/ethernet/intel/i40e/i40e_txrx.c b/drivers/net/ethernet/intel/i40e/i40e_txrx.c index 55f151fca1dc..a8868e1bf832 100644 --- a/drivers/net/ethernet/intel/i40e/i40e_txrx.c +++ b/drivers/net/ethernet/intel/i40e/i40e_txrx.c @@ -1280,8 +1280,8 @@ static inline void i40e_rx_checksum(struct i40e_vsi *vsi,  				    union i40e_rx_desc *rx_desc)  {  	struct i40e_rx_ptype_decoded decoded; -	bool ipv4, ipv6, tunnel = false;  	u32 rx_error, rx_status; +	bool ipv4, ipv6;  	u8 ptype;  	u64 qword; @@ -1336,19 +1336,23 @@ static inline void i40e_rx_checksum(struct i40e_vsi *vsi,  	if (rx_error & BIT(I40E_RX_DESC_ERROR_PPRS_SHIFT))  		return; -	/* The hardware supported by this driver does not validate outer -	 * checksums for tunneled VXLAN or GENEVE frames.  I don't agree -	 * with it but the specification states that you "MAY validate", it -	 * doesn't make it a hard requirement so if we have validated the -	 * inner checksum report CHECKSUM_UNNECESSARY. +	/* If there is an outer header present that might contain a checksum +	 * we need to bump the checksum level by 1 to reflect the fact that +	 * we are indicating we validated the inner checksum.  	 */ -	if (decoded.inner_prot & (I40E_RX_PTYPE_INNER_PROT_TCP | -				  I40E_RX_PTYPE_INNER_PROT_UDP | -				  I40E_RX_PTYPE_INNER_PROT_SCTP)) -		tunnel = true; - -	skb->ip_summed = CHECKSUM_UNNECESSARY; -	skb->csum_level = tunnel ? 1 : 0; +	if (decoded.tunnel_type >= I40E_RX_PTYPE_TUNNEL_IP_GRENAT) +		skb->csum_level = 1; + +	/* Only report checksum unnecessary for TCP, UDP, or SCTP */ +	switch (decoded.inner_prot) { +	case I40E_RX_PTYPE_INNER_PROT_TCP: +	case I40E_RX_PTYPE_INNER_PROT_UDP: +	case I40E_RX_PTYPE_INNER_PROT_SCTP: +		skb->ip_summed = CHECKSUM_UNNECESSARY; +		/* fall though */ +	default: +		break; +	}  	return; diff --git a/drivers/net/ethernet/intel/i40evf/i40e_txrx.c b/drivers/net/ethernet/intel/i40evf/i40e_txrx.c index be99189da925..79d99cd91b24 100644 --- a/drivers/net/ethernet/intel/i40evf/i40e_txrx.c +++ b/drivers/net/ethernet/intel/i40evf/i40e_txrx.c @@ -752,8 +752,8 @@ static inline void i40e_rx_checksum(struct i40e_vsi *vsi,  				    union i40e_rx_desc *rx_desc)  {  	struct i40e_rx_ptype_decoded decoded; -	bool ipv4, ipv6, tunnel = false;  	u32 rx_error, rx_status; +	bool ipv4, ipv6;  	u8 ptype;  	u64 qword; @@ -808,19 +808,23 @@ static inline void i40e_rx_checksum(struct i40e_vsi *vsi,  	if (rx_error & BIT(I40E_RX_DESC_ERROR_PPRS_SHIFT))  		return; -	/* The hardware supported by this driver does not validate outer -	 * checksums for tunneled VXLAN or GENEVE frames.  I don't agree -	 * with it but the specification states that you "MAY validate", it -	 * doesn't make it a hard requirement so if we have validated the -	 * inner checksum report CHECKSUM_UNNECESSARY. +	/* If there is an outer header present that might contain a checksum +	 * we need to bump the checksum level by 1 to reflect the fact that +	 * we are indicating we validated the inner checksum.  	 */ -	if (decoded.inner_prot & (I40E_RX_PTYPE_INNER_PROT_TCP | -				  I40E_RX_PTYPE_INNER_PROT_UDP | -				  I40E_RX_PTYPE_INNER_PROT_SCTP)) -		tunnel = true; - -	skb->ip_summed = CHECKSUM_UNNECESSARY; -	skb->csum_level = tunnel ? 1 : 0; +	if (decoded.tunnel_type >= I40E_RX_PTYPE_TUNNEL_IP_GRENAT) +		skb->csum_level = 1; + +	/* Only report checksum unnecessary for TCP, UDP, or SCTP */ +	switch (decoded.inner_prot) { +	case I40E_RX_PTYPE_INNER_PROT_TCP: +	case I40E_RX_PTYPE_INNER_PROT_UDP: +	case I40E_RX_PTYPE_INNER_PROT_SCTP: +		skb->ip_summed = CHECKSUM_UNNECESSARY; +		/* fall though */ +	default: +		break; +	}  	return; diff --git a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c index 088c47cf27d9..8bebd862a54c 100644 --- a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c +++ b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c @@ -2887,7 +2887,7 @@ int ixgbe_poll(struct napi_struct *napi, int budget)  	if (!test_bit(__IXGBE_DOWN, &adapter->state))  		ixgbe_irq_enable_queues(adapter, BIT_ULL(q_vector->v_idx)); -	return 0; +	return min(work_done, budget - 1);  }  /** diff --git a/drivers/net/ethernet/intel/ixgbevf/mbx.c b/drivers/net/ethernet/intel/ixgbevf/mbx.c index 61a80da8b6f0..2819abc454c7 100644 --- a/drivers/net/ethernet/intel/ixgbevf/mbx.c +++ b/drivers/net/ethernet/intel/ixgbevf/mbx.c @@ -85,7 +85,7 @@ static s32 ixgbevf_poll_for_ack(struct ixgbe_hw *hw)  static s32 ixgbevf_read_posted_mbx(struct ixgbe_hw *hw, u32 *msg, u16 size)  {  	struct ixgbe_mbx_info *mbx = &hw->mbx; -	s32 ret_val = -IXGBE_ERR_MBX; +	s32 ret_val = IXGBE_ERR_MBX;  	if (!mbx->ops.read)  		goto out; @@ -111,7 +111,7 @@ out:  static s32 ixgbevf_write_posted_mbx(struct ixgbe_hw *hw, u32 *msg, u16 size)  {  	struct ixgbe_mbx_info *mbx = &hw->mbx; -	s32 ret_val = -IXGBE_ERR_MBX; +	s32 ret_val = IXGBE_ERR_MBX;  	/* exit if either we can't write or there isn't a defined timeout */  	if (!mbx->ops.write || !mbx->timeout) | 

