[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20240930215934.349238-1-rosenp@gmail.com>
Date: Mon, 30 Sep 2024 14:59:34 -0700
From: Rosen Penev <rosenp@...il.com>
To: linux-arm-kernel@...ts.infradead.org
Cc: andrew@...n.ch,
gregory.clement@...tlin.com,
sebastian.hesselbarth@...il.com,
linux@...linux.org.uk,
linux-kernel@...r.kernel.org
Subject: [PATCH] arch: arm: kirkwood: support nvmem mac address
of_get_ethdev_address gets called too early for nvmem. If EPROBE_DEFER
gets called, skip so that the ethernet driver can adjust the MAC address
through nvmem.
Signed-off-by: Rosen Penev <rosenp@...il.com>
---
arch/arm/mach-mvebu/kirkwood.c | 11 ++++++++---
1 file changed, 8 insertions(+), 3 deletions(-)
diff --git a/arch/arm/mach-mvebu/kirkwood.c b/arch/arm/mach-mvebu/kirkwood.c
index 73b2a86d6489..da347f66900b 100644
--- a/arch/arm/mach-mvebu/kirkwood.c
+++ b/arch/arm/mach-mvebu/kirkwood.c
@@ -86,13 +86,18 @@ static void __init kirkwood_dt_eth_fixup(void)
void __iomem *io;
u8 *macaddr;
u32 reg;
+ int err;
if (!pnp)
continue;
- /* skip disabled nodes or nodes with valid MAC address*/
- if (!of_device_is_available(pnp) ||
- !of_get_mac_address(np, tmpmac))
+ /* skip disabled nodes */
+ if (!of_device_is_available(pnp))
+ goto eth_fixup_skip;
+
+ /* skip nodes with valid MAC address*/
+ err = of_get_mac_address(np, tmpmac);
+ if (err == -EPROBE_DEFER || !err)
goto eth_fixup_skip;
clk = of_clk_get(pnp, 0);
--
2.46.2
Powered by blists - more mailing lists