Skip to content

Commit bf361ad

Browse files
viviendavem330
authored andcommitted
net: bridge: check __vlan_vid_del for error
Since __vlan_del can return an error code, change its inner function __vlan_vid_del to return an eventual error from switchdev_port_obj_del. Signed-off-by: Vivien Didelot <[email protected]> Acked-by: Jiri Pirko <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 39797a2 commit bf361ad

File tree

1 file changed

+13
-4
lines changed

1 file changed

+13
-4
lines changed

net/bridge/br_vlan.c

Lines changed: 13 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -117,10 +117,11 @@ static int __vlan_add(struct net_port_vlans *v, u16 vid, u16 flags)
117117
return err;
118118
}
119119

120-
static void __vlan_vid_del(struct net_device *dev, struct net_bridge *br,
121-
u16 vid)
120+
static int __vlan_vid_del(struct net_device *dev, struct net_bridge *br,
121+
u16 vid)
122122
{
123123
const struct net_device_ops *ops = dev->netdev_ops;
124+
int err = 0;
124125

125126
/* If driver uses VLAN ndo ops, use 8021q to delete vid
126127
* on device, otherwise try switchdev ops to delete vid.
@@ -137,8 +138,12 @@ static void __vlan_vid_del(struct net_device *dev, struct net_bridge *br,
137138
},
138139
};
139140

140-
switchdev_port_obj_del(dev, &vlan_obj);
141+
err = switchdev_port_obj_del(dev, &vlan_obj);
142+
if (err == -EOPNOTSUPP)
143+
err = 0;
141144
}
145+
146+
return err;
142147
}
143148

144149
static int __vlan_del(struct net_port_vlans *v, u16 vid)
@@ -151,7 +156,11 @@ static int __vlan_del(struct net_port_vlans *v, u16 vid)
151156

152157
if (v->port_idx) {
153158
struct net_bridge_port *p = v->parent.port;
154-
__vlan_vid_del(p->dev, p->br, vid);
159+
int err;
160+
161+
err = __vlan_vid_del(p->dev, p->br, vid);
162+
if (err)
163+
return err;
155164
}
156165

157166
clear_bit(vid, v->vlan_bitmap);

0 commit comments

Comments
 (0)