mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	i40e: Add allmulti support for the VF
This patch enables a feature to enable/disable all multicast for a trusted VF. Change-Id: I926eba7f8850c8d40f8ad7e08bbe4056bbd3985f Signed-off-by: Anjali Singhai Jain <anjali.singhai@intel.com> Tested-by: Andrew Bowers <andrewx.bowers@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
		
							parent
							
								
									06c0e39bbe
								
							
						
					
					
						commit
						f42a5c74da
					
				| @ -215,6 +215,7 @@ struct i40evf_adapter { | |||||||
| #define I40EVF_FLAG_OUTER_UDP_CSUM_CAPABLE	BIT(12) | #define I40EVF_FLAG_OUTER_UDP_CSUM_CAPABLE	BIT(12) | ||||||
| #define I40EVF_FLAG_ADDR_SET_BY_PF		BIT(13) | #define I40EVF_FLAG_ADDR_SET_BY_PF		BIT(13) | ||||||
| #define I40EVF_FLAG_PROMISC_ON			BIT(15) | #define I40EVF_FLAG_PROMISC_ON			BIT(15) | ||||||
|  | #define I40EVF_FLAG_ALLMULTI_ON			BIT(16) | ||||||
| /* duplicates for common code */ | /* duplicates for common code */ | ||||||
| #define I40E_FLAG_FDIR_ATR_ENABLED		 0 | #define I40E_FLAG_FDIR_ATR_ENABLED		 0 | ||||||
| #define I40E_FLAG_DCB_ENABLED			 0 | #define I40E_FLAG_DCB_ENABLED			 0 | ||||||
| @ -241,6 +242,8 @@ struct i40evf_adapter { | |||||||
| #define I40EVF_FLAG_AQ_SET_RSS_LUT		BIT(14) | #define I40EVF_FLAG_AQ_SET_RSS_LUT		BIT(14) | ||||||
| #define I40EVF_FLAG_AQ_REQUEST_PROMISC		BIT(15) | #define I40EVF_FLAG_AQ_REQUEST_PROMISC		BIT(15) | ||||||
| #define I40EVF_FLAG_AQ_RELEASE_PROMISC		BIT(16) | #define I40EVF_FLAG_AQ_RELEASE_PROMISC		BIT(16) | ||||||
|  | #define I40EVF_FLAG_AQ_REQUEST_ALLMULTI		BIT(17) | ||||||
|  | #define I40EVF_FLAG_AQ_RELEASE_ALLMULTI		BIT(18) | ||||||
| 
 | 
 | ||||||
| 	/* OS defined structs */ | 	/* OS defined structs */ | ||||||
| 	struct net_device *netdev; | 	struct net_device *netdev; | ||||||
|  | |||||||
| @ -934,6 +934,13 @@ bottom_of_search_loop: | |||||||
| 		 adapter->flags & I40EVF_FLAG_PROMISC_ON) | 		 adapter->flags & I40EVF_FLAG_PROMISC_ON) | ||||||
| 		adapter->aq_required |= I40EVF_FLAG_AQ_RELEASE_PROMISC; | 		adapter->aq_required |= I40EVF_FLAG_AQ_RELEASE_PROMISC; | ||||||
| 
 | 
 | ||||||
|  | 	if (netdev->flags & IFF_ALLMULTI && | ||||||
|  | 	    !(adapter->flags & I40EVF_FLAG_ALLMULTI_ON)) | ||||||
|  | 		adapter->aq_required |= I40EVF_FLAG_AQ_REQUEST_ALLMULTI; | ||||||
|  | 	else if (!(netdev->flags & IFF_ALLMULTI) && | ||||||
|  | 		 adapter->flags & I40EVF_FLAG_ALLMULTI_ON) | ||||||
|  | 		adapter->aq_required |= I40EVF_FLAG_AQ_RELEASE_ALLMULTI; | ||||||
|  | 
 | ||||||
