Commit 3a7bde55 authored by Scott Feldman's avatar Scott Feldman Committed by David S. Miller

switchdev: fix: erasing too much of vlan obj when handling multiple vlan specs

When adding vlans with multiple IFLA_BRIDGE_VLAN_INFO attrs set in AFSPEC,
we would wipe the vlan obj struct after the first IFLA_BRIDGE_VLAN_INFO.
Fix this by only clearing what's necessary on each IFLA_BRIDGE_VLAN_INFO
iteration.

Fixes: 9e8f4a54 ("switchdev: push object ID back to object structure")
Signed-off-by: default avatarScott Feldman <sfeldma@gmail.com>
Acked-by: default avatarJiri Pirko <jiri@mellanox.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 740215dd
...@@ -869,7 +869,7 @@ static int switchdev_port_br_afspec(struct net_device *dev, ...@@ -869,7 +869,7 @@ static int switchdev_port_br_afspec(struct net_device *dev,
err = f(dev, &vlan.obj); err = f(dev, &vlan.obj);
if (err) if (err)
return err; return err;
memset(&vlan, 0, sizeof(vlan)); vlan.vid_begin = 0;
} else { } else {
if (vlan.vid_begin) if (vlan.vid_begin)
return -EINVAL; return -EINVAL;
...@@ -878,7 +878,7 @@ static int switchdev_port_br_afspec(struct net_device *dev, ...@@ -878,7 +878,7 @@ static int switchdev_port_br_afspec(struct net_device *dev,
err = f(dev, &vlan.obj); err = f(dev, &vlan.obj);
if (err) if (err)
return err; return err;
memset(&vlan, 0, sizeof(vlan)); vlan.vid_begin = 0;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment