|
@@ -147,7 +147,7 @@ static int __switchdev_port_attr_set(struct net_device *dev,
|
|
return ops->switchdev_port_attr_set(dev, attr, trans);
|
|
return ops->switchdev_port_attr_set(dev, attr, trans);
|
|
|
|
|
|
if (attr->flags & SWITCHDEV_F_NO_RECURSE)
|
|
if (attr->flags & SWITCHDEV_F_NO_RECURSE)
|
|
- return err;
|
|
|
|
|
|
+ goto done;
|
|
|
|
|
|
/* Switch device port(s) may be stacked under
|
|
/* Switch device port(s) may be stacked under
|
|
* bond/team/vlan dev, so recurse down to set attr on
|
|
* bond/team/vlan dev, so recurse down to set attr on
|
|
@@ -156,10 +156,17 @@ static int __switchdev_port_attr_set(struct net_device *dev,
|
|
|
|
|
|
netdev_for_each_lower_dev(dev, lower_dev, iter) {
|
|
netdev_for_each_lower_dev(dev, lower_dev, iter) {
|
|
err = __switchdev_port_attr_set(lower_dev, attr, trans);
|
|
err = __switchdev_port_attr_set(lower_dev, attr, trans);
|
|
|
|
+ if (err == -EOPNOTSUPP &&
|
|
|
|
+ attr->flags & SWITCHDEV_F_SKIP_EOPNOTSUPP)
|
|
|
|
+ continue;
|
|
if (err)
|
|
if (err)
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+done:
|
|
|
|
+ if (err == -EOPNOTSUPP && attr->flags & SWITCHDEV_F_SKIP_EOPNOTSUPP)
|
|
|
|
+ err = 0;
|
|
|
|
+
|
|
return err;
|
|
return err;
|
|
}
|
|
}
|
|
|
|
|