mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	i40e: allow VF to remove any MAC filter
If you use ip to change the MAC address of a VF while the VF driver is loaded, closing the VF interface or unloading the VF driver will cause the VF driver to remove the MAC filter for its original (now invalid) MAC address. This would cause the PF driver to kick an error message to the log, and back to the VF driver. Since the VF driver has not really done anything naughty, let's not punish it. Don't check for MAC address overrides on the delete operation, just make sure it's a valid address. This keeps us from spamming the log with confusing errors. Change-ID: I1f051bd4014e50855457d928c9ee8b0766981b2f Signed-off-by: Mitch Williams <mitch.a.williams@intel.com> Signed-off-by: Jesse Brandeburg <jesse.brandeburg@intel.com> Tested-by: Kavindya Deegala <kavindya.s.deegala@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
		
							parent
							
								
									3b867b28ce
								
							
						
					
					
						commit
						700bbf6c1f
					
				| @ -1525,9 +1525,13 @@ static int i40e_vc_del_mac_addr_msg(struct i40e_vf *vf, u8 *msg, u16 msglen) | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	for (i = 0; i < al->num_elements; i++) { | 	for (i = 0; i < al->num_elements; i++) { | ||||||
| 		ret = i40e_check_vf_permission(vf, al->list[i].addr); | 		if (is_broadcast_ether_addr(al->list[i].addr) || | ||||||
| 		if (ret) | 		    is_zero_ether_addr(al->list[i].addr)) { | ||||||
|  | 			dev_err(&pf->pdev->dev, "invalid VF MAC addr %pM\n", | ||||||
|  | 				al->list[i].addr); | ||||||
|  | 			ret = I40E_ERR_INVALID_MAC_ADDR; | ||||||
| 			goto error_param; | 			goto error_param; | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 	vsi = pf->vsi[vsi_id]; | 	vsi = pf->vsi[vsi_id]; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Mitch Williams
						Mitch Williams