mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-13 00:29:50 +00:00
bridge: a netlink notification should be sent when those attributes are changed by ioctl
Now when we change the attributes of bridge or br_port by netlink, a relevant netlink notification will be sent, but if we change them by ioctl or sysfs, no notification will be sent. We should ensure that whenever those attributes change internally or from sysfs/ioctl, that a netlink notification is sent out to listeners. Also, NetworkManager will use this in the future to listen for out-of-band bridge master attribute updates and incorporate them into the runtime configuration. This patch is used for ioctl. Signed-off-by: Xin Long <lucien.xin@gmail.com> Reviewed-by: Nikolay Aleksandrov <nikolay@cumulusnetworks.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
bdaf0d5d98
commit
bf871ad792
@ -112,7 +112,9 @@ static int add_del_if(struct net_bridge *br, int ifindex, int isadd)
|
||||
static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
||||
{
|
||||
struct net_bridge *br = netdev_priv(dev);
|
||||
struct net_bridge_port *p = NULL;
|
||||
unsigned long args[4];
|
||||
int ret = -EOPNOTSUPP;
|
||||
|
||||
if (copy_from_user(args, rq->ifr_data, sizeof(args)))
|
||||
return -EFAULT;
|
||||
@ -182,25 +184,29 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
||||
if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
return br_set_forward_delay(br, args[1]);
|
||||
ret = br_set_forward_delay(br, args[1]);
|
||||
break;
|
||||
|
||||
case BRCTL_SET_BRIDGE_HELLO_TIME:
|
||||
if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
return br_set_hello_time(br, args[1]);
|
||||
ret = br_set_hello_time(br, args[1]);
|
||||
break;
|
||||
|
||||
case BRCTL_SET_BRIDGE_MAX_AGE:
|
||||
if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
return br_set_max_age(br, args[1]);
|
||||
ret = br_set_max_age(br, args[1]);
|
||||
break;
|
||||
|
||||
case BRCTL_SET_AGEING_TIME:
|
||||
if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
return br_set_ageing_time(br, args[1]);
|
||||
ret = br_set_ageing_time(br, args[1]);
|
||||
break;
|
||||
|
||||
case BRCTL_GET_PORT_INFO:
|
||||
{
|
||||
@ -240,20 +246,19 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
||||
return -EPERM;
|
||||
|
||||
br_stp_set_enabled(br, args[1]);
|
||||
return 0;
|
||||
ret = 0;
|
||||
break;
|
||||
|
||||
case BRCTL_SET_BRIDGE_PRIORITY:
|
||||
if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
br_stp_set_bridge_priority(br, args[1]);
|
||||
return 0;
|
||||
ret = 0;
|
||||
break;
|
||||
|
||||
case BRCTL_SET_PORT_PRIORITY:
|
||||
{
|
||||
struct net_bridge_port *p;
|
||||
int ret;
|
||||
|
||||
if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
@ -263,14 +268,11 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
||||
else
|
||||
ret = br_stp_set_port_priority(p, args[2]);
|
||||
spin_unlock_bh(&br->lock);
|
||||
return ret;
|
||||
break;
|
||||
}
|
||||
|
||||
case BRCTL_SET_PATH_COST:
|
||||
{
|
||||
struct net_bridge_port *p;
|
||||
int ret;
|
||||
|
||||
if (!ns_capable(dev_net(dev)->user_ns, CAP_NET_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
@ -280,8 +282,7 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
||||
else
|
||||
ret = br_stp_set_path_cost(p, args[2]);
|
||||
spin_unlock_bh(&br->lock);
|
||||
|
||||
return ret;
|
||||
break;
|
||||
}
|
||||
|
||||
case BRCTL_GET_FDB_ENTRIES:
|
||||
@ -289,7 +290,14 @@ static int old_dev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
||||
args[2], args[3]);
|
||||
}
|
||||
|
||||
return -EOPNOTSUPP;
|
||||
if (!ret) {
|
||||
if (p)
|
||||
br_ifinfo_notify(RTM_NEWLINK, p);
|
||||
else
|
||||
netdev_state_change(br->dev);
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int old_deviceless(struct net *net, void __user *uarg)
|
||||
|
Loading…
x
Reference in New Issue
Block a user