]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
net: xfrm: Use link netns in newlink() of rtnl_link_ops
authorXiao Liang <shaw.leon@gmail.com>
Wed, 19 Feb 2025 12:50:35 +0000 (20:50 +0800)
committerJakub Kicinski <kuba@kernel.org>
Fri, 21 Feb 2025 23:28:03 +0000 (15:28 -0800)
When link_net is set, use it as link netns instead of dev_net(). This
prepares for rtnetlink core to create device in target netns directly,
in which case the two namespaces may be different.

Signed-off-by: Xiao Liang <shaw.leon@gmail.com>
Reviewed-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Link: https://patch.msgid.link/20250219125039.18024-10-shaw.leon@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/xfrm/xfrm_interface_core.c

index 5659a6cadd5193c1f69371232b962f17b109faea..622445f041d320bac077fcd85c7f7e0111f58717 100644 (file)
@@ -242,10 +242,9 @@ static void xfrmi_dev_free(struct net_device *dev)
        gro_cells_destroy(&xi->gro_cells);
 }
 
-static int xfrmi_create(struct net_device *dev)
+static int xfrmi_create(struct net *net, struct net_device *dev)
 {
        struct xfrm_if *xi = netdev_priv(dev);
-       struct net *net = dev_net(dev);
        struct xfrmi_net *xfrmn = net_generic(net, xfrmi_net_id);
        int err;
 
@@ -819,11 +818,12 @@ static int xfrmi_newlink(struct net_device *dev,
                         struct netlink_ext_ack *extack)
 {
        struct nlattr **data = params->data;
-       struct net *net = dev_net(dev);
        struct xfrm_if_parms p = {};
        struct xfrm_if *xi;
+       struct net *net;
        int err;
 
+       net = params->link_net ? : dev_net(dev);
        xfrmi_netlink_parms(data, &p);
        if (p.collect_md) {
                struct xfrmi_net *xfrmn = net_generic(net, xfrmi_net_id);
@@ -852,7 +852,7 @@ static int xfrmi_newlink(struct net_device *dev,
        xi->net = net;
        xi->dev = dev;
 
-       err = xfrmi_create(dev);
+       err = xfrmi_create(net, dev);
        return err;
 }