Skip to content

Commit c9805b9

Browse files
Fabio Estevamdavem330
authored andcommitted
Revert "net: fec: Ensure clocks are enabled while using mdio bus"
This reverts commit 6c3e921. commit 6c3e921 ("net: fec: Ensure clocks are enabled while using mdio bus") prevents the kernel to boot on mx6 boards, so let's revert it. Reported-by: Tyler Baker <[email protected]> Signed-off-by: Fabio Estevam <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent da27862 commit c9805b9

File tree

1 file changed

+13
-75
lines changed

1 file changed

+13
-75
lines changed

drivers/net/ethernet/freescale/fec_main.c

Lines changed: 13 additions & 75 deletions
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,6 @@
2424
#include <linux/module.h>
2525
#include <linux/kernel.h>
2626
#include <linux/string.h>
27-
#include <linux/pm_runtime.h>
2827
#include <linux/ptrace.h>
2928
#include <linux/errno.h>
3029
#include <linux/ioport.h>
@@ -78,7 +77,6 @@ static void fec_enet_itr_coal_init(struct net_device *ndev);
7877
#define FEC_ENET_RAEM_V 0x8
7978
#define FEC_ENET_RAFL_V 0x8
8079
#define FEC_ENET_OPD_V 0xFFF0
81-
#define FEC_MDIO_PM_TIMEOUT 100 /* ms */
8280

