net: fec: fix unbalanced clk disable on driver unbind
authorStefan Agner <stefan@agner.ch>
Thu, 5 Mar 2015 14:09:29 +0000 (15:09 +0100)
committerDavid S. Miller <davem@davemloft.net>
Fri, 6 Mar 2015 03:23:33 +0000 (22:23 -0500)
When the driver is removed (e.g. using unbind through sysfs), the
clocks get disabled twice, once on fec_enet_close and once on
fec_drv_remove. Since the clocks are enabled only once, this leads
to a warning:

WARNING: CPU: 0 PID: 402 at drivers/clk/clk.c:992 clk_core_disable+0x64/0x68()

Remove the call to fec_enet_clk_enable in fec_drv_remove to balance
the clock enable/disable calls again. This has been introduce by
e8fcfcd5684a ("net: fec: optimize the clock management to save power").

Signed-off-by: Stefan Agner <stefan@agner.ch>
Acked-by: Fugang Duan <B38611@freescale.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/freescale/fec_main.c

index 5ff8fee3850f7aaa453a74ffc99d2f0fa7b3098c..99492b7e3713bbd04aaacffb8aa1a926b1ce9ef9 100644 (file)
@@ -3383,7 +3383,6 @@ fec_drv_remove(struct platform_device *pdev)
                regulator_disable(fep->reg_phy);
        if (fep->ptp_clock)
                ptp_clock_unregister(fep->ptp_clock);
-       fec_enet_clk_enable(ndev, false);
        of_node_put(fep->phy_node);
        free_netdev(ndev);