mirror of
https://xff.cz/git/u-boot/
synced 2025-09-18 00:52:07 +02:00
net: dm: fec: Support phy-reset-post-delay property
As per Linux kernel DT binding doc: - phy-reset-post-delay : Post reset delay in milliseconds. If present then a delay of phy-reset-post-delay milliseconds will be observed after the phy-reset-gpios has been toggled. Can be omitted thus no delay is observed. Delay is in range of 1ms to 1000ms. Other delays are invalid. Signed-off-by: Andrejs Cainikovs <andrejs.cainikovs@netmodule.com> Reviewed-by: Anatolij Gustschin <agust@denx.de> Reviewed-by: Stefano Babic <sbabic@denx.de> Acked-by: Joe Hershberger <joe.hershberger@ni.com> Acked-by: Lukasz Majewski <lukma@denx.de>
This commit is contained in:
committed by
Anatolij Gustschin
parent
afbc31948a
commit
31d4045d4b
@@ -1309,6 +1309,8 @@ static void fec_gpio_reset(struct fec_priv *priv)
|
|||||||
dm_gpio_set_value(&priv->phy_reset_gpio, 1);
|
dm_gpio_set_value(&priv->phy_reset_gpio, 1);
|
||||||
mdelay(priv->reset_delay);
|
mdelay(priv->reset_delay);
|
||||||
dm_gpio_set_value(&priv->phy_reset_gpio, 0);
|
dm_gpio_set_value(&priv->phy_reset_gpio, 0);
|
||||||
|
if (priv->reset_post_delay)
|
||||||
|
mdelay(priv->reset_post_delay);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@@ -1468,6 +1470,15 @@ static int fecmxc_ofdata_to_platdata(struct udevice *dev)
|
|||||||
/* property value wrong, use default value */
|
/* property value wrong, use default value */
|
||||||
priv->reset_delay = 1;
|
priv->reset_delay = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
priv->reset_post_delay = dev_read_u32_default(dev,
|
||||||
|
"phy-reset-post-delay",
|
||||||
|
0);
|
||||||
|
if (priv->reset_post_delay > 1000) {
|
||||||
|
printf("FEC MXC: phy reset post delay should be <= 1000ms\n");
|
||||||
|
/* property value wrong, use default value */
|
||||||
|
priv->reset_post_delay = 0;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@@ -258,6 +258,7 @@ struct fec_priv {
|
|||||||
#ifdef CONFIG_DM_GPIO
|
#ifdef CONFIG_DM_GPIO
|
||||||
struct gpio_desc phy_reset_gpio;
|
struct gpio_desc phy_reset_gpio;
|
||||||
uint32_t reset_delay;
|
uint32_t reset_delay;
|
||||||
|
uint32_t reset_post_delay;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_DM_ETH
|
#ifdef CONFIG_DM_ETH
|
||||||
u32 interface;
|
u32 interface;
|
||||||
|
Reference in New Issue
Block a user