提交 5833e052 编写于 作者: G Gregory CLEMENT 提交者: David S. Miller

net/macb: add support for resetting PHY using GPIO

With device tree it is no more possible to reset the PHY at board
level. Furthermore, doing in the driver allow to power down the PHY when
the network interface is no more used.

This reset can't be done at the PHY driver level. The PHY must be able to
answer the to the mii bus scan to let the kernel creating a PHY device.

The patch introduces a new optional property "phy-reset-gpios" inspired
from the one use for the FEC.
Signed-off-by: NGregory CLEMENT <gregory.clement@free-electrons.com>
Acked-by: NRob Herring <robh@kernel.org>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 bda13fed
...@@ -19,6 +19,9 @@ Required properties: ...@@ -19,6 +19,9 @@ Required properties:
Optional elements: 'tx_clk' Optional elements: 'tx_clk'
- clocks: Phandles to input clocks. - clocks: Phandles to input clocks.
Optional properties:
- phy-reset-gpios : Should specify the gpio for phy reset
Examples: Examples:
macb0: ethernet@fffc4000 { macb0: ethernet@fffc4000 {
......
...@@ -2904,6 +2904,10 @@ static int macb_probe(struct platform_device *pdev) ...@@ -2904,6 +2904,10 @@ static int macb_probe(struct platform_device *pdev)
else else
macb_get_hwaddr(bp); macb_get_hwaddr(bp);
/* Power up the PHY if there is a GPIO reset */
bp->reset_gpio = devm_gpiod_get_optional(&bp->pdev->dev, "phy-reset",
GPIOD_OUT_HIGH);
err = of_get_phy_mode(np); err = of_get_phy_mode(np);
if (err < 0) { if (err < 0) {
pdata = dev_get_platdata(&pdev->dev); pdata = dev_get_platdata(&pdev->dev);
...@@ -2970,6 +2974,10 @@ static int macb_remove(struct platform_device *pdev) ...@@ -2970,6 +2974,10 @@ static int macb_remove(struct platform_device *pdev)
mdiobus_unregister(bp->mii_bus); mdiobus_unregister(bp->mii_bus);
kfree(bp->mii_bus->irq); kfree(bp->mii_bus->irq);
mdiobus_free(bp->mii_bus); mdiobus_free(bp->mii_bus);
/* Shutdown the PHY if there is a GPIO reset */
gpiod_set_value(bp->reset_gpio, 0);
unregister_netdev(dev); unregister_netdev(dev);
clk_disable_unprepare(bp->tx_clk); clk_disable_unprepare(bp->tx_clk);
clk_disable_unprepare(bp->hclk); clk_disable_unprepare(bp->hclk);
......
...@@ -829,6 +829,7 @@ struct macb { ...@@ -829,6 +829,7 @@ struct macb {
unsigned int dma_burst_length; unsigned int dma_burst_length;
phy_interface_t phy_interface; phy_interface_t phy_interface;
struct gpio_desc *reset_gpio;
/* AT91RM9200 transmit */ /* AT91RM9200 transmit */
struct sk_buff *skb; /* holds skb until xmit interrupt completes */ struct sk_buff *skb; /* holds skb until xmit interrupt completes */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册