mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-19 02:54:00 +08:00
PIM-SM: namespace changes
IPv4: - make PIM register vifs netns local - set the netns when a PIM register vif is created - make PIM available in all network namespaces (if CONFIG_IP_PIMSM_V2) by adding the protocol handler when multicast routing is initialized IPv6: - make PIM register vifs netns local - make PIM available in all network namespaces (if CONFIG_IPV6_PIMSM_V2) by adding the protocol handler when multicast routing is initialized Signed-off-by: Tom Goff <thomas.goff@boeing.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e61a4b634a
commit
403dbb97f6
@ -226,9 +226,10 @@ static void reg_vif_setup(struct net_device *dev)
|
|||||||
dev->flags = IFF_NOARP;
|
dev->flags = IFF_NOARP;
|
||||||
dev->netdev_ops = ®_vif_netdev_ops,
|
dev->netdev_ops = ®_vif_netdev_ops,
|
||||||
dev->destructor = free_netdev;
|
dev->destructor = free_netdev;
|
||||||
|
dev->features |= NETIF_F_NETNS_LOCAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct net_device *ipmr_reg_vif(void)
|
static struct net_device *ipmr_reg_vif(struct net *net)
|
||||||
{
|
{
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
struct in_device *in_dev;
|
struct in_device *in_dev;
|
||||||
@ -238,6 +239,8 @@ static struct net_device *ipmr_reg_vif(void)
|
|||||||
if (dev == NULL)
|
if (dev == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
dev_net_set(dev, net);
|
||||||
|
|
||||||
if (register_netdevice(dev)) {
|
if (register_netdevice(dev)) {
|
||||||
free_netdev(dev);
|
free_netdev(dev);
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -448,7 +451,7 @@ static int vif_add(struct net *net, struct vifctl *vifc, int mrtsock)
|
|||||||
*/
|
*/
|
||||||
if (net->ipv4.mroute_reg_vif_num >= 0)
|
if (net->ipv4.mroute_reg_vif_num >= 0)
|
||||||
return -EADDRINUSE;
|
return -EADDRINUSE;
|
||||||
dev = ipmr_reg_vif();
|
dev = ipmr_reg_vif(net);
|
||||||
if (!dev)
|
if (!dev)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
err = dev_set_allmulti(dev, 1);
|
err = dev_set_allmulti(dev, 1);
|
||||||
@ -1031,16 +1034,6 @@ int ip_mroute_setsockopt(struct sock *sk, int optname, char __user *optval, int
|
|||||||
if (v != net->ipv4.mroute_do_pim) {
|
if (v != net->ipv4.mroute_do_pim) {
|
||||||
net->ipv4.mroute_do_pim = v;
|
net->ipv4.mroute_do_pim = v;
|
||||||
net->ipv4.mroute_do_assert = v;
|
net->ipv4.mroute_do_assert = v;
|
||||||
#ifdef CONFIG_IP_PIMSM_V2
|
|
||||||
if (net->ipv4.mroute_do_pim)
|
|
||||||
ret = inet_add_protocol(&pim_protocol,
|
|
||||||
IPPROTO_PIM);
|
|
||||||
else
|
|
||||||
ret = inet_del_protocol(&pim_protocol,
|
|
||||||
IPPROTO_PIM);
|
|
||||||
if (ret < 0)
|
|
||||||
ret = -EAGAIN;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
rtnl_unlock();
|
rtnl_unlock();
|
||||||
return ret;
|
return ret;
|
||||||
@ -1954,6 +1947,7 @@ static const struct file_operations ipmr_mfc_fops = {
|
|||||||
#ifdef CONFIG_IP_PIMSM_V2
|
#ifdef CONFIG_IP_PIMSM_V2
|
||||||
static struct net_protocol pim_protocol = {
|
static struct net_protocol pim_protocol = {
|
||||||
.handler = pim_rcv,
|
.handler = pim_rcv,
|
||||||
|
.netns_ok = 1,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2040,8 +2034,19 @@ int __init ip_mr_init(void)
|
|||||||
err = register_netdevice_notifier(&ip_mr_notifier);
|
err = register_netdevice_notifier(&ip_mr_notifier);
|
||||||
if (err)
|
if (err)
|
||||||
goto reg_notif_fail;
|
goto reg_notif_fail;
|
||||||
|
#ifdef CONFIG_IP_PIMSM_V2
|
||||||
|
if (inet_add_protocol(&pim_protocol, IPPROTO_PIM) < 0) {
|
||||||
|
printk(KERN_ERR "ip_mr_init: can't add PIM protocol\n");
|
||||||
|
err = -EAGAIN;
|
||||||
|
goto add_proto_fail;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
#ifdef CONFIG_IP_PIMSM_V2
|
||||||
|
add_proto_fail:
|
||||||
|
unregister_netdevice_notifier(&ip_mr_notifier);
|
||||||
|
#endif
|
||||||
reg_notif_fail:
|
reg_notif_fail:
|
||||||
del_timer(&ipmr_expire_timer);
|
del_timer(&ipmr_expire_timer);
|
||||||
unregister_pernet_subsys(&ipmr_net_ops);
|
unregister_pernet_subsys(&ipmr_net_ops);
|
||||||
|
@ -441,6 +441,7 @@ static void reg_vif_setup(struct net_device *dev)
|
|||||||
dev->flags = IFF_NOARP;
|
dev->flags = IFF_NOARP;
|
||||||
dev->netdev_ops = ®_vif_netdev_ops;
|
dev->netdev_ops = ®_vif_netdev_ops;
|
||||||
dev->destructor = free_netdev;
|
dev->destructor = free_netdev;
|
||||||
|
dev->features |= NETIF_F_NETNS_LOCAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct net_device *ip6mr_reg_vif(struct net *net)
|
static struct net_device *ip6mr_reg_vif(struct net *net)
|
||||||
@ -1077,7 +1078,18 @@ int __init ip6_mr_init(void)
|
|||||||
err = register_netdevice_notifier(&ip6_mr_notifier);
|
err = register_netdevice_notifier(&ip6_mr_notifier);
|
||||||
if (err)
|
if (err)
|
||||||
goto reg_notif_fail;
|
goto reg_notif_fail;
|
||||||
|
#ifdef CONFIG_IPV6_PIMSM_V2
|
||||||
|
if (inet6_add_protocol(&pim6_protocol, IPPROTO_PIM) < 0) {
|
||||||
|
printk(KERN_ERR "ip6_mr_init: can't add PIM protocol\n");
|
||||||
|
err = -EAGAIN;
|
||||||
|
goto add_proto_fail;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
|
#ifdef CONFIG_IPV6_PIMSM_V2
|
||||||
|
add_proto_fail:
|
||||||
|
unregister_netdevice_notifier(&ip6_mr_notifier);
|
||||||
|
#endif
|
||||||
reg_notif_fail:
|
reg_notif_fail:
|
||||||
del_timer(&ipmr_expire_timer);
|
del_timer(&ipmr_expire_timer);
|
||||||
unregister_pernet_subsys(&ip6mr_net_ops);
|
unregister_pernet_subsys(&ip6mr_net_ops);
|
||||||
@ -1363,14 +1375,6 @@ int ip6_mroute_setsockopt(struct sock *sk, int optname, char __user *optval, int
|
|||||||
if (v != net->ipv6.mroute_do_pim) {
|
if (v != net->ipv6.mroute_do_pim) {
|
||||||
net->ipv6.mroute_do_pim = v;
|
net->ipv6.mroute_do_pim = v;
|
||||||
net->ipv6.mroute_do_assert = v;
|
net->ipv6.mroute_do_assert = v;
|
||||||
if (net->ipv6.mroute_do_pim)
|
|
||||||
ret = inet6_add_protocol(&pim6_protocol,
|
|
||||||
IPPROTO_PIM);
|
|
||||||
else
|
|
||||||
ret = inet6_del_protocol(&pim6_protocol,
|
|
||||||
IPPROTO_PIM);
|
|
||||||
if (ret < 0)
|
|
||||||
ret = -EAGAIN;
|
|
||||||
}
|
}
|
||||||
rtnl_unlock();
|
rtnl_unlock();
|
||||||
return ret;
|
return ret;
|
||||||
|
Loading…
Reference in New Issue
Block a user