1 From 651c9e71ffe44e99b5a9b011271c2117f0353b32 Mon Sep 17 00:00:00 2001
2 From: =?UTF-8?q?=C3=81lvaro=20Fern=C3=A1ndez=20Rojas?= <noltari@gmail.com>
3 Date: Sat, 14 Jun 2025 09:59:58 +0200
4 Subject: [PATCH] net: dsa: b53: fix unicast/multicast flooding on BCM5325
6 Content-Type: text/plain; charset=UTF-8
7 Content-Transfer-Encoding: 8bit
9 BCM5325 doesn't implement UC_FLOOD_MASK, MC_FLOOD_MASK and IPMC_FLOOD_MASK
11 This has to be handled differently with other pages and registers.
13 Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com>
14 Reviewed-by: Florian Fainelli <florian.fainelli@broadcom.com>
15 Link: https://patch.msgid.link/20250614080000.1884236-13-noltari@gmail.com
16 Signed-off-by: Jakub Kicinski <kuba@kernel.org>
18 drivers/net/dsa/b53/b53_common.c | 60 ++++++++++++++++++++++----------
19 drivers/net/dsa/b53/b53_regs.h | 13 +++++++
20 2 files changed, 55 insertions(+), 18 deletions(-)
22 --- a/drivers/net/dsa/b53/b53_common.c
23 +++ b/drivers/net/dsa/b53/b53_common.c
24 @@ -564,12 +564,24 @@ static void b53_port_set_ucast_flood(str
28 - b53_read16(dev, B53_CTRL_PAGE, B53_UC_FLOOD_MASK, &uc);
33 - b53_write16(dev, B53_CTRL_PAGE, B53_UC_FLOOD_MASK, uc);
35 + if (port == B53_CPU_PORT_25)
36 + port = B53_CPU_PORT;
38 + b53_read16(dev, B53_IEEE_PAGE, B53_IEEE_UCAST_DLF, &uc);
40 + uc |= BIT(port) | B53_IEEE_UCAST_DROP_EN;
43 + b53_write16(dev, B53_IEEE_PAGE, B53_IEEE_UCAST_DLF, uc);
45 + b53_read16(dev, B53_CTRL_PAGE, B53_UC_FLOOD_MASK, &uc);
50 + b53_write16(dev, B53_CTRL_PAGE, B53_UC_FLOOD_MASK, uc);
54 static void b53_port_set_mcast_flood(struct b53_device *dev, int port,
55 @@ -577,19 +589,31 @@ static void b53_port_set_mcast_flood(str
59 - b53_read16(dev, B53_CTRL_PAGE, B53_MC_FLOOD_MASK, &mc);
64 - b53_write16(dev, B53_CTRL_PAGE, B53_MC_FLOOD_MASK, mc);
66 - b53_read16(dev, B53_CTRL_PAGE, B53_IPMC_FLOOD_MASK, &mc);
71 - b53_write16(dev, B53_CTRL_PAGE, B53_IPMC_FLOOD_MASK, mc);
73 + if (port == B53_CPU_PORT_25)
74 + port = B53_CPU_PORT;
76 + b53_read16(dev, B53_IEEE_PAGE, B53_IEEE_MCAST_DLF, &mc);
78 + mc |= BIT(port) | B53_IEEE_MCAST_DROP_EN;
81 + b53_write16(dev, B53_IEEE_PAGE, B53_IEEE_MCAST_DLF, mc);
83 + b53_read16(dev, B53_CTRL_PAGE, B53_MC_FLOOD_MASK, &mc);
88 + b53_write16(dev, B53_CTRL_PAGE, B53_MC_FLOOD_MASK, mc);
90 + b53_read16(dev, B53_CTRL_PAGE, B53_IPMC_FLOOD_MASK, &mc);
95 + b53_write16(dev, B53_CTRL_PAGE, B53_IPMC_FLOOD_MASK, mc);
99 static void b53_port_set_learning(struct b53_device *dev, int port,
100 --- a/drivers/net/dsa/b53/b53_regs.h
101 +++ b/drivers/net/dsa/b53/b53_regs.h
103 #define B53_ARLIO_PAGE 0x05 /* ARL Access */
104 #define B53_FRAMEBUF_PAGE 0x06 /* Management frame access */
105 #define B53_MEM_ACCESS_PAGE 0x08 /* Memory access */
106 +#define B53_IEEE_PAGE 0x0a /* IEEE 802.1X */
109 #define B53_PORT_MII_PAGE(i) (0x10 + (i)) /* Port i MII Registers */
111 #define B53_ARL_SRCH_RSTL(x) (B53_ARL_SRCH_RSTL_0 + ((x) * 0x10))
113 /*************************************************************************
114 + * IEEE 802.1X Registers
115 + *************************************************************************/
117 +/* Multicast DLF Drop Control register (16 bit) */
118 +#define B53_IEEE_MCAST_DLF 0x94
119 +#define B53_IEEE_MCAST_DROP_EN BIT(11)
121 +/* Unicast DLF Drop Control register (16 bit) */
122 +#define B53_IEEE_UCAST_DLF 0x96
123 +#define B53_IEEE_UCAST_DROP_EN BIT(11)
125 +/*************************************************************************
126 * Port VLAN Registers
127 *************************************************************************/