| 	clear_bit(__I40EVF_IN_CRITICAL_TASK, &adapter->crit_section); | 	clear_bit(__I40EVF_IN_CRITICAL_TASK, &adapter->crit_section); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1612,7 +1619,13 @@ static void i40evf_watchdog_task(struct work_struct *work) | |||||||
| 		goto watchdog_done; | 		goto watchdog_done; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (adapter->aq_required & I40EVF_FLAG_AQ_RELEASE_PROMISC) { | 	if (adapter->aq_required & I40EVF_FLAG_AQ_REQUEST_ALLMULTI) { | ||||||
|  | 		i40evf_set_promiscuous(adapter, I40E_FLAG_VF_MULTICAST_PROMISC); | ||||||
|  | 		goto watchdog_done; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if ((adapter->aq_required & I40EVF_FLAG_AQ_RELEASE_PROMISC) && | ||||||
|  | 	    (adapter->aq_required & I40EVF_FLAG_AQ_RELEASE_ALLMULTI)) { | ||||||
| 		i40evf_set_promiscuous(adapter, 0); | 		i40evf_set_promiscuous(adapter, 0); | ||||||
| 		goto watchdog_done; | 		goto watchdog_done; | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -641,6 +641,7 @@ void i40evf_del_vlans(struct i40evf_adapter *adapter) | |||||||
| void i40evf_set_promiscuous(struct i40evf_adapter *adapter, int flags) | void i40evf_set_promiscuous(struct i40evf_adapter *adapter, int flags) | ||||||
| { | { | ||||||
| 	struct i40e_virtchnl_promisc_info vpi; | 	struct i40e_virtchnl_promisc_info vpi; | ||||||
|  | 	int promisc_all; | ||||||
| 
 | 
 | ||||||
| 	if (adapter->current_op != I40E_VIRTCHNL_OP_UNKNOWN) { | 	if (adapter->current_op != I40E_VIRTCHNL_OP_UNKNOWN) { | ||||||
| 		/* bail because we already have a command pending */ | 		/* bail because we already have a command pending */ | ||||||
| @ -649,11 +650,21 @@ void i40evf_set_promiscuous(struct i40evf_adapter *adapter, int flags) | |||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (flags) { | 	promisc_all = I40E_FLAG_VF_UNICAST_PROMISC | | ||||||
|  | 		      I40E_FLAG_VF_MULTICAST_PROMISC; | ||||||
|  | 	if ((flags & promisc_all) == promisc_all) { | ||||||
| 		adapter->flags |= I40EVF_FLAG_PROMISC_ON; | 		adapter->flags |= I40EVF_FLAG_PROMISC_ON; | ||||||
| 		adapter->aq_required &= ~I40EVF_FLAG_AQ_REQUEST_PROMISC; | 		adapter->aq_required &= ~I40EVF_FLAG_AQ_REQUEST_PROMISC; | ||||||
| 		dev_info(&adapter->pdev->dev, "Entering promiscuous mode\n"); | 		dev_info(&adapter->pdev->dev, "Entering promiscuous mode\n"); | ||||||
| 	} else { | 	} | ||||||
|  | 
 | ||||||
|  | 	if (flags & I40E_FLAG_VF_MULTICAST_PROMISC) { | ||||||
|  | 		adapter->flags |= I40EVF_FLAG_ALLMULTI_ON; | ||||||
|  | 		adapter->aq_required &= ~I40EVF_FLAG_AQ_REQUEST_ALLMULTI; | ||||||
|  | 		dev_info(&adapter->pdev->dev, "Entering multicast promiscuous mode\n"); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if (!flags) { | ||||||
| 		adapter->flags &= ~I40EVF_FLAG_PROMISC_ON; | 		adapter->flags &= ~I40EVF_FLAG_PROMISC_ON; | ||||||
| 		adapter->aq_required &= ~I40EVF_FLAG_AQ_RELEASE_PROMISC; | 		adapter->aq_required &= ~I40EVF_FLAG_AQ_RELEASE_PROMISC; | ||||||
| 		dev_info(&adapter->pdev->dev, "Leaving promiscuous mode\n"); | 		dev_info(&adapter->pdev->dev, "Leaving promiscuous mode\n"); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Anjali Singhai Jain
						Anjali Singhai Jain