[PATCH 21/31] net: davinci_mdio: Use fallback clock rate

Sascha Hauer s.hauer at pengutronix.de
Wed May 28 04:45:33 PDT 2025


On AM62L There is a clock attached to the mdio block, but the TF-A
returns 0 for its rate. Use 256MHz as fallback rate when we don't find a
valid clock rate.

Signed-off-by: Sascha Hauer <s.hauer at pengutronix.de>
---
 drivers/net/davinci_mdio.c | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/drivers/net/davinci_mdio.c b/drivers/net/davinci_mdio.c
index 1186642e1337b603f541f6bdf19ac2d2792f4994..ca7cecd2c08488cfa7a12d9cf8947e27722b916c 100644
--- a/drivers/net/davinci_mdio.c
+++ b/drivers/net/davinci_mdio.c
@@ -112,17 +112,18 @@ static int cpsw_mdio_write(struct mii_bus *bus, int phy_id, int phy_reg, u16 val
 
 static void cpsw_mdio_init_clk(struct cpsw_mdio_priv *priv)
 {
-	u32 mdio_in, clk_div;
+	u32 mdio_in = 0, clk_div;
 	u32 bus_freq = 1000000;
 
 	of_property_read_u32(priv->dev->of_node, "bus_freq", &bus_freq);
 
 	priv->clk = clk_get_enabled(priv->dev, "fck");
-	if (IS_ERR(priv->clk))
-		mdio_in = 256000000;
-	else
+	if (!IS_ERR(priv->clk))
 		mdio_in = clk_get_rate(priv->clk);
 
+	if (mdio_in == 0)
+		mdio_in = 256000000;
+
 	clk_div = (mdio_in / bus_freq) - 1;
 	if (clk_div > CONTROL_MAX_DIV)
 		clk_div = CONTROL_MAX_DIV;

-- 
2.39.5




More information about the barebox mailing list