diff options
| author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-03-19 17:02:01 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-03-19 17:02:01 -0700 | 
| commit | 10ce3cc919f50c2043b41ca968b43c26a3672600 (patch) | |
| tree | ea409366a5208aced495bc0516a08b81fd43222e /net/ipv4/devinet.c | |
| parent | 24e3e5ae1e4c2a3a32f5b1f96b4e3fd721806acd (diff) | |
| parent | 5c6a7a62c130afef3d61c1dee153012231ff5cd9 (diff) | |
Merge branch 'next' into for-linus
Diffstat (limited to 'net/ipv4/devinet.c')
| -rw-r--r-- | net/ipv4/devinet.c | 7 | 
1 files changed, 6 insertions, 1 deletions
| diff --git a/net/ipv4/devinet.c b/net/ipv4/devinet.c index c6b5092f29a1..e41c40f48cfe 100644 --- a/net/ipv4/devinet.c +++ b/net/ipv4/devinet.c @@ -258,7 +258,7 @@ static struct in_device *inetdev_init(struct net_device *dev)  		ip_mc_up(in_dev);  	/* we can receive as soon as ip_ptr is set -- do this last */ -	RCU_INIT_POINTER(dev->ip_ptr, in_dev); +	rcu_assign_pointer(dev->ip_ptr, in_dev);  out:  	return in_dev;  out_kfree: @@ -1490,7 +1490,9 @@ static int devinet_conf_proc(ctl_table *ctl, int write,  			     void __user *buffer,  			     size_t *lenp, loff_t *ppos)  { +	int old_value = *(int *)ctl->data;  	int ret = proc_dointvec(ctl, write, buffer, lenp, ppos); +	int new_value = *(int *)ctl->data;  	if (write) {  		struct ipv4_devconf *cnf = ctl->extra1; @@ -1501,6 +1503,9 @@ static int devinet_conf_proc(ctl_table *ctl, int write,  		if (cnf == net->ipv4.devconf_dflt)  			devinet_copy_dflt_conf(net, i); +		if (i == IPV4_DEVCONF_ACCEPT_LOCAL - 1) +			if ((new_value == 0) && (old_value != 0)) +				rt_cache_flush(net, 0);  	}  	return ret; | 
