Skip to content

Commit cb9b902

Browse files
viviendavem330
authored andcommitted
net: dsa: mv88e6xxx: add STU capability
Some switch models have a STU (per VLAN port state database). Add a new capability flag to switches info, instead of checking their family. Also if the 6165 family has an STU, it must have a VTU, so add the MV88E6XXX_FLAG_VTU to its family flags. Signed-off-by: Vivien Didelot <[email protected]> Reviewed-by: Andrew Lunn <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 15d7d7d commit cb9b902

File tree

2 files changed

+16
-14
lines changed

2 files changed

+16
-14
lines changed

drivers/net/dsa/mv88e6xxx.c

Lines changed: 2 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -453,16 +453,6 @@ static bool mv88e6xxx_has_fid_reg(struct mv88e6xxx_priv_state *ps)
453453
return false;
454454
}
455455

456-
static bool mv88e6xxx_has_stu(struct mv88e6xxx_priv_state *ps)
457-
{
458-
/* Does the device have STU and dedicated SID registers for VTU ops? */
459-
if (mv88e6xxx_6097_family(ps) || mv88e6xxx_6165_family(ps) ||
460-
mv88e6xxx_6351_family(ps) || mv88e6xxx_6352_family(ps))
461-
return true;
462-
463-
return false;
464-
}
465-
466456
/* We expect the switch to perform auto negotiation if there is a real
467457
* phy. However, in the case of a fixed link phy, we force the port
468458
* settings from the fixed link settings.
@@ -1599,7 +1589,7 @@ static int _mv88e6xxx_vtu_getnext(struct mv88e6xxx_priv_state *ps,
15991589
next.fid |= ret & 0xf;
16001590
}
16011591

1602-
if (mv88e6xxx_has_stu(ps)) {
1592+
if (mv88e6xxx_has(ps, MV88E6XXX_FLAG_STU)) {
16031593
ret = _mv88e6xxx_reg_read(ps, REG_GLOBAL,
16041594
GLOBAL_VTU_SID);
16051595
if (ret < 0)
@@ -1686,7 +1676,7 @@ static int _mv88e6xxx_vtu_loadpurge(struct mv88e6xxx_priv_state *ps,
16861676
if (ret < 0)
16871677
return ret;
16881678

1689-
if (mv88e6xxx_has_stu(ps)) {
1679+
if (mv88e6xxx_has(ps, MV88E6XXX_FLAG_STU)) {
16901680
reg = entry->sid & GLOBAL_VTU_SID_MASK;
16911681
ret = _mv88e6xxx_reg_write(ps, REG_GLOBAL, GLOBAL_VTU_SID, reg);
16921682
if (ret < 0)

drivers/net/dsa/mv88e6xxx.h

Lines changed: 14 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -403,6 +403,12 @@ enum mv88e6xxx_cap {
403403
*/
404404
MV88E6XXX_CAP_SMI_PHY,
405405

406+
/* Per VLAN Spanning Tree Unit (STU).
407+
* The Port State database, if present, is accessed through VTU
408+
* operations and dedicated SID registers. See GLOBAL_VTU_SID.
409+
*/
410+
MV88E6XXX_CAP_STU,
411+
406412
/* Switch MAC/WoL/WoF register.
407413
* This requires an indirect access to set the switch MAC address
408414
* through GLOBAL2_SWITCH_MAC, otherwise GLOBAL_MAC_01, GLOBAL_MAC_23,
@@ -436,6 +442,7 @@ enum mv88e6xxx_cap {
436442
#define MV88E6XXX_FLAG_PPU BIT(MV88E6XXX_CAP_PPU)
437443
#define MV88E6XXX_FLAG_PPU_ACTIVE BIT(MV88E6XXX_CAP_PPU_ACTIVE)
438444
#define MV88E6XXX_FLAG_SMI_PHY BIT(MV88E6XXX_CAP_SMI_PHY)
445+
#define MV88E6XXX_FLAG_STU BIT(MV88E6XXX_CAP_STU)
439446
#define MV88E6XXX_FLAG_SWITCH_MAC BIT(MV88E6XXX_CAP_SWITCH_MAC_WOL_WOF)
440447
#define MV88E6XXX_FLAG_TEMP BIT(MV88E6XXX_CAP_TEMP)
441448
#define MV88E6XXX_FLAG_TEMP_LIMIT BIT(MV88E6XXX_CAP_TEMP_LIMIT)
@@ -451,12 +458,15 @@ enum mv88e6xxx_cap {
451458
#define MV88E6XXX_FLAGS_FAMILY_6097 \
452459
(MV88E6XXX_FLAG_ATU | \
453460
MV88E6XXX_FLAG_PPU | \
461+
MV88E6XXX_FLAG_STU | \
454462
MV88E6XXX_FLAG_VLANTABLE | \
455463
MV88E6XXX_FLAG_VTU)
456464

457465
#define MV88E6XXX_FLAGS_FAMILY_6165 \
458-
(MV88E6XXX_FLAG_SWITCH_MAC | \
459-
MV88E6XXX_FLAG_TEMP)
466+
(MV88E6XXX_FLAG_STU | \
467+
MV88E6XXX_FLAG_SWITCH_MAC | \
468+
MV88E6XXX_FLAG_TEMP | \
469+
MV88E6XXX_FLAG_VTU)
460470

461471
#define MV88E6XXX_FLAGS_FAMILY_6185 \
462472
(MV88E6XXX_FLAG_ATU | \
@@ -482,6 +492,7 @@ enum mv88e6xxx_cap {
482492
MV88E6XXX_FLAG_PORTSTATE | \
483493
MV88E6XXX_FLAG_PPU_ACTIVE | \
484494
MV88E6XXX_FLAG_SMI_PHY | \
495+
MV88E6XXX_FLAG_STU | \
485496
MV88E6XXX_FLAG_SWITCH_MAC | \
486497
MV88E6XXX_FLAG_TEMP | \
487498
MV88E6XXX_FLAG_VLANTABLE | \
@@ -494,6 +505,7 @@ enum mv88e6xxx_cap {
494505
MV88E6XXX_FLAG_PORTSTATE | \
495506
MV88E6XXX_FLAG_PPU_ACTIVE | \
496507
MV88E6XXX_FLAG_SMI_PHY | \
508+
MV88E6XXX_FLAG_STU | \
497509
MV88E6XXX_FLAG_SWITCH_MAC | \
498510
MV88E6XXX_FLAG_TEMP | \
499511
MV88E6XXX_FLAG_TEMP_LIMIT | \

0 commit comments

Comments
 (0)