]> Gentwo Git Trees - linux/.git/commitdiff
net: enetc: update the base address of port MDIO registers for ENETC v4
authorWei Fang <wei.fang@nxp.com>
Wed, 19 Nov 2025 10:25:57 +0000 (18:25 +0800)
committerJakub Kicinski <kuba@kernel.org>
Wed, 26 Nov 2025 01:44:48 +0000 (17:44 -0800)
Each ENETC has a set of external MDIO registers to access its external
PHY based on its port EMDIO bus, these registers are used for MDIO bus
access, such as setting the PHY address, PHY register address and value,
read or write operations, C22 or C45 format, etc. The base address of
this set of registers has been modified in ENETC v4 and is different
from that in ENETC v1. So the base address needs to be updated so that
ENETC v4 can use port MDIO to manage its own external PHY.

Additionally, if ENETC has the PCS layer, it also has a set of internal
MDIO registers for managing its on-die PHY (PCS/Serdes). The base address
of this set of registers is also different from that of ENETC v1, so the
base address also needs to be updated so that ENETC v4 can support the
management of on-die PHY through the internal MDIO bus.

Signed-off-by: Wei Fang <wei.fang@nxp.com>
Reviewed-by: Claudiu Manoil <claudiu.manoil@nxp.com>
Link: https://patch.msgid.link/20251119102557.1041881-4-wei.fang@nxp.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/freescale/enetc/enetc4_hw.h
drivers/net/ethernet/freescale/enetc/enetc_pf_common.c

index ebea4298791ce8d557720db1f92c6d01d1380c40..3ed0f7a02767983f3f7fbe52083b7cd928ee319e 100644 (file)
 /* Port MAC 0/1 Maximum Frame Length Register */
 #define ENETC4_PM_MAXFRM(mac)          (0x5014 + (mac) * 0x400)
 
+/* Port internal MDIO base address, use to access PCS */
+#define ENETC4_PM_IMDIO_BASE           0x5030
+
 /* Port MAC 0/1 Pause Quanta Register */
 #define ENETC4_PM_PAUSE_QUANTA(mac)    (0x5054 + (mac) * 0x400)
 
 #define   SSP_1G                       2
 #define  PM_IF_MODE_ENA                        BIT(15)
 
+/* Port external MDIO Base address, use to access off-chip PHY */
+#define ENETC4_EMDIO_BASE              0x5c00
+
 /**********************ENETC Pseudo MAC port registers************************/
 /* Port pseudo MAC receive octets counter (64-bit) */
 #define ENETC4_PPMROCR                 0x5080
index 9c634205e2a76a524478d5693c5884d864cba7a6..76263b8566bb3ee67f8bcce60b20aa642b7cc93d 100644 (file)
@@ -176,7 +176,12 @@ static int enetc_mdio_probe(struct enetc_pf *pf, struct device_node *np)
        bus->parent = dev;
        mdio_priv = bus->priv;
        mdio_priv->hw = &pf->si->hw;
-       mdio_priv->mdio_base = ENETC_EMDIO_BASE;
+
+       if (is_enetc_rev1(pf->si))
+               mdio_priv->mdio_base = ENETC_EMDIO_BASE;
+       else
+               mdio_priv->mdio_base = ENETC4_EMDIO_BASE;
+
        snprintf(bus->id, MII_BUS_ID_SIZE, "%s", dev_name(dev));
 
        err = of_mdiobus_register(bus, np);
@@ -221,7 +226,12 @@ static int enetc_imdio_create(struct enetc_pf *pf)
        bus->phy_mask = ~0;
        mdio_priv = bus->priv;
        mdio_priv->hw = &pf->si->hw;
-       mdio_priv->mdio_base = ENETC_PM_IMDIO_BASE;
+
+       if (is_enetc_rev1(pf->si))
+               mdio_priv->mdio_base = ENETC_PM_IMDIO_BASE;
+       else
+               mdio_priv->mdio_base = ENETC4_PM_IMDIO_BASE;
+
        snprintf(bus->id, MII_BUS_ID_SIZE, "%s-imdio", dev_name(dev));
 
        err = mdiobus_register(bus);