mirror of
https://source.denx.de/u-boot/u-boot.git
synced 2026-05-04 20:26:13 +02:00
net: fsl_enetc: Enable optional ENETREF clock on i.MX95
The ENETCv4 port DT nodes on i.MX95 may contain optional clock phandle to IMX95_CLK_ENETREF "ref" clock. These "ref" clock must be enabled for the ethernet to work. These "ref" clock are enabled after cold boot, but when the system booted Linux and rebooted, those "ref" clock might have been disabled in the process, which would make ethernet inoperable after reboot. Make sure those "ref" clock are always correctly enabled. Signed-off-by: Marek Vasut <marex@denx.de>
This commit is contained in:
parent
07358b7ac6
commit
219b048820
@ -5,6 +5,7 @@
|
||||
* Copyright 2023-2025 NXP
|
||||
*/
|
||||
|
||||
#include <clk.h>
|
||||
#include <dm.h>
|
||||
#include <errno.h>
|
||||
#include <fdt_support.h>
|
||||
@ -981,11 +982,31 @@ static const struct eth_ops enetc_ops_imx = {
|
||||
.read_rom_hwaddr = enetc_read_rom_hwaddr,
|
||||
};
|
||||
|
||||
static int enetc_probe_imx(struct udevice *dev)
|
||||
{
|
||||
struct clk *clk;
|
||||
int ret;
|
||||
|
||||
clk = devm_clk_get_optional(dev, "ref");
|
||||
if (IS_ERR(clk))
|
||||
return PTR_ERR(clk);
|
||||
|
||||
ret = clk_enable(clk);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = enetc_probe(dev);
|
||||
if (ret)
|
||||
clk_disable(clk);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
U_BOOT_DRIVER(eth_enetc_imx) = {
|
||||
.name = ENETC_DRIVER_NAME,
|
||||
.id = UCLASS_ETH,
|
||||
.bind = enetc_bind,
|
||||
.probe = enetc_probe,
|
||||
.probe = enetc_probe_imx,
|
||||
.remove = enetc_remove,
|
||||
.ops = &enetc_ops_imx,
|
||||
.priv_auto = sizeof(struct enetc_priv),
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user