8381
static struct platform_device_id fec_devtype[] = {
8482
{
@@ -1769,13 +1767,7 @@ static void fec_enet_adjust_link(struct net_device *ndev)
17691767
static int fec_enet_mdio_read(struct mii_bus *bus, int mii_id, int regnum)
17701768
{
17711769
struct fec_enet_private *fep = bus->priv;
1772-
struct device *dev = &fep->pdev->dev;
17731770
unsigned long time_left;
1774-
int ret = 0;
1775-
1776-
ret = pm_runtime_get_sync(dev);
1777-
if (IS_ERR_VALUE(ret))
1778-
return ret;
17791771

17801772
fep->mii_timeout = 0;
17811773
init_completion(&fep->mdio_done);
@@ -1791,30 +1783,18 @@ static int fec_enet_mdio_read(struct mii_bus *bus, int mii_id, int regnum)
17911783
if (time_left == 0) {
17921784
fep->mii_timeout = 1;
17931785
netdev_err(fep->netdev, "MDIO read timeout\n");
1794-
ret = -ETIMEDOUT;
1795-
goto out;
1786+
return -ETIMEDOUT;
17961787
}
17971788

1798-
ret = FEC_MMFR_DATA(readl(fep->hwp + FEC_MII_DATA));
1799-
1800-
out:
1801-
pm_runtime_mark_last_busy(dev);
1802-
pm_runtime_put_autosuspend(dev);
1803-
1804-
return ret;
1789+
/* return value */
1790+
return FEC_MMFR_DATA(readl(fep->hwp + FEC_MII_DATA));
18051791
}
18061792

18071793
static int fec_enet_mdio_write(struct mii_bus *bus, int mii_id, int regnum,
18081794
u16 value)
18091795
{
18101796
struct fec_enet_private *fep = bus->priv;
1811-
struct device *dev = &fep->pdev->dev;
18121797
unsigned long time_left;
1813-
int ret = 0;
1814-
1815-
ret = pm_runtime_get_sync(dev);
1816-
if (IS_ERR_VALUE(ret))
1817-
return ret;
18181798

18191799
fep->mii_timeout = 0;
18201800
init_completion(&fep->mdio_done);
@@ -1831,13 +1811,10 @@ static int fec_enet_mdio_write(struct mii_bus *bus, int mii_id, int regnum,
18311811
if (time_left == 0) {
18321812
fep->mii_timeout = 1;
18331813
netdev_err(fep->netdev, "MDIO write timeout\n");
1834-
ret = -ETIMEDOUT;
1814+
return -ETIMEDOUT;
18351815
}
18361816

1837-
pm_runtime_mark_last_busy(dev);
1838-
pm_runtime_put_autosuspend(dev);
1839-
1840-
return ret;
1817+
return 0;
18411818
}
18421819

18431820
static int fec_enet_clk_enable(struct net_device *ndev, bool enable)
@@ -1849,6 +1826,9 @@ static int fec_enet_clk_enable(struct net_device *ndev, bool enable)
18491826
ret = clk_prepare_enable(fep->clk_ahb);
18501827
if (ret)
18511828
return ret;
1829+
ret = clk_prepare_enable(fep->clk_ipg);
1830+
if (ret)
1831+
goto failed_clk_ipg;
18521832
if (fep->clk_enet_out) {
18531833
ret = clk_prepare_enable(fep->clk_enet_out);
18541834
if (ret)
@@ -1872,6 +1852,7 @@ static int fec_enet_clk_enable(struct net_device *ndev, bool enable)
18721852
}
18731853
} else {
18741854
clk_disable_unprepare(fep->clk_ahb);
1855+
clk_disable_unprepare(fep->clk_ipg);
18751856
if (fep->clk_enet_out)
18761857
clk_disable_unprepare(fep->clk_enet_out);
18771858
if (fep->clk_ptp) {
@@ -1893,6 +1874,8 @@ static int fec_enet_clk_enable(struct net_device *ndev, bool enable)
18931874
if (fep->clk_enet_out)
18941875
clk_disable_unprepare(fep->clk_enet_out);
18951876
failed_clk_enet_out:
1877+
clk_disable_unprepare(fep->clk_ipg);
1878+
failed_clk_ipg:
18961879
clk_disable_unprepare(fep->clk_ahb);
18971880

18981881
return ret;
@@ -2864,14 +2847,10 @@ fec_enet_open(struct net_device *ndev)
28642847
struct fec_enet_private *fep = netdev_priv(ndev);
28652848
int ret;
28662849

2867-
ret = pm_runtime_get_sync(&fep->pdev->dev);
2868-
if (IS_ERR_VALUE(ret))
2869-
return ret;
2870-
28712850
pinctrl_pm_select_default_state(&fep->pdev->dev);
28722851
ret = fec_enet_clk_enable(ndev, true);
28732852
if (ret)
2874-
goto clk_enable;
2853+
return ret;
28752854

28762855
/* I should reset the ring buffers here, but I don't yet know
28772856
* a simple way to do that.
@@ -2902,9 +2881,6 @@ fec_enet_open(struct net_device *ndev)
29022881
fec_enet_free_buffers(ndev);
29032882
err_enet_alloc:
29042883
fec_enet_clk_enable(ndev, false);
2905-
clk_enable:
2906-
pm_runtime_mark_last_busy(&fep->pdev->dev);
2907-
pm_runtime_put_autosuspend(&fep->pdev->dev);
29082884
pinctrl_pm_select_sleep_state(&fep->pdev->dev);
29092885
return ret;
29102886
}
@@ -2927,9 +2903,6 @@ fec_enet_close(struct net_device *ndev)
29272903

29282904
fec_enet_clk_enable(ndev, false);
29292905
pinctrl_pm_select_sleep_state(&fep->pdev->dev);
2930-
pm_runtime_mark_last_busy(&fep->pdev->dev);
2931-
pm_runtime_put_autosuspend(&fep->pdev->dev);
2932-
29332906
fec_enet_free_buffers(ndev);
29342907

29352908
return 0;
@@ -3415,10 +3388,6 @@ fec_probe(struct platform_device *pdev)
34153388
if (ret)
34163389
goto failed_clk;
34173390

3418-
ret = clk_prepare_enable(fep->clk_ipg);
3419-
if (ret)
3420-
goto failed_clk_ipg;
3421-
34223391
fep->reg_phy = devm_regulator_get(&pdev->dev, "phy");
34233392
if (!IS_ERR(fep->reg_phy)) {
34243393
ret = regulator_enable(fep->reg_phy);
@@ -3465,8 +3434,6 @@ fec_probe(struct platform_device *pdev)
34653434
netif_carrier_off(ndev);
34663435
fec_enet_clk_enable(ndev, false);
34673436
pinctrl_pm_select_sleep_state(&pdev->dev);
3468-
pm_runtime_set_active(&pdev->dev);
3469-
pm_runtime_enable(&pdev->dev);
34703437

34713438
ret = register_netdev(ndev);
34723439
if (ret)
@@ -3480,12 +3447,6 @@ fec_probe(struct platform_device *pdev)
34803447

34813448
fep->rx_copybreak = COPYBREAK_DEFAULT;
34823449
INIT_WORK(&fep->tx_timeout_work, fec_enet_timeout_work);
3483-
3484-
pm_runtime_set_autosuspend_delay(&pdev->dev, FEC_MDIO_PM_TIMEOUT);
3485-
pm_runtime_use_autosuspend(&pdev->dev);
3486-
pm_runtime_mark_last_busy(&pdev->dev);
3487-
pm_runtime_put_autosuspend(&pdev->dev);
3488-
34893450
return 0;
34903451

34913452
failed_register:
@@ -3496,8 +3457,6 @@ fec_probe(struct platform_device *pdev)
34963457
if (fep->reg_phy)
34973458
regulator_disable(fep->reg_phy);
34983459
failed_regulator:
3499-
clk_disable_unprepare(fep->clk_ipg);
3500-
failed_clk_ipg:
35013460
fec_enet_clk_enable(ndev, false);
35023461
failed_clk:
35033462
failed_phy:
@@ -3609,28 +3568,7 @@ static int __maybe_unused fec_resume(struct device *dev)
36093568
return ret;
36103569
}
36113570

3612-
static int __maybe_unused fec_runtime_suspend(struct device *dev)
3613-
{
3614-
struct net_device *ndev = dev_get_drvdata(dev);
3615-
struct fec_enet_private *fep = netdev_priv(ndev);
3616-
3617-
clk_disable_unprepare(fep->clk_ipg);
3618-
3619-
return 0;
3620-
}
3621-
3622-
static int __maybe_unused fec_runtime_resume(struct device *dev)
3623-
{
3624-
struct net_device *ndev = dev_get_drvdata(dev);
3625-
struct fec_enet_private *fep = netdev_priv(ndev);
3626-
3627-
return clk_prepare_enable(fep->clk_ipg);
3628-
}
3629-
3630-
static const struct dev_pm_ops fec_pm_ops = {
3631-
SET_SYSTEM_SLEEP_PM_OPS(fec_suspend, fec_resume)
3632-
SET_RUNTIME_PM_OPS(fec_runtime_suspend, fec_runtime_resume, NULL)
3633-
};
3571+
static SIMPLE_DEV_PM_OPS(fec_pm_ops, fec_suspend, fec_resume);
36343572

36353573
static struct platform_driver fec_driver = {
36363574
.driver = {

0 commit comments

Comments
 (0)