Skip to content

Commit ca752be

Browse files
dsaherndavem330
authored andcommitted
net: bridge: Pass extack to down to netdev_master_upper_dev_link
Pass extack arg to br_add_if. Add messages for a couple of failures and pass arg to netdev_master_upper_dev_link. Signed-off-by: David Ahern <[email protected]> Acked-by: Stephen Hemminger <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 759088b commit ca752be

File tree

4 files changed

+15
-7
lines changed

4 files changed

+15
-7
lines changed

net/bridge/br_device.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -326,7 +326,7 @@ static int br_add_slave(struct net_device *dev, struct net_device *slave_dev,
326326
{
327327
struct net_bridge *br = netdev_priv(dev);
328328

329-
return br_add_if(br, slave_dev);
329+
return br_add_if(br, slave_dev, extack);
330330
}
331331

332332
static int br_del_slave(struct net_device *dev, struct net_device *slave_dev)

net/bridge/br_if.c

Lines changed: 11 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -480,7 +480,8 @@ netdev_features_t br_features_recompute(struct net_bridge *br,
480480
}
481481

482482
/* called with RTNL */
483-
int br_add_if(struct net_bridge *br, struct net_device *dev)
483+
int br_add_if(struct net_bridge *br, struct net_device *dev,
484+
struct netlink_ext_ack *extack)
484485
{
485486
struct net_bridge_port *p;
486487
int err = 0;
@@ -500,16 +501,22 @@ int br_add_if(struct net_bridge *br, struct net_device *dev)
500501
return -EINVAL;
501502

502503
/* No bridging of bridges */
503-
if (dev->netdev_ops->ndo_start_xmit == br_dev_xmit)
504+
if (dev->netdev_ops->ndo_start_xmit == br_dev_xmit) {
505+
NL_SET_ERR_MSG(extack,
506+
"Can not enslave a bridge to a bridge");
504507
return -ELOOP;
508+
}
505509

506510
/* Device is already being bridged */
507511
if (br_port_exists(dev))
508512
return -EBUSY;
509513

510514
/* No bridging devices that dislike that (e.g. wireless) */
511-
if (dev->priv_flags & IFF_DONT_BRIDGE)
515+
if (dev->priv_flags & IFF_DONT_BRIDGE) {
516+
NL_SET_ERR_MSG(extack,
517+
"Device does not allow enslaving to a bridge");
512518
return -EOPNOTSUPP;
519+
}
513520

514521
p = new_nbp(br, dev);
515522
if (IS_ERR(p))
@@ -540,7 +547,7 @@ int br_add_if(struct net_bridge *br, struct net_device *dev)
540547

541548
dev->priv_flags |= IFF_BRIDGE_PORT;
542549

543-
err = netdev_master_upper_dev_link(dev, br->dev, NULL, NULL, NULL);
550+
err = netdev_master_upper_dev_link(dev, br->dev, NULL, NULL, extack);
544551
if (err)
545552
goto err5;
546553

net/bridge/br_ioctl.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -98,7 +98,7 @@ static int add_del_if(struct net_bridge *br, int ifindex, int isadd)
9898
return -EINVAL;
9999

100100
if (isadd)
101-
ret = br_add_if(br, dev);
101+
ret = br_add_if(br, dev, NULL);
102102
else
103103
ret = br_del_if(br, dev);
104104

net/bridge/br_private.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -566,7 +566,8 @@ void br_flood(struct net_bridge *br, struct sk_buff *skb,
566566
void br_port_carrier_check(struct net_bridge_port *p);
567567
int br_add_bridge(struct net *net, const char *name);
568568
int br_del_bridge(struct net *net, const char *name);
569-
int br_add_if(struct net_bridge *br, struct net_device *dev);
569+
int br_add_if(struct net_bridge *br, struct net_device *dev,
570+
struct netlink_ext_ack *extack);
570571
int br_del_if(struct net_bridge *br, struct net_device *dev);
571572
int br_min_mtu(const struct net_bridge *br);
572573
netdev_features_t br_features_recompute(struct net_bridge *br,

0 commit comments

Comments
 (0)