ipv4: use RCU protection in inet_select_addr()
[ Upstream commit719817cd29] inet_select_addr() must use RCU protection to make sure the net structure it reads does not disappear. Fixes:c4544c7243("[NETNS]: Process inet_select_addr inside a namespace.") Signed-off-by: Eric Dumazet <edumazet@google.com> Link: https://patch.msgid.link/20250205155120.1676781-7-edumazet@google.com Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
1f778d7a8b
commit
91d93fb597
+2
-1
@@ -1341,10 +1341,11 @@ __be32 inet_select_addr(const struct net_device *dev, __be32 dst, int scope)
|
||||
__be32 addr = 0;
|
||||
unsigned char localnet_scope = RT_SCOPE_HOST;
|
||||
struct in_device *in_dev;
|
||||
struct net *net = dev_net(dev);
|
||||
struct net *net;
|
||||
int master_idx;
|
||||
|
||||
rcu_read_lock();
|
||||
net = dev_net_rcu(dev);
|
||||
in_dev = __in_dev_get_rcu(dev);
|
||||
if (!in_dev)
|
||||
goto no_in_dev;
|
||||
|
||||
Reference in New Issue
Block a user