dev: advertise the new nsid when the netns iface changes
x-netns interfaces are bound to two netns: the link netns and the upper netns. Usually, this kind of interfaces is created in the link netns and then moved to the upper netns. At the end, the interface is visible only in the upper netns. The link nsid is advertised via netlink in the upper netns, thus the user always knows where is the link part. There is no such mechanism in the link netns. When the interface is moved to another netns, the user cannot "follow" it. This patch adds a new netlink attribute which helps to follow an interface which moves to another netns. When the interface is unregistered, the new nsid is advertised. If the interface is a x-netns interface (ie rtnl_link_ops->get_link_net is defined), the nsid is allocated if needed. CC: Jason A. Donenfeld <Jason@zx2c4.com> Signed-off-by: Nicolas Dichtel <nicolas.dichtel@6wind.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
b295edc54b
commit
6621dd29eb
@@ -145,6 +145,7 @@
|
||||
#include <linux/crash_dump.h>
|
||||
#include <linux/sctp.h>
|
||||
#include <net/udp_tunnel.h>
|
||||
#include <linux/net_namespace.h>
|
||||
|
||||
#include "net-sysfs.h"
|
||||
|
||||
@@ -7204,7 +7205,7 @@ static void rollback_registered_many(struct list_head *head)
|
||||
if (!dev->rtnl_link_ops ||
|
||||
dev->rtnl_link_state == RTNL_LINK_INITIALIZED)
|
||||
skb = rtmsg_ifinfo_build_skb(RTM_DELLINK, dev, ~0U, 0,
|
||||
GFP_KERNEL);
|
||||
GFP_KERNEL, NULL);
|
||||
|
||||
/*
|
||||
* Flush the unicast and multicast chains
|
||||
@@ -8291,7 +8292,7 @@ EXPORT_SYMBOL(unregister_netdev);
|
||||
|
||||
int dev_change_net_namespace(struct net_device *dev, struct net *net, const char *pat)
|
||||
{
|
||||
int err;
|
||||
int err, new_nsid;
|
||||
|
||||
ASSERT_RTNL();
|
||||
|
||||
@@ -8347,7 +8348,11 @@ int dev_change_net_namespace(struct net_device *dev, struct net *net, const char
|
||||
call_netdevice_notifiers(NETDEV_UNREGISTER, dev);
|
||||
rcu_barrier();
|
||||
call_netdevice_notifiers(NETDEV_UNREGISTER_FINAL, dev);
|
||||
rtmsg_ifinfo(RTM_DELLINK, dev, ~0U, GFP_KERNEL);
|
||||
if (dev->rtnl_link_ops && dev->rtnl_link_ops->get_link_net)
|
||||
new_nsid = peernet2id_alloc(dev_net(dev), net);
|
||||
else
|
||||
new_nsid = peernet2id(dev_net(dev), net);
|
||||
rtmsg_ifinfo_newnet(RTM_DELLINK, dev, ~0U, GFP_KERNEL, &new_nsid);
|
||||
|
||||
/*
|
||||
* Flush the unicast and multicast chains
|
||||
|
Reference in New Issue
Block a user