]> git.baikalelectronics.ru Git - kernel.git/commitdiff
net: dsa: microchip: lan937x: add support for configuing xMII register
authorArun Ramadoss <arun.ramadoss@microchip.com>
Sun, 24 Jul 2022 09:28:19 +0000 (14:58 +0530)
committerDavid S. Miller <davem@davemloft.net>
Wed, 27 Jul 2022 08:39:17 +0000 (09:39 +0100)
This patch add the common ksz_set_xmii function for ksz series switch
and update the lan937x code phylink mac config. The register address for
the ksz8795 is Port 5 Interface control 6 and for all other switch is
xMII Control 1.
The bit value for selecting the interface is same for
KSZ8795 and KSZ9893 are same. The bit values for KSZ9477 and lan973x are
same. So, this patch add the bit value for each switches in
ksz_chip_data and configure the registers based on the chip id.

Signed-off-by: Arun Ramadoss <arun.ramadoss@microchip.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/microchip/ksz_common.c
drivers/net/dsa/microchip/ksz_common.h
drivers/net/dsa/microchip/lan937x_main.c
drivers/net/dsa/microchip/lan937x_reg.h

index bcf61f815e1100ba57561dcf114f93a374ea978c..39b83b4d02ed1ff1b2911dc5415c792b07d18ea1 100644 (file)
@@ -292,6 +292,10 @@ static const u8 ksz8795_xmii_ctrl0[] = {
 };
 
 static const u8 ksz8795_xmii_ctrl1[] = {
+       [P_RGMII_SEL]                   = 3,
+       [P_GMII_SEL]                    = 2,
+       [P_RMII_SEL]                    = 1,
+       [P_MII_SEL]                     = 0,
        [P_GMII_1GBIT]                  = 1,
        [P_GMII_NOT_1GBIT]              = 0,
 };
@@ -389,6 +393,10 @@ static const u8 ksz9477_xmii_ctrl0[] = {
 };
 
 static const u8 ksz9477_xmii_ctrl1[] = {
+       [P_RGMII_SEL]                   = 0,
+       [P_RMII_SEL]                    = 1,
+       [P_GMII_SEL]                    = 2,
+       [P_MII_SEL]                     = 3,
        [P_GMII_1GBIT]                  = 0,
        [P_GMII_NOT_1GBIT]              = 1,
 };
@@ -1400,6 +1408,42 @@ static int ksz_max_mtu(struct dsa_switch *ds, int port)
        return dev->dev_ops->max_mtu(dev, port);
 }
 
+void ksz_set_xmii(struct ksz_device *dev, int port, phy_interface_t interface)
+{
+       const u8 *bitval = dev->info->xmii_ctrl1;
+       const u16 *regs = dev->info->regs;
+       u8 data8;
+
+       ksz_pread8(dev, port, regs[P_XMII_CTRL_1], &data8);
+
+       data8 &= ~P_MII_SEL_M;
+
+       switch (interface) {
+       case PHY_INTERFACE_MODE_MII:
+               data8 |= bitval[P_MII_SEL];
+               break;
+       case PHY_INTERFACE_MODE_RMII:
+               data8 |= bitval[P_RMII_SEL];
+               break;
+       case PHY_INTERFACE_MODE_GMII:
+               data8 |= bitval[P_GMII_SEL];
+               break;
+       case PHY_INTERFACE_MODE_RGMII:
+       case PHY_INTERFACE_MODE_RGMII_ID:
+       case PHY_INTERFACE_MODE_RGMII_TXID:
+       case PHY_INTERFACE_MODE_RGMII_RXID:
+               data8 |= bitval[P_RGMII_SEL];
+               break;
+       default:
+               dev_err(dev->dev, "Unsupported interface '%s' for port %d\n",
+                       phy_modes(interface), port);
+               return;
+       }
+
+       /* Write the updated value */
+       ksz_pwrite8(dev, port, regs[P_XMII_CTRL_1], data8);
+}
+
 static void ksz_phylink_mac_config(struct dsa_switch *ds, int port,
                                   unsigned int mode,
                                   const struct phylink_link_state *state)
