diff options
author | Wolfram Sang <w.sang@pengutronix.de> | 2013-01-29 09:46:11 -0500 |
---|---|---|
committer | Shawn Guo <shawn.guo@linaro.org> | 2013-04-04 09:22:40 -0400 |
commit | daa7d392ffe67e698ee442694276061624b4b0a1 (patch) | |
tree | de6e3cba8d79fcc55ae6cdc294c1a29e5742d141 | |
parent | c29dc2d771411850777eb027756b12106b5f6cd5 (diff) |
net: freescale: fec: add support for optional enet_out clk
Some MX28 boards need the internal enet_out clock to be enabled. So, do
this in the driver iff the clock was referenced via devicetree.
Signed-off-by: Wolfram Sang <w.sang@pengutronix.de>
Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
Acked-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/ethernet/freescale/fec.c | 10 | ||||
-rw-r--r-- | drivers/net/ethernet/freescale/fec.h | 1 |
2 files changed, 11 insertions, 0 deletions
diff --git a/drivers/net/ethernet/freescale/fec.c b/drivers/net/ethernet/freescale/fec.c index 6d965bb32908..dd098ea44d48 100644 --- a/drivers/net/ethernet/freescale/fec.c +++ b/drivers/net/ethernet/freescale/fec.c | |||
@@ -1802,6 +1802,11 @@ fec_probe(struct platform_device *pdev) | |||
1802 | goto failed_clk; | 1802 | goto failed_clk; |
1803 | } | 1803 | } |
1804 | 1804 | ||
1805 | /* enet_out is optional, depends on board */ | ||
1806 | fep->clk_enet_out = devm_clk_get(&pdev->dev, "enet_out"); | ||
1807 | if (IS_ERR(fep->clk_enet_out)) | ||
1808 | fep->clk_enet_out = NULL; | ||
1809 | |||
1805 | fep->clk_ptp = devm_clk_get(&pdev->dev, "ptp"); | 1810 | fep->clk_ptp = devm_clk_get(&pdev->dev, "ptp"); |
1806 | fep->bufdesc_ex = | 1811 | fep->bufdesc_ex = |
1807 | pdev->id_entry->driver_data & FEC_QUIRK_HAS_BUFDESC_EX; | 1812 | pdev->id_entry->driver_data & FEC_QUIRK_HAS_BUFDESC_EX; |
@@ -1812,6 +1817,7 @@ fec_probe(struct platform_device *pdev) | |||
1812 | 1817 | ||
1813 | clk_prepare_enable(fep->clk_ahb); | 1818 | clk_prepare_enable(fep->clk_ahb); |
1814 | clk_prepare_enable(fep->clk_ipg); | 1819 | clk_prepare_enable(fep->clk_ipg); |
1820 | clk_prepare_enable(fep->clk_enet_out); | ||
1815 | clk_prepare_enable(fep->clk_ptp); | 1821 | clk_prepare_enable(fep->clk_ptp); |
1816 | 1822 | ||
1817 | reg_phy = devm_regulator_get(&pdev->dev, "phy"); | 1823 | reg_phy = devm_regulator_get(&pdev->dev, "phy"); |
@@ -1877,6 +1883,7 @@ failed_irq: | |||
1877 | failed_regulator: | 1883 | failed_regulator: |
1878 | clk_disable_unprepare(fep->clk_ahb); | 1884 | clk_disable_unprepare(fep->clk_ahb); |
1879 | clk_disable_unprepare(fep->clk_ipg); | 1885 | clk_disable_unprepare(fep->clk_ipg); |
1886 | clk_disable_unprepare(fep->clk_enet_out); | ||
1880 | clk_disable_unprepare(fep->clk_ptp); | 1887 | clk_disable_unprepare(fep->clk_ptp); |
1881 | failed_pin: | 1888 | failed_pin: |
1882 | failed_clk: | 1889 | failed_clk: |
@@ -1903,6 +1910,7 @@ fec_drv_remove(struct platform_device *pdev) | |||
1903 | clk_disable_unprepare(fep->clk_ptp); | 1910 | clk_disable_unprepare(fep->clk_ptp); |
1904 | if (fep->ptp_clock) | 1911 | if (fep->ptp_clock) |
1905 | ptp_clock_unregister(fep->ptp_clock); | 1912 | ptp_clock_unregister(fep->ptp_clock); |
1913 | clk_disable_unprepare(fep->clk_enet_out); | ||
1906 | clk_disable_unprepare(fep->clk_ahb); | 1914 | clk_disable_unprepare(fep->clk_ahb); |
1907 | clk_disable_unprepare(fep->clk_ipg); | 1915 | clk_disable_unprepare(fep->clk_ipg); |
1908 | for (i = 0; i < FEC_IRQ_NUM; i++) { | 1916 | for (i = 0; i < FEC_IRQ_NUM; i++) { |
@@ -1933,6 +1941,7 @@ fec_suspend(struct device *dev) | |||
1933 | fec_stop(ndev); | 1941 | fec_stop(ndev); |
1934 | netif_device_detach(ndev); | 1942 | netif_device_detach(ndev); |
1935 | } | 1943 | } |
1944 | clk_disable_unprepare(fep->clk_enet_out); | ||
1936 | clk_disable_unprepare(fep->clk_ahb); | 1945 | clk_disable_unprepare(fep->clk_ahb); |
1937 | clk_disable_unprepare(fep->clk_ipg); | 1946 | clk_disable_unprepare(fep->clk_ipg); |
1938 | 1947 | ||
@@ -1945,6 +1954,7 @@ fec_resume(struct device *dev) | |||
1945 | struct net_device *ndev = dev_get_drvdata(dev); | 1954 | struct net_device *ndev = dev_get_drvdata(dev); |
1946 | struct fec_enet_private *fep = netdev_priv(ndev); | 1955 | struct fec_enet_private *fep = netdev_priv(ndev); |
1947 | 1956 | ||
1957 | clk_prepare_enable(fep->clk_enet_out); | ||
1948 | clk_prepare_enable(fep->clk_ahb); | 1958 | clk_prepare_enable(fep->clk_ahb); |
1949 | clk_prepare_enable(fep->clk_ipg); | 1959 | clk_prepare_enable(fep->clk_ipg); |
1950 | if (netif_running(ndev)) { | 1960 | if (netif_running(ndev)) { |
diff --git a/drivers/net/ethernet/freescale/fec.h b/drivers/net/ethernet/freescale/fec.h index eb4372962839..feabcb6a78b4 100644 --- a/drivers/net/ethernet/freescale/fec.h +++ b/drivers/net/ethernet/freescale/fec.h | |||
@@ -207,6 +207,7 @@ struct fec_enet_private { | |||
207 | 207 | ||
208 | struct clk *clk_ipg; | 208 | struct clk *clk_ipg; |
209 | struct clk *clk_ahb; | 209 | struct clk *clk_ahb; |
210 | struct clk *clk_enet_out; | ||
210 | struct clk *clk_ptp; | 211 | struct clk *clk_ptp; |
211 | 212 | ||
212 | /* The saved address of a sent-in-place packet/buffer, for skfree(). */ | 213 | /* The saved address of a sent-in-place packet/buffer, for skfree(). */ |