diff options
author | Greg Rose <gregory.v.rose@intel.com> | 2014-03-14 03:32:20 -0400 |
---|---|---|
committer | Jeff Kirsher <jeffrey.t.kirsher@intel.com> | 2014-04-28 06:54:12 -0400 |
commit | 1315f7c34e08f50b0d710168c2d98fb4766a7f5d (patch) | |
tree | 64dad81893e6775d007600fabd6fb0c29ebf8011 /drivers/net | |
parent | 0dd8357f8fab1d82aa8fc8267261203f393d5a1f (diff) |
i40e: Retain MAC filters when changing port VLAN
We were already taking care to retain the MAC filter list when deleting a
port VLAN. Take some additional care to retain the MAC filter list when
changing a port VLAN.
Change-ID: Iacf9599ea24ecb4dca8e419aacaf4b58ca361a9c
Signed-off-by: Greg Rose <gregory.v.rose@intel.com>
Signed-off-by: Catherine Sullivan <catherine.sullivan@intel.com>
Tested-by: Sibai Li <sibai.li@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c b/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c index b27b2f59ea82..982eef042577 100644 --- a/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c +++ b/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c | |||
@@ -2128,11 +2128,15 @@ int i40e_ndo_set_vf_port_vlan(struct net_device *netdev, | |||
2128 | 2128 | ||
2129 | /* Check for condition where there was already a port VLAN ID | 2129 | /* Check for condition where there was already a port VLAN ID |
2130 | * filter set and now it is being deleted by setting it to zero. | 2130 | * filter set and now it is being deleted by setting it to zero. |
2131 | * Additionally check for the condition where there was a port | ||
2132 | * VLAN but now there is a new and different port VLAN being set. | ||
2131 | * Before deleting all the old VLAN filters we must add new ones | 2133 | * Before deleting all the old VLAN filters we must add new ones |
2132 | * with -1 (I40E_VLAN_ANY) or otherwise we're left with all our | 2134 | * with -1 (I40E_VLAN_ANY) or otherwise we're left with all our |
2133 | * MAC addresses deleted. | 2135 | * MAC addresses deleted. |
2134 | */ | 2136 | */ |
2135 | if (!(vlan_id || qos) && vsi->info.pvid) | 2137 | if ((!(vlan_id || qos) || |
2138 | (vlan_id | qos) != le16_to_cpu(vsi->info.pvid)) && | ||
2139 | vsi->info.pvid) | ||
2136 | ret = i40e_vsi_add_vlan(vsi, I40E_VLAN_ANY); | 2140 | ret = i40e_vsi_add_vlan(vsi, I40E_VLAN_ANY); |
2137 | 2141 | ||
2138 | if (vsi->info.pvid) { | 2142 | if (vsi->info.pvid) { |