|
@@ -1957,7 +1957,8 @@ static int do_setvfinfo(struct net_device *dev, struct nlattr **tb)
|
|
|
return err;
|
|
|
}
|
|
|
|
|
|
-static int do_set_master(struct net_device *dev, int ifindex)
|
|
|
+static int do_set_master(struct net_device *dev, int ifindex,
|
|
|
+ struct netlink_ext_ack *extack)
|
|
|
{
|
|
|
struct net_device *upper_dev = netdev_master_upper_dev_get(dev);
|
|
|
const struct net_device_ops *ops;
|
|
@@ -1982,7 +1983,7 @@ static int do_set_master(struct net_device *dev, int ifindex)
|
|
|
return -EINVAL;
|
|
|
ops = upper_dev->netdev_ops;
|
|
|
if (ops->ndo_add_slave) {
|
|
|
- err = ops->ndo_add_slave(upper_dev, dev);
|
|
|
+ err = ops->ndo_add_slave(upper_dev, dev, extack);
|
|
|
if (err)
|
|
|
return err;
|
|
|
} else {
|
|
@@ -2115,7 +2116,7 @@ static int do_setlink(const struct sk_buff *skb,
|
|
|
}
|
|
|
|
|
|
if (tb[IFLA_MASTER]) {
|
|
|
- err = do_set_master(dev, nla_get_u32(tb[IFLA_MASTER]));
|
|
|
+ err = do_set_master(dev, nla_get_u32(tb[IFLA_MASTER]), extack);
|
|
|
if (err)
|
|
|
goto errout;
|
|
|
status |= DO_SETLINK_MODIFIED;
|
|
@@ -2753,7 +2754,8 @@ replay:
|
|
|
goto out_unregister;
|
|
|
}
|
|
|
if (tb[IFLA_MASTER]) {
|
|
|
- err = do_set_master(dev, nla_get_u32(tb[IFLA_MASTER]));
|
|
|
+ err = do_set_master(dev, nla_get_u32(tb[IFLA_MASTER]),
|
|
|
+ extack);
|
|
|
if (err)
|
|
|
goto out_unregister;
|
|
|
}
|