In preparation of OMAP moving to Common Clk Framework (CCF) add clk_prepare()
and clk_unprepare() for the various usb host clocks.

Signed-off-by: Rajendra Nayak <[email protected]>
Cc: Samuel Ortiz <[email protected]>
---
 drivers/mfd/omap-usb-host.c |   20 ++++++++++++++++++++
 1 files changed, 20 insertions(+), 0 deletions(-)

diff --git a/drivers/mfd/omap-usb-host.c b/drivers/mfd/omap-usb-host.c
index 7e96bb2..dcffa5c 100644
--- a/drivers/mfd/omap-usb-host.c
+++ b/drivers/mfd/omap-usb-host.c
@@ -632,6 +632,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                                dev_warn(dev, "ehci_logic_fck failed:%d\n",
                                         ret);
                        }
+                       clk_prepare(omap->ehci_logic_fck);
                        break;
                }
 
@@ -641,6 +642,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "utmi_p1_gfclk failed error:%d\n", ret);
                goto err_end;
        }
+       clk_prepare(omap->utmi_p1_fck);
 
        omap->xclk60mhsp1_ck = clk_get(dev, "xclk60mhsp1_ck");
        if (IS_ERR(omap->xclk60mhsp1_ck)) {
@@ -648,6 +650,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "xclk60mhsp1_ck failed error:%d\n", ret);
                goto err_utmi_p1_fck;
        }
+       clk_prepare(omap->xclk60mhsp1_ck);
 
        omap->utmi_p2_fck = clk_get(dev, "utmi_p2_gfclk");
        if (IS_ERR(omap->utmi_p2_fck)) {
@@ -655,6 +658,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "utmi_p2_gfclk failed error:%d\n", ret);
                goto err_xclk60mhsp1_ck;
        }
+       clk_prepare(omap->utmi_p2_fck);
 
        omap->xclk60mhsp2_ck = clk_get(dev, "xclk60mhsp2_ck");
        if (IS_ERR(omap->xclk60mhsp2_ck)) {
@@ -662,6 +666,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "xclk60mhsp2_ck failed error:%d\n", ret);
                goto err_utmi_p2_fck;
        }
+       clk_prepare(omap->xclk60mhsp2_ck);
 
        omap->usbhost_p1_fck = clk_get(dev, "usb_host_hs_utmi_p1_clk");
        if (IS_ERR(omap->usbhost_p1_fck)) {
@@ -669,6 +674,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "usbhost_p1_fck failed error:%d\n", ret);
                goto err_xclk60mhsp2_ck;
        }
+       clk_prepare(omap->usbhost_p1_fck);
 
        omap->usbtll_p1_fck = clk_get(dev, "usb_tll_hs_usb_ch0_clk");
        if (IS_ERR(omap->usbtll_p1_fck)) {
@@ -676,6 +682,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "usbtll_p1_fck failed error:%d\n", ret);
                goto err_usbhost_p1_fck;
        }
+       clk_prepare(omap->usbtll_p1_fck);
 
        omap->usbhost_p2_fck = clk_get(dev, "usb_host_hs_utmi_p2_clk");
        if (IS_ERR(omap->usbhost_p2_fck)) {
@@ -683,6 +690,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "usbhost_p2_fck failed error:%d\n", ret);
                goto err_usbtll_p1_fck;
        }
+       clk_prepare(omap->usbhost_p2_fck);
 
        omap->usbtll_p2_fck = clk_get(dev, "usb_tll_hs_usb_ch1_clk");
        if (IS_ERR(omap->usbtll_p2_fck)) {
@@ -690,6 +698,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "usbtll_p2_fck failed error:%d\n", ret);
                goto err_usbhost_p2_fck;
        }
+       clk_prepare(omap->usbtll_p2_fck);
 
        omap->init_60m_fclk = clk_get(dev, "init_60m_fclk");
        if (IS_ERR(omap->init_60m_fclk)) {
@@ -697,6 +706,7 @@ static int __devinit usbhs_omap_probe(struct 
platform_device *pdev)
                dev_err(dev, "init_60m_fclk failed error:%d\n", ret);
                goto err_usbtll_p2_fck;
        }
+       clk_prepare(omap->init_60m_fclk);
 
        if (is_ehci_phy_mode(pdata->port_mode[0])) {
                /* for OMAP3 , the clk set paretn fails */
@@ -773,33 +783,43 @@ err_tll:
        iounmap(omap->uhh_base);
 
 err_init_60m_fclk:
+       clk_unprepare(omap->init_60m_fclk);
        clk_put(omap->init_60m_fclk);
 
 err_usbtll_p2_fck:
+       clk_unprepare(omap->usbtll_p2_fck);
        clk_put(omap->usbtll_p2_fck);
 
 err_usbhost_p2_fck:
+       clk_unprepare(omap->usbhost_p2_fck);
        clk_put(omap->usbhost_p2_fck);
 
 err_usbtll_p1_fck:
+       clk_unprepare(omap->usbtll_p1_fck);
        clk_put(omap->usbtll_p1_fck);
 
 err_usbhost_p1_fck:
+       clk_unprepare(omap->usbhost_p1_fck);
        clk_put(omap->usbhost_p1_fck);
 
 err_xclk60mhsp2_ck:
+       clk_unprepare(omap->xclk60mhsp2_ck);
        clk_put(omap->xclk60mhsp2_ck);
 
 err_utmi_p2_fck:
+       clk_unprepare(omap->utmi_p2_fck);
        clk_put(omap->utmi_p2_fck);
 
 err_xclk60mhsp1_ck:
+       clk_unprepare(omap->xclk60mhsp1_ck);
        clk_put(omap->xclk60mhsp1_ck);
 
 err_utmi_p1_fck:
+       clk_unprepare(omap->utmi_p1_fck);
        clk_put(omap->utmi_p1_fck);
 
 err_end:
+       clk_unprepare(omap->ehci_logic_fck);
        clk_put(omap->ehci_logic_fck);
        pm_runtime_disable(dev);
        kfree(omap);
-- 
1.7.1

--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to