diff options
author | David Ahern <dsa@cumulusnetworks.com> | 2015-12-10 21:25:24 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-12-14 07:58:44 +0300 |
commit | 7f49e7a38b77a7538acf48762c22ccbd05d9535c (patch) | |
tree | 93cf3d05956b28bf4d69049da97c53ef032522dd /include/linux/cpufreq.h | |
parent | 98900a80d5343901634852190e2728ea1ffec250 (diff) | |
download | linux-7f49e7a38b77a7538acf48762c22ccbd05d9535c.tar.xz |
net: Flush local routes when device changes vrf association
The VRF driver cycles netdevs when an interface is enslaved or released:
the down event is used to flush neighbor and route tables and the up
event (if the interface was already up) effectively moves local and
connected routes to the proper table.
As of 4f823defdd5b the local route is left hanging around after a link
down, so when a netdev is moved from one VRF to another (or released
from a VRF altogether) local routes are left in the wrong table.
Fix by handling the NETDEV_CHANGEUPPER event. When the upper dev is
an L3mdev then call fib_disable_ip to flush all routes, local ones
to.
Fixes: 4f823defdd5b ("ipv4: fix to not remove local route on link down")
Cc: Julian Anastasov <ja@ssi.bg>
Signed-off-by: David Ahern <dsa@cumulusnetworks.com>
Signed-off-by: Nikolay Aleksandrov <nikolay@cumulusnetworks.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux/cpufreq.h')
0 files changed, 0 insertions, 0 deletions