]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - net/bridge/br_vlan.c
bridge: add vlan filtering change notification
[karo-tx-linux.git] / net / bridge / br_vlan.c
index 1394da63614a1d8a325ef44d5fa17849b5d82294..190fb3372ab57e74a15a3439516819bdd29a3b42 100644 (file)
@@ -73,6 +73,7 @@ static int __vlan_vid_add(struct net_device *dev, struct net_bridge *br,
                          u16 vid, u16 flags)
 {
        struct switchdev_obj_port_vlan v = {
+               .obj.orig_dev = dev,
                .obj.id = SWITCHDEV_OBJ_ID_PORT_VLAN,
                .flags = flags,
                .vid_begin = vid,
@@ -120,6 +121,7 @@ static int __vlan_vid_del(struct net_device *dev, struct net_bridge *br,
                          u16 vid)
 {
        struct switchdev_obj_port_vlan v = {
+               .obj.orig_dev = dev,
                .obj.id = SWITCHDEV_OBJ_ID_PORT_VLAN,
                .vid_begin = vid,
                .vid_end = vid,
@@ -624,9 +626,21 @@ void br_recalculate_fwd_mask(struct net_bridge *br)
 
 int __br_vlan_filter_toggle(struct net_bridge *br, unsigned long val)
 {
+       struct switchdev_attr attr = {
+               .orig_dev = br->dev,
+               .id = SWITCHDEV_ATTR_ID_BRIDGE_VLAN_FILTERING,
+               .flags = SWITCHDEV_F_SKIP_EOPNOTSUPP,
+               .u.vlan_filtering = val,
+       };
+       int err;
+
        if (br->vlan_enabled == val)
                return 0;
 
+       err = switchdev_port_attr_set(br->dev, &attr);
+       if (err && err != -EOPNOTSUPP)
+               return err;
+
        br->vlan_enabled = val;
        br_manage_promisc(br);
        recalculate_group_addr(br);
@@ -637,13 +651,15 @@ int __br_vlan_filter_toggle(struct net_bridge *br, unsigned long val)
 
 int br_vlan_filter_toggle(struct net_bridge *br, unsigned long val)
 {
+       int err;
+
        if (!rtnl_trylock())
                return restart_syscall();
 
-       __br_vlan_filter_toggle(br, val);
+       err = __br_vlan_filter_toggle(br, val);
        rtnl_unlock();
 
-       return 0;
+       return err;
 }
 
 int __br_vlan_set_proto(struct net_bridge *br, __be16 proto)