aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPetr Machata <petrm@mellanox.com>2019-01-16 18:06:43 -0500
committerDavid S. Miller <davem@davemloft.net>2019-01-17 18:18:46 -0500
commit1cdc98c2711e42d956c4a5ce525d3f8e90c58f9e (patch)
tree82b07408b814d7901590d4b8e8900c94b5ebcae6
parent038a5a99e95214d0549401c74711152d9869ead3 (diff)
vxlan: changelink: Delete remote after update
If a change in remote address prompts a change in a default FDB entry, that change might be vetoed. If that happens, it would then be necessary to reinstate the already-removed default FDB entry corresponding to the previous remote address. Instead, arrange to have the previous address removed only after the FDB is successfully vetted. Signed-off-by: Petr Machata <petrm@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/vxlan.c17
1 files changed, 8 insertions, 9 deletions
diff --git a/drivers/net/vxlan.c b/drivers/net/vxlan.c
index 51e10f47d4f1..83f65eb3085f 100644
--- a/drivers/net/vxlan.c
+++ b/drivers/net/vxlan.c
@@ -3809,15 +3809,6 @@ static int vxlan_changelink(struct net_device *dev, struct nlattr *tb[],
3809 /* handle default dst entry */ 3809 /* handle default dst entry */
3810 if (!vxlan_addr_equal(&conf.remote_ip, &dst->remote_ip)) { 3810 if (!vxlan_addr_equal(&conf.remote_ip, &dst->remote_ip)) {
3811 spin_lock_bh(&vxlan->hash_lock); 3811 spin_lock_bh(&vxlan->hash_lock);
3812 if (!vxlan_addr_any(&dst->remote_ip))
3813 __vxlan_fdb_delete(vxlan, all_zeros_mac,
3814 dst->remote_ip,
3815 vxlan->cfg.dst_port,
3816 dst->remote_vni,
3817 dst->remote_vni,
3818 dst->remote_ifindex,
3819 true);
3820
3821 if (!vxlan_addr_any(&conf.remote_ip)) { 3812 if (!vxlan_addr_any(&conf.remote_ip)) {
3822 err = vxlan_fdb_update(vxlan, all_zeros_mac, 3813 err = vxlan_fdb_update(vxlan, all_zeros_mac,
3823 &conf.remote_ip, 3814 &conf.remote_ip,
@@ -3832,6 +3823,14 @@ static int vxlan_changelink(struct net_device *dev, struct nlattr *tb[],
3832 return err; 3823 return err;
3833 } 3824 }
3834 } 3825 }
3826 if (!vxlan_addr_any(&dst->remote_ip))
3827 __vxlan_fdb_delete(vxlan, all_zeros_mac,
3828 dst->remote_ip,
3829 vxlan->cfg.dst_port,
3830 dst->remote_vni,
3831 dst->remote_vni,
3832 dst->remote_ifindex,
3833 true);
3835 spin_unlock_bh(&vxlan->hash_lock); 3834 spin_unlock_bh(&vxlan->hash_lock);
3836 } 3835 }
3837 3836