index 71a344afbf1f176dc033941c11da64c8a72309bb..24044fc873fd4513726348d43b48835ed1cd13ee 100644 (file)
@@ -222,6 +222,10 @@ enum ksz_xmii_ctrl0 {
 };
 
 enum ksz_xmii_ctrl1 {
+       P_RGMII_SEL,
+       P_RMII_SEL,
+       P_GMII_SEL,
+       P_MII_SEL,
        P_GMII_1GBIT,
        P_GMII_NOT_1GBIT,
 };
@@ -313,6 +317,7 @@ void ksz_r_mib_stats64(struct ksz_device *dev, int port);
 void ksz_port_stp_state_set(struct dsa_switch *ds, int port, u8 state);
 bool ksz_get_gbit(struct ksz_device *dev, int port);
 void ksz_set_gbit(struct ksz_device *dev, int port, bool gbit);
+void ksz_set_xmii(struct ksz_device *dev, int port, phy_interface_t interface);
 extern const struct ksz_chip_data ksz_switch_chips[];
 
 /* Common register access functions */
@@ -489,6 +494,9 @@ static inline int is_lan937x(struct ksz_device *dev)
 #define P_MII_100MBIT_M                        BIT(4)
 
 #define P_GMII_1GBIT_M                 BIT(6)
+#define P_RGMII_ID_IG_ENABLE           BIT(4)
+#define P_RGMII_ID_EG_ENABLE           BIT(3)
+#define P_MII_SEL_M                    0x3
 
 /* Regmap tables generation */
 #define KSZ_SPI_OP_RD          3
index a2e648eacd1914f8eccee38360385f2807be1084..d86ffdf976b065eb09254b7d87932fb01224a499 100644 (file)
@@ -315,36 +315,6 @@ int lan937x_change_mtu(struct ksz_device *dev, int port, int new_mtu)
        return 0;
 }
 
-static void lan937x_mac_config(struct ksz_device *dev, int port,
-                              phy_interface_t interface)
-{
-       u8 data8;
-
-       ksz_pread8(dev, port, REG_PORT_XMII_CTRL_1, &data8);
-
-       /* clear MII selection & set it based on interface later */
-       data8 &= ~PORT_MII_SEL_M;
-
-       /* configure MAC based on interface */
-       switch (interface) {
-       case PHY_INTERFACE_MODE_MII:
-               ksz_set_gbit(dev, port, false);
-               data8 |= PORT_MII_SEL;
-               break;
-       case PHY_INTERFACE_MODE_RMII:
-               ksz_set_gbit(dev, port, false);
-               data8 |= PORT_RMII_SEL;
-               break;
-       default:
-               dev_err(dev->dev, "Unsupported interface '%s' for port %d\n",
-                       phy_modes(interface), port);
-               return;
-       }
-
-       /* Write the updated value */
-       ksz_pwrite8(dev, port, REG_PORT_XMII_CTRL_1, data8);
-}
-
 void lan937x_phylink_get_caps(struct ksz_device *dev, int port,
                              struct phylink_config *config)
 {
@@ -370,7 +340,7 @@ void lan937x_phylink_mac_config(struct ksz_device *dev, int port,
                return;
        }
 
-       lan937x_mac_config(dev, port, state->interface);
+       ksz_set_xmii(dev, port, state->interface);
 }
 
 int lan937x_setup(struct dsa_switch *ds)
index d5eb6dc3a739fe7d77866f785a24db75ecbc0dc5..a6cb3ca22dc334290a46102ee1ec935e000d9930 100644 (file)
 #define REG_PORT_T1_PHY_CTRL_BASE      0x0100
 
 /* 3 - xMII */
-#define REG_PORT_XMII_CTRL_0           0x0300
 #define PORT_SGMII_SEL                 BIT(7)
 #define PORT_GRXC_ENABLE               BIT(0)
 
-#define REG_PORT_XMII_CTRL_1           0x0301
 #define PORT_MII_SEL_EDGE              BIT(5)
-#define PORT_RGMII_ID_IG_ENABLE                BIT(4)
-#define PORT_RGMII_ID_EG_ENABLE                BIT(3)
-#define PORT_MII_MAC_MODE              BIT(2)
-#define PORT_MII_SEL_M                 0x3
-#define PORT_RGMII_SEL                 0x0
-#define PORT_RMII_SEL                  0x1
-#define PORT_MII_SEL                   0x2
 
 /* 4 - MAC */
 #define REG_PORT_MAC_CTRL_0            0x0400