]> git.baikalelectronics.ru Git - kernel.git/commitdiff
net: dsa: realtek: rtl8365mb: add RTL8367S support
authorLuiz Angelo Daros de Luca <luizluca@gmail.com>
Fri, 28 Jan 2022 06:05:06 +0000 (03:05 -0300)
committerDavid S. Miller <davem@davemloft.net>
Fri, 28 Jan 2022 15:02:49 +0000 (15:02 +0000)
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: Luiz Angelo Daros de Luca <luizluca@gmail.com>
Tested-by: Arınç ÜNAL <arinc.unal@arinc9.com>
Reviewed-by: Alvin Šipraga <alsi@bang-olufsen.dk>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/realtek/Kconfig
drivers/net/dsa/realtek/realtek-mdio.c
drivers/net/dsa/realtek/realtek-smi.c
drivers/net/dsa/realtek/rtl8365mb.c

index 553f696e74356bb95797cdb39141ed929f3b78ce..5242698143d9bc41987ddd3aeded03fa364e5097 100644 (file)
@@ -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"
index b82f96668218d1095e463e9e86caf66c6b284cbb..0c5f2bdced9d339d136efede9f01673cea737ab6 100644 (file)
@@ -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 */ },
 };
index 1ef147e55a4c52dd6f4ca25068bb5faa47837249..946fbbd7015384029405515be6caa56032a8ecd2 100644 (file)
@@ -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 */ },
 };
index d580afc04b8d6ad082d4fd49fdbfafd954921ab7..6974decf5ebef6ccd97f0491d432f99d82442ea8 100644 (file)
 #include "realtek.h"
 
 /* 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_ID_8365MB_VC    0x6367
+#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
+#define RTL8365MB_PHYADDRMAX           7
+#define RTL8365MB_NUM_PHYREGS          32
+#define RTL8365MB_PHYREGMAX            (RTL8365MB_NUM_PHYREGS - 1)
+/* 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:
-               dev_info(priv->dev,
-                        "found an RTL8365MB-VC switch (ver=0x%04x)\n",
-                        chip_ver);
+               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);