aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/addrconf.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/ipv6/addrconf.c')
-rw-r--r--net/ipv6/addrconf.c24
1 files changed, 14 insertions, 10 deletions
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c
index 18d43349013e..bde50c686722 100644
--- a/net/ipv6/addrconf.c
+++ b/net/ipv6/addrconf.c
@@ -456,13 +456,13 @@ static void dev_forward_change(struct inet6_dev *idev)
456} 456}
457 457
458 458
459static void addrconf_forward_change(void) 459static void addrconf_forward_change(struct net *net)
460{ 460{
461 struct net_device *dev; 461 struct net_device *dev;
462 struct inet6_dev *idev; 462 struct inet6_dev *idev;
463 463
464 read_lock(&dev_base_lock); 464 read_lock(&dev_base_lock);
465 for_each_netdev(&init_net, dev) { 465 for_each_netdev(net, dev) {
466 rcu_read_lock(); 466 rcu_read_lock();
467 idev = __in6_dev_get(dev); 467 idev = __in6_dev_get(dev);
468 if (idev) { 468 if (idev) {
@@ -478,12 +478,15 @@ static void addrconf_forward_change(void)
478 478
479static void addrconf_fixup_forwarding(struct ctl_table *table, int *p, int old) 479static void addrconf_fixup_forwarding(struct ctl_table *table, int *p, int old)
480{ 480{
481 struct net *net;
482
483 net = (struct net *)table->extra2;
481 if (p == &ipv6_devconf_dflt.forwarding) 484 if (p == &ipv6_devconf_dflt.forwarding)
482 return; 485 return;
483 486
484 if (p == &ipv6_devconf.forwarding) { 487 if (p == &ipv6_devconf.forwarding) {
485 ipv6_devconf_dflt.forwarding = ipv6_devconf.forwarding; 488 ipv6_devconf_dflt.forwarding = ipv6_devconf.forwarding;
486 addrconf_forward_change(); 489 addrconf_forward_change(net);
487 } else if ((!*p) ^ (!old)) 490 } else if ((!*p) ^ (!old))
488 dev_forward_change((struct inet6_dev *)table->extra1); 491 dev_forward_change((struct inet6_dev *)table->extra1);
489 492
@@ -4044,8 +4047,8 @@ static struct addrconf_sysctl_table
4044 }, 4047 },
4045}; 4048};
4046 4049
4047static int __addrconf_sysctl_register(char *dev_name, int ctl_name, 4050static int __addrconf_sysctl_register(struct net *net, char *dev_name,
4048 struct inet6_dev *idev, struct ipv6_devconf *p) 4051 int ctl_name, struct inet6_dev *idev, struct ipv6_devconf *p)
4049{ 4052{
4050 int i; 4053 int i;
4051 struct addrconf_sysctl_table *t; 4054 struct addrconf_sysctl_table *t;
@@ -4068,6 +4071,7 @@ static int __addrconf_sysctl_register(char *dev_name, int ctl_name,
4068 for (i=0; t->addrconf_vars[i].data; i++) { 4071 for (i=0; t->addrconf_vars[i].data; i++) {
4069 t->addrconf_vars[i].data += (char*)p - (char*)&ipv6_devconf; 4072 t->addrconf_vars[i].data += (char*)p - (char*)&ipv6_devconf;
4070 t->addrconf_vars[i].extra1 = idev; /* embedded; no ref */ 4073 t->addrconf_vars[i].extra1 = idev; /* embedded; no ref */
4074 t->addrconf_vars[i].extra2 = net;
4071 } 4075 }
4072 4076
4073 /* 4077 /*
@@ -4082,7 +4086,7 @@ static int __addrconf_sysctl_register(char *dev_name, int ctl_name,
4082 addrconf_ctl_path[ADDRCONF_CTL_PATH_DEV].procname = t->dev_name; 4086 addrconf_ctl_path[ADDRCONF_CTL_PATH_DEV].procname = t->dev_name;
4083 addrconf_ctl_path[ADDRCONF_CTL_PATH_DEV].ctl_name = ctl_name; 4087 addrconf_ctl_path[ADDRCONF_CTL_PATH_DEV].ctl_name = ctl_name;
4084 4088
4085 t->sysctl_header = register_sysctl_paths(addrconf_ctl_path, 4089 t->sysctl_header = register_net_sysctl_table(net, addrconf_ctl_path,
4086 t->addrconf_vars); 4090 t->addrconf_vars);
4087 if (t->sysctl_header == NULL) 4091 if (t->sysctl_header == NULL)
4088 goto free_procname; 4092 goto free_procname;
@@ -4118,8 +4122,8 @@ static void addrconf_sysctl_register(struct inet6_dev *idev)
4118 NET_IPV6_NEIGH, "ipv6", 4122 NET_IPV6_NEIGH, "ipv6",
4119 &ndisc_ifinfo_sysctl_change, 4123 &ndisc_ifinfo_sysctl_change,
4120 NULL); 4124 NULL);
4121 __addrconf_sysctl_register(idev->dev->name, idev->dev->ifindex, 4125 __addrconf_sysctl_register(idev->dev->nd_net, idev->dev->name,
4122 idev, &idev->cnf); 4126 idev->dev->ifindex, idev, &idev->cnf);
4123} 4127}
4124 4128
4125static void addrconf_sysctl_unregister(struct inet6_dev *idev) 4129static void addrconf_sysctl_unregister(struct inet6_dev *idev)
@@ -4215,9 +4219,9 @@ int __init addrconf_init(void)
4215 ipv6_addr_label_rtnl_register(); 4219 ipv6_addr_label_rtnl_register();
4216 4220
4217#ifdef CONFIG_SYSCTL 4221#ifdef CONFIG_SYSCTL
4218 __addrconf_sysctl_register("all", NET_PROTO_CONF_ALL, 4222 __addrconf_sysctl_register(&init_net, "all", NET_PROTO_CONF_ALL,
4219 NULL, &ipv6_devconf); 4223 NULL, &ipv6_devconf);
4220 __addrconf_sysctl_register("default", NET_PROTO_CONF_DEFAULT, 4224 __addrconf_sysctl_register(&init_net, "default", NET_PROTO_CONF_DEFAULT,
4221 NULL, &ipv6_devconf_dflt); 4225 NULL, &ipv6_devconf_dflt);
4222#endif 4226#endif
4223 4227