net: dsa: b53: Add JOIN_ALL_VLAN support
In order to migrate the bcm_sf2 driver over to the b53 driver for most VLAN/FDB/bridge operations, we need to add support for the "join all VLANs" register and behavior which allows us to make a given port join all VLANs and avoid setting specific VLAN entries when it is leaving the bridge. Signed-off-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
bde5d132c3
commit
48aea33a77
|
@ -1315,9 +1315,21 @@ static int b53_br_join(struct dsa_switch *ds, int port,
|
||||||
struct net_device *bridge)
|
struct net_device *bridge)
|
||||||
{
|
{
|
||||||
struct b53_device *dev = ds_to_priv(ds);
|
struct b53_device *dev = ds_to_priv(ds);
|
||||||
|
s8 cpu_port = ds->dst->cpu_port;
|
||||||
u16 pvlan, reg;
|
u16 pvlan, reg;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
|
/* Make this port leave the all VLANs join since we will have proper
|
||||||
|
* VLAN entries from now on
|
||||||
|
*/
|
||||||
|
if (is58xx(dev)) {
|
||||||
|
b53_read16(dev, B53_VLAN_PAGE, B53_JOIN_ALL_VLAN_EN, ®);
|
||||||
|
reg &= ~BIT(port);
|
||||||
|
if ((reg & BIT(cpu_port)) == BIT(cpu_port))
|
||||||
|
reg &= ~BIT(cpu_port);
|
||||||
|
b53_write16(dev, B53_VLAN_PAGE, B53_JOIN_ALL_VLAN_EN, reg);
|
||||||
|
}
|
||||||
|
|
||||||
dev->ports[port].bridge_dev = bridge;
|
dev->ports[port].bridge_dev = bridge;
|
||||||
b53_read16(dev, B53_PVLAN_PAGE, B53_PVLAN_PORT_MASK(port), &pvlan);
|
b53_read16(dev, B53_PVLAN_PAGE, B53_PVLAN_PORT_MASK(port), &pvlan);
|
||||||
|
|
||||||
|
@ -1350,6 +1362,7 @@ static void b53_br_leave(struct dsa_switch *ds, int port)
|
||||||
struct b53_device *dev = ds_to_priv(ds);
|
struct b53_device *dev = ds_to_priv(ds);
|
||||||
struct net_device *bridge = dev->ports[port].bridge_dev;
|
struct net_device *bridge = dev->ports[port].bridge_dev;
|
||||||
struct b53_vlan *vl = &dev->vlans[0];
|
struct b53_vlan *vl = &dev->vlans[0];
|
||||||
|
s8 cpu_port = ds->dst->cpu_port;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
u16 pvlan, reg, pvid;
|
u16 pvlan, reg, pvid;
|
||||||
|
|
||||||
|
@ -1379,10 +1392,19 @@ static void b53_br_leave(struct dsa_switch *ds, int port)
|
||||||
else
|
else
|
||||||
pvid = 0;
|
pvid = 0;
|
||||||
|
|
||||||
b53_get_vlan_entry(dev, pvid, vl);
|
/* Make this port join all VLANs without VLAN entries */
|
||||||
vl->members |= BIT(port) | BIT(dev->cpu_port);
|
if (is58xx(dev)) {
|
||||||
vl->untag |= BIT(port) | BIT(dev->cpu_port);
|
b53_read16(dev, B53_VLAN_PAGE, B53_JOIN_ALL_VLAN_EN, ®);
|
||||||
b53_set_vlan_entry(dev, pvid, vl);
|
reg |= BIT(port);
|
||||||
|
if (!(reg & BIT(cpu_port)))
|
||||||
|
reg |= BIT(cpu_port);
|
||||||
|
b53_write16(dev, B53_VLAN_PAGE, B53_JOIN_ALL_VLAN_EN, reg);
|
||||||
|
} else {
|
||||||
|
b53_get_vlan_entry(dev, pvid, vl);
|
||||||
|
vl->members |= BIT(port) | BIT(dev->cpu_port);
|
||||||
|
vl->untag |= BIT(port) | BIT(dev->cpu_port);
|
||||||
|
b53_set_vlan_entry(dev, pvid, vl);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void b53_br_set_stp_state(struct dsa_switch *ds, int port,
|
static void b53_br_set_stp_state(struct dsa_switch *ds, int port,
|
||||||
|
|
|
@ -309,6 +309,9 @@
|
||||||
/* Port VLAN mask (16 bit) IMP port is always 8, also on 5325 & co */
|
/* Port VLAN mask (16 bit) IMP port is always 8, also on 5325 & co */
|
||||||
#define B53_PVLAN_PORT_MASK(i) ((i) * 2)
|
#define B53_PVLAN_PORT_MASK(i) ((i) * 2)
|
||||||
|
|
||||||
|
/* Join all VLANs register (16 bit) */
|
||||||
|
#define B53_JOIN_ALL_VLAN_EN 0x50
|
||||||
|
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
* 802.1Q Page Registers
|
* 802.1Q Page Registers
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
|
|
Loading…
Reference in New Issue