]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
net: phy: dp83822: Configure RMII mode on DP83825 devices
authorErik Schumacher <erik.schumacher@iris-sensing.com>
Thu, 24 Oct 2024 13:24:23 +0000 (13:24 +0000)
committerPaolo Abeni <pabeni@redhat.com>
Thu, 31 Oct 2024 14:42:58 +0000 (15:42 +0100)
Like the DP83826, the DP83825 can also be configured as an RMII master or
slave via a control register. The existing function responsible for this
configuration is renamed to a general dp8382x function. The DP83825 only
supports RMII so nothing more needs to be configured.

With this change, the dp83822_driver list is reorganized according to the
device name.

Signed-off-by: Erik Schumacher <erik.schumacher@iris-sensing.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Link: https://patch.msgid.link/aa62d081804f44b5af0e8de2372ae6bfe1affd34.camel@iris-sensing.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
drivers/net/phy/dp83822.c

index 3ab64e04a01c9cbcb4109f5fb358270c525fb592..cf8b6d0bfaa9812eee98c612c0d4259d87da7572 100644 (file)
@@ -506,7 +506,7 @@ static int dp83822_config_init(struct phy_device *phydev)
        return dp83822_config_wol(phydev, &dp83822->wol);
 }
 
-static int dp83826_config_rmii_mode(struct phy_device *phydev)
+static int dp8382x_config_rmii_mode(struct phy_device *phydev)
 {
        struct device *dev = &phydev->mdio.dev;
        const char *of_val;
@@ -544,7 +544,7 @@ static int dp83826_config_init(struct phy_device *phydev)
                if (ret)
                        return ret;
 
-               ret = dp83826_config_rmii_mode(phydev);
+               ret = dp8382x_config_rmii_mode(phydev);
                if (ret)
                        return ret;
        } else {
@@ -585,9 +585,14 @@ static int dp83826_config_init(struct phy_device *phydev)
        return dp83822_config_wol(phydev, &dp83822->wol);
 }
 
-static int dp8382x_config_init(struct phy_device *phydev)
+static int dp83825_config_init(struct phy_device *phydev)
 {
        struct dp83822_private *dp83822 = phydev->priv;
+       int ret;
+
+       ret = dp8382x_config_rmii_mode(phydev);
+       if (ret)
+               return ret;
 
        return dp83822_config_wol(phydev, &dp83822->wol);
 }
@@ -782,14 +787,14 @@ static int dp83822_resume(struct phy_device *phydev)
                .resume = dp83822_resume,                       \
        }
 
-#define DP83826_PHY_DRIVER(_id, _name)                         \
+#define DP83825_PHY_DRIVER(_id, _name)                         \
        {                                                       \
                PHY_ID_MATCH_MODEL(_id),                        \
                .name           = (_name),                      \
                /* PHY_BASIC_FEATURES */                        \
-               .probe          = dp83826_probe,                \
+               .probe          = dp8382x_probe,                \
                .soft_reset     = dp83822_phy_reset,            \
-               .config_init    = dp83826_config_init,          \
+               .config_init    = dp83825_config_init,          \
                .get_wol = dp83822_get_wol,                     \
                .set_wol = dp83822_set_wol,                     \
                .config_intr = dp83822_config_intr,             \
@@ -798,14 +803,14 @@ static int dp83822_resume(struct phy_device *phydev)
                .resume = dp83822_resume,                       \
        }
 
-#define DP8382X_PHY_DRIVER(_id, _name)                         \
+#define DP83826_PHY_DRIVER(_id, _name)                         \
        {                                                       \
                PHY_ID_MATCH_MODEL(_id),                        \
                .name           = (_name),                      \
                /* PHY_BASIC_FEATURES */                        \
-               .probe          = dp8382x_probe,                \
+               .probe          = dp83826_probe,                \
                .soft_reset     = dp83822_phy_reset,            \
-               .config_init    = dp8382x_config_init,          \
+               .config_init    = dp83826_config_init,          \
                .get_wol = dp83822_get_wol,                     \
                .set_wol = dp83822_set_wol,                     \
                .config_intr = dp83822_config_intr,             \
@@ -816,12 +821,12 @@ static int dp83822_resume(struct phy_device *phydev)
 
 static struct phy_driver dp83822_driver[] = {
        DP83822_PHY_DRIVER(DP83822_PHY_ID, "TI DP83822"),
-       DP8382X_PHY_DRIVER(DP83825I_PHY_ID, "TI DP83825I"),
+       DP83825_PHY_DRIVER(DP83825I_PHY_ID, "TI DP83825I"),
+       DP83825_PHY_DRIVER(DP83825S_PHY_ID, "TI DP83825S"),
+       DP83825_PHY_DRIVER(DP83825CM_PHY_ID, "TI DP83825M"),
+       DP83825_PHY_DRIVER(DP83825CS_PHY_ID, "TI DP83825CS"),
        DP83826_PHY_DRIVER(DP83826C_PHY_ID, "TI DP83826C"),
        DP83826_PHY_DRIVER(DP83826NC_PHY_ID, "TI DP83826NC"),
-       DP8382X_PHY_DRIVER(DP83825S_PHY_ID, "TI DP83825S"),
-       DP8382X_PHY_DRIVER(DP83825CM_PHY_ID, "TI DP83825M"),
-       DP8382X_PHY_DRIVER(DP83825CS_PHY_ID, "TI DP83825CS"),
 };
 module_phy_driver(dp83822_driver);