aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/freescale/fec.c
diff options
context:
space:
mode:
authorShawn Guo <shawn.guo@linaro.org>2012-06-26 23:45:24 -0400
committerDavid S. Miller <davem@davemloft.net>2012-06-28 00:22:06 -0400
commita3caad0a160c03b7238a2518fa89abda78adef1e (patch)
tree117a390c87e7a69cf1b469e4225c5c7414198cf6 /drivers/net/ethernet/freescale/fec.c
parentc9040af264de8a425b0efabfcc18a6ce47d0f21f (diff)
net: fec: add phy-reset-duration for device tree probe
Different boards may require different phy reset duration. Add property phy-reset-duration for device tree probe, so that the boards that need a longer reset duration can specify it in their device tree. Signed-off-by: Shawn Guo <shawn.guo@linaro.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/freescale/fec.c')
-rw-r--r--drivers/net/ethernet/freescale/fec.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/net/ethernet/freescale/fec.c b/drivers/net/ethernet/freescale/fec.c
index f174070646f5..dafd797a6069 100644
--- a/drivers/net/ethernet/freescale/fec.c
+++ b/drivers/net/ethernet/freescale/fec.c
@@ -1507,11 +1507,17 @@ static int __devinit fec_get_phy_mode_dt(struct platform_device *pdev)
1507static void __devinit fec_reset_phy(struct platform_device *pdev) 1507static void __devinit fec_reset_phy(struct platform_device *pdev)
1508{ 1508{
1509 int err, phy_reset; 1509 int err, phy_reset;
1510 int msec = 1;
1510 struct device_node *np = pdev->dev.of_node; 1511 struct device_node *np = pdev->dev.of_node;
1511 1512
1512 if (!np) 1513 if (!np)
1513 return; 1514 return;
1514 1515
1516 of_property_read_u32(np, "phy-reset-duration", &msec);
1517 /* A sane reset duration should not be longer than 1s */
1518 if (msec > 1000)
1519 msec = 1;
1520
1515 phy_reset = of_get_named_gpio(np, "phy-reset-gpios", 0); 1521 phy_reset = of_get_named_gpio(np, "phy-reset-gpios", 0);
1516 err = devm_gpio_request_one(&pdev->dev, phy_reset, 1522 err = devm_gpio_request_one(&pdev->dev, phy_reset,
1517 GPIOF_OUT_INIT_LOW, "phy-reset"); 1523 GPIOF_OUT_INIT_LOW, "phy-reset");
@@ -1519,7 +1525,7 @@ static void __devinit fec_reset_phy(struct platform_device *pdev)
1519 pr_debug("FEC: failed to get gpio phy-reset: %d\n", err); 1525 pr_debug("FEC: failed to get gpio phy-reset: %d\n", err);
1520 return; 1526 return;
1521 } 1527 }
1522 msleep(1); 1528 msleep(msec);
1523 gpio_set_value(phy_reset, 1); 1529 gpio_set_value(phy_reset, 1);
1524} 1530}
1525#else /* CONFIG_OF */ 1531#else /* CONFIG_OF */