Commit a9c31741 authored by Frank Wunderlich's avatar Frank Wunderlich Committed by Jakub Kicinski

net: dsa: mt7530: rework mt7530_hw_vlan_{add,del}

Rework vlan_add/vlan_del functions in preparation for dynamic cpu port.

Currently BIT(MT7530_CPU_PORT) is added to new_members, even though
mt7530_port_vlan_add() will be called on the CPU port too.

Let DSA core decide when to call port_vlan_add for the CPU port, rather
than doing it implicitly.

We can do autonomous forwarding in a certain VLAN, but not add br0 to that
VLAN and avoid flooding the CPU with those packets, if software knows it
doesn't need to process them.
Suggested-by: default avatarVladimir Oltean <olteanv@gmail.com>
Signed-off-by: default avatarFrank Wunderlich <frank-w@public-files.de>
Reviewed-by: default avatarVladimir Oltean <olteanv@gmail.com>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent e0dda311
...@@ -1527,11 +1527,11 @@ static void ...@@ -1527,11 +1527,11 @@ static void
mt7530_hw_vlan_add(struct mt7530_priv *priv, mt7530_hw_vlan_add(struct mt7530_priv *priv,
struct mt7530_hw_vlan_entry *entry) struct mt7530_hw_vlan_entry *entry)
{ {
struct dsa_port *dp = dsa_to_port(priv->ds, entry->port);
u8 new_members; u8 new_members;
u32 val; u32 val;
new_members = entry->old_members | BIT(entry->port) | new_members = entry->old_members | BIT(entry->port);
BIT(MT7530_CPU_PORT);
/* Validate the entry with independent learning, create egress tag per /* Validate the entry with independent learning, create egress tag per
* VLAN and joining the port as one of the port members. * VLAN and joining the port as one of the port members.
...@@ -1542,22 +1542,20 @@ mt7530_hw_vlan_add(struct mt7530_priv *priv, ...@@ -1542,22 +1542,20 @@ mt7530_hw_vlan_add(struct mt7530_priv *priv,
/* Decide whether adding tag or not for those outgoing packets from the /* Decide whether adding tag or not for those outgoing packets from the
* port inside the VLAN. * port inside the VLAN.
*/ * CPU port is always taken as a tagged port for serving more than one
val = entry->untagged ? MT7530_VLAN_EGRESS_UNTAG :
MT7530_VLAN_EGRESS_TAG;
mt7530_rmw(priv, MT7530_VAWD2,
ETAG_CTRL_P_MASK(entry->port),
ETAG_CTRL_P(entry->port, val));
/* CPU port is always taken as a tagged port for serving more than one
* VLANs across and also being applied with egress type stack mode for * VLANs across and also being applied with egress type stack mode for
* that VLAN tags would be appended after hardware special tag used as * that VLAN tags would be appended after hardware special tag used as
* DSA tag. * DSA tag.
*/ */
if (dsa_port_is_cpu(dp))
val = MT7530_VLAN_EGRESS_STACK;
else if (entry->untagged)
val = MT7530_VLAN_EGRESS_UNTAG;
else
val = MT7530_VLAN_EGRESS_TAG;
mt7530_rmw(priv, MT7530_VAWD2, mt7530_rmw(priv, MT7530_VAWD2,
ETAG_CTRL_P_MASK(MT7530_CPU_PORT), ETAG_CTRL_P_MASK(entry->port),
ETAG_CTRL_P(MT7530_CPU_PORT, ETAG_CTRL_P(entry->port, val));
MT7530_VLAN_EGRESS_STACK));
} }
static void static void
...@@ -1576,11 +1574,7 @@ mt7530_hw_vlan_del(struct mt7530_priv *priv, ...@@ -1576,11 +1574,7 @@ mt7530_hw_vlan_del(struct mt7530_priv *priv,
return; return;
} }
/* If certain member apart from CPU port is still alive in the VLAN, if (new_members) {
* the entry would be kept valid. Otherwise, the entry is got to be
* disabled.
*/
if (new_members && new_members != BIT(MT7530_CPU_PORT)) {
val = IVL_MAC | VTAG_EN | PORT_MEM(new_members) | val = IVL_MAC | VTAG_EN | PORT_MEM(new_members) |
VLAN_VALID; VLAN_VALID;
mt7530_write(priv, MT7530_VAWD1, val); mt7530_write(priv, MT7530_VAWD1, val);
......
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