Commit d40f607c authored by Luiz Angelo Daros de Luca's avatar Luiz Angelo Daros de Luca Committed by David S. Miller
Browse files

net: dsa: realtek: rtl8365mb: add RTL8367S support



Realtek's RTL8367S, a 5+2 port 10/100/1000M Ethernet switch.
It shares the same driver family (RTL8367C) with other models
as the RTL8365MB-VC. Its compatible string is "realtek,rtl8367s".

It was tested only with MDIO interface (realtek-mdio), although it might
work out-of-the-box with SMI interface (using realtek-smi).

This patch was based on an unpublished patch from Alvin Šipraga
<alsi@bang-olufsen.dk>.

Signed-off-by: default avatarLuiz Angelo Daros de Luca <luizluca@gmail.com>
Tested-by: default avatarArınç ÜNAL <arinc.unal@arinc9.com>
Reviewed-by: default avatarAlvin Šipraga <alsi@bang-olufsen.dk>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 7fa8af30
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -32,7 +32,7 @@ config NET_DSA_REALTEK_RTL8365MB
	depends on NET_DSA_REALTEK_SMI || NET_DSA_REALTEK_MDIO
	select NET_DSA_TAG_RTL8_4
	help
	  Select to enable support for Realtek RTL8365MB
	  Select to enable support for Realtek RTL8365MB-VC and RTL8367S.

config NET_DSA_REALTEK_RTL8366RB
	tristate "Realtek RTL8366RB switch subdriver"
+1 −0
Original line number Diff line number Diff line
@@ -206,6 +206,7 @@ static const struct of_device_id realtek_mdio_of_match[] = {
#endif
#if IS_ENABLED(CONFIG_NET_DSA_REALTEK_RTL8365MB)
	{ .compatible = "realtek,rtl8365mb", .data = &rtl8365mb_variant, },
	{ .compatible = "realtek,rtl8367s", .data = &rtl8365mb_variant, },
#endif
	{ /* sentinel */ },
};
+4 −0
Original line number Diff line number Diff line
@@ -510,6 +510,10 @@ static const struct of_device_id realtek_smi_of_match[] = {
		.compatible = "realtek,rtl8365mb",
		.data = &rtl8365mb_variant,
	},
	{
		.compatible = "realtek,rtl8367s",
		.data = &rtl8365mb_variant,
	},
#endif
	{ /* sentinel */ },
};
+31 −11
Original line number Diff line number Diff line
@@ -103,14 +103,21 @@

/* Chip-specific data and limits */
#define RTL8365MB_CHIP_ID_8365MB_VC	0x6367
#define RTL8365MB_LEARN_LIMIT_MAX_8365MB_VC	2112
static const int rtl8365mb_extint_port_map[] = { -1, -1, -1, -1, -1, -1, 1 };
#define RTL8365MB_CHIP_VER_8365MB_VC	0x0040

#define RTL8365MB_CHIP_ID_8367S		0x6367
#define RTL8365MB_CHIP_VER_8367S	0x00A0

/* Family-specific data and limits */
#define RTL8365MB_PHYADDRMAX		7
#define RTL8365MB_NUM_PHYREGS		32
#define RTL8365MB_PHYREGMAX		(RTL8365MB_NUM_PHYREGS - 1)
#define RTL8365MB_MAX_NUM_PORTS  7
/* RTL8370MB and RTL8310SR, possibly suportable by this driver, have 10 ports */
#define RTL8365MB_MAX_NUM_PORTS		10
#define RTL8365MB_LEARN_LIMIT_MAX	2112

/* valid for all 6-port or less variants */
static const int rtl8365mb_extint_port_map[]  = { -1, -1, -1, -1, -1, -1, 1, 2, -1, -1};

/* Chip identification registers */
#define RTL8365MB_CHIP_ID_REG		0x1300
@@ -1966,9 +1973,22 @@ static int rtl8365mb_detect(struct realtek_priv *priv)

	switch (chip_id) {
	case RTL8365MB_CHIP_ID_8365MB_VC:
		switch (chip_ver) {
		case RTL8365MB_CHIP_VER_8365MB_VC:
			dev_info(priv->dev,
				 "found an RTL8365MB-VC switch (ver=0x%04x)\n",
				 chip_ver);
			break;
		case RTL8365MB_CHIP_VER_8367S:
			dev_info(priv->dev,
				 "found an RTL8367S switch (ver=0x%04x)\n",
				 chip_ver);
			break;
		default:
			dev_err(priv->dev, "unrecognized switch version (ver=0x%04x)",
				chip_ver);
			return -ENODEV;
		}

		priv->num_ports = RTL8365MB_MAX_NUM_PORTS;

@@ -1976,7 +1996,7 @@ static int rtl8365mb_detect(struct realtek_priv *priv)
		mb->chip_id = chip_id;
		mb->chip_ver = chip_ver;
		mb->port_mask = GENMASK(priv->num_ports - 1, 0);
		mb->learn_limit_max = RTL8365MB_LEARN_LIMIT_MAX_8365MB_VC;
		mb->learn_limit_max = RTL8365MB_LEARN_LIMIT_MAX;
		mb->jam_table = rtl8365mb_init_jam_8365mb_vc;
		mb->jam_size = ARRAY_SIZE(rtl8365mb_init_jam_8365mb_vc);