[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20191107182952.4352-1-dsahern@kernel.org>
Date: Thu, 7 Nov 2019 18:29:52 +0000
From: David Ahern <dsahern@...nel.org>
To: netdev@...r.kernel.org
Cc: hd@...cillation.de, mark.tomlinson@...iedtelesis.co.nz,
David Ahern <dsahern@...nel.org>
Subject: [PATCH net] ipv4: Fix table id reference in fib_sync_down_addr
Hendrik reported routes in the main table using source address are not
removed when the address is removed. The problem is that fib_sync_down_addr
does not account for devices in the default VRF which are associated
with the main table. Fix by updating the table id reference.
Fixes: 5a56a0b3a45d ("net: Don't delete routes in different VRFs")
Reported-by: Hendrik Donner <hd@...cillation.de>
Signed-off-by: David Ahern <dsahern@...nel.org>
---
net/ipv4/fib_semantics.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/net/ipv4/fib_semantics.c b/net/ipv4/fib_semantics.c
index 0913a090b2bf..f1888c683426 100644
--- a/net/ipv4/fib_semantics.c
+++ b/net/ipv4/fib_semantics.c
@@ -1814,8 +1814,8 @@ int fib_sync_down_addr(struct net_device *dev, __be32 local)
int ret = 0;
unsigned int hash = fib_laddr_hashfn(local);
struct hlist_head *head = &fib_info_laddrhash[hash];
+ int tb_id = l3mdev_fib_table(dev) ? : RT_TABLE_MAIN;
struct net *net = dev_net(dev);
- int tb_id = l3mdev_fib_table(dev);
struct fib_info *fi;
if (!fib_info_laddrhash || local == 0)
--
2.21.0
Powered by blists - more mailing lists