diff options
Diffstat (limited to 'net/bridge/br_ioctl.c')
| -rw-r--r-- | net/bridge/br_ioctl.c | 69 | 
1 files changed, 24 insertions, 45 deletions
diff --git a/net/bridge/br_ioctl.c b/net/bridge/br_ioctl.c index cb43312b846..a9a4a1b7863 100644 --- a/net/bridge/br_ioctl.c +++ b/net/bridge/br_ioctl.c @@ -85,13 +85,14 @@ static int get_fdb_entries(struct net_bridge *br, void __user *userbuf,  /* called with RTNL */  static int add_del_if(struct net_bridge *br, int ifindex, int isadd)  { +	struct net *net = dev_net(br->dev);  	struct net_device *dev;  	int ret; -	if (!capable(CAP_NET_ADMIN)) +	if (!ns_capable(net->user_ns, CAP_NET_ADMIN))  		return -EPERM; -	dev = __dev_get_by_index(dev_net(br->dev), ifindex); +	dev = __dev_get_by_index(net, ifindex);  	if (dev == NULL)  		return -EINVAL; @@ -106,7 +107,7 @@ static int add_del_if(struct net_bridge *br, int ifindex, int isadd)  /*   * Legacy ioctl's through SIOCDEVPRIVATE   * This interface is deprecated because it was too difficult to - * to do the translation for 32/64bit ioctl compatability. + * to do the translation for 32/64bit ioctl compatibility.   */  static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)  { @@ -178,46 +179,25 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)  	}  	case BRCTL_SET_BRIDGE_FORWARD_DELAY: -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM; -		spin_lock_bh(&br->lock); -		br->bridge_forward_delay = clock_t_to_jiffies(args[1]); -		if (br_is_root_bridge(br)) -			br->forward_delay = br->bridge_forward_delay; -		spin_unlock_bh(&br->lock); -		return 0; +		return br_set_forward_delay(br, args[1]);  	case BRCTL_SET_BRIDGE_HELLO_TIME: -	{ -		unsigned long t = clock_t_to_jiffies(args[1]); -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM; -		if (t < HZ) -			return -EINVAL; - -		spin_lock_bh(&br->lock); -		br->bridge_hello_time = t; -		if (br_is_root_bridge(br)) -			br->hello_time = br->bridge_hello_time; -		spin_unlock_bh(&br->lock); -		return 0; -	} +		return br_set_hello_time(br, args[1]);  	case BRCTL_SET_BRIDGE_MAX_AGE: -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM; -		spin_lock_bh(&br->lock); -		br->bridge_max_age = clock_t_to_jiffies(args[1]); -		if (br_is_root_bridge(br)) -			br->max_age = br->bridge_max_age; -		spin_unlock_bh(&br->lock); -		return 0; +		return br_set_max_age(br, args[1]);  	case BRCTL_SET_AGEING_TIME: -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM;  		br->ageing_time = clock_t_to_jiffies(args[1]); @@ -257,14 +237,14 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)  	}  	case BRCTL_SET_BRIDGE_STP_STATE: -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM;  		br_stp_set_enabled(br, args[1]);  		return 0;  	case BRCTL_SET_BRIDGE_PRIORITY: -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM;  		spin_lock_bh(&br->lock); @@ -275,19 +255,16 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)  	case BRCTL_SET_PORT_PRIORITY:  	{  		struct net_bridge_port *p; -		int ret = 0; +		int ret; -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM; -		if (args[2] >= (1<<(16-BR_PORT_BITS))) -			return -ERANGE; -  		spin_lock_bh(&br->lock);  		if ((p = br_get_port(br, args[1])) == NULL)  			ret = -EINVAL;  		else -			br_stp_set_port_priority(p, args[2]); +			ret = br_stp_set_port_priority(p, args[2]);  		spin_unlock_bh(&br->lock);  		return ret;  	} @@ -295,15 +272,17 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)  	case BRCTL_SET_PATH_COST:  	{  		struct net_bridge_port *p; -		int ret = 0; +		int ret; -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))  			return -EPERM; +		spin_lock_bh(&br->lock);  		if ((p = br_get_port(br, args[1])) == NULL)  			ret = -EINVAL;  		else -			br_stp_set_path_cost(p, args[2]); +			ret = br_stp_set_path_cost(p, args[2]); +		spin_unlock_bh(&br->lock);  		return ret;  	} @@ -352,7 +331,7 @@ static int old_deviceless(struct net *net, void __user *uarg)  	{  		char buf[IFNAMSIZ]; -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(net->user_ns, CAP_NET_ADMIN))  			return -EPERM;  		if (copy_from_user(buf, (void __user *)args[1], IFNAMSIZ)) @@ -382,7 +361,7 @@ int br_ioctl_deviceless_stub(struct net *net, unsigned int cmd, void __user *uar  	{  		char buf[IFNAMSIZ]; -		if (!capable(CAP_NET_ADMIN)) +		if (!ns_capable(net->user_ns, CAP_NET_ADMIN))  			return -EPERM;  		if (copy_from_user(buf, uarg, IFNAMSIZ)) @@ -402,7 +381,7 @@ int br_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)  {  	struct net_bridge *br = netdev_priv(dev); -	switch(cmd) { +	switch (cmd) {  	case SIOCDEVPRIVATE:  		return old_dev_ioctl(dev, rq, cmd);  | 
