"state_uhs");
        }
 
-       host = tmio_mmc_host_alloc(pdev);
+       host = tmio_mmc_host_alloc(pdev, mmc_data);
        if (IS_ERR(host))
                return PTR_ERR(host);
 
        /* All SDHI have SDIO status bits which must be 1 */
        mmc_data->flags |= TMIO_MMC_SDIO_STATUS_SETBITS;
 
-       ret = tmio_mmc_host_probe(host, mmc_data, dma_ops);
-       if (ret < 0)
+       ret = renesas_sdhi_clk_enable(host);
+       if (ret)
                goto efree;
 
+       ret = tmio_mmc_host_probe(host, dma_ops);
+       if (ret < 0)
+               goto edisclk;
+
        /* One Gen2 SDHI incarnation does NOT have a CBSY bit */
        if (sd_ctrl_read16(host, CTL_VERSION) == SDHI_VER_GEN2_SDR50)
                mmc_data->flags &= ~TMIO_MMC_HAVE_CBSY;
 
 eirq:
        tmio_mmc_host_remove(host);
+edisclk:
+       renesas_sdhi_clk_disable(host);
 efree:
        tmio_mmc_host_free(host);
 
        struct tmio_mmc_host *host = platform_get_drvdata(pdev);
 
        tmio_mmc_host_remove(host);
+       renesas_sdhi_clk_disable(host);
 
        return 0;
 }
 
 
        pdata->flags |= TMIO_MMC_HAVE_HIGH_REG;
 
-       host = tmio_mmc_host_alloc(pdev);
+       host = tmio_mmc_host_alloc(pdev, pdata);
        if (IS_ERR(host)) {
                ret = PTR_ERR(host);
                goto cell_disable;
        /* SD control register space size is 0x200, 0x400 for bus_shift=1 */
        host->bus_shift = resource_size(res) >> 10;
 
-       ret = tmio_mmc_host_probe(host, pdata, NULL);
+       host->mmc->f_max = pdata->hclk;
+       host->mmc->f_min = pdata->hclk / 512;
+
+       ret = tmio_mmc_host_probe(host, NULL);
        if (ret)
                goto host_free;
 
 
        const struct tmio_mmc_dma_ops *dma_ops;
 };
 
-struct tmio_mmc_host *tmio_mmc_host_alloc(struct platform_device *pdev);
+struct tmio_mmc_host *tmio_mmc_host_alloc(struct platform_device *pdev,
+                                         struct tmio_mmc_data *pdata);
 void tmio_mmc_host_free(struct tmio_mmc_host *host);
 int tmio_mmc_host_probe(struct tmio_mmc_host *host,
-                       struct tmio_mmc_data *pdata,
                        const struct tmio_mmc_dma_ops *dma_ops);
 void tmio_mmc_host_remove(struct tmio_mmc_host *host);
 void tmio_mmc_do_data_irq(struct tmio_mmc_host *host);
 
                pdata->flags |= TMIO_MMC_WRPROTECT_DISABLE;
 }
 
-struct tmio_mmc_host*
-tmio_mmc_host_alloc(struct platform_device *pdev)
+struct tmio_mmc_host *tmio_mmc_host_alloc(struct platform_device *pdev,
+                                         struct tmio_mmc_data *pdata)
 {
        struct tmio_mmc_host *host;
        struct mmc_host *mmc;
        host->ctl = ctl;
        host->mmc = mmc;
        host->pdev = pdev;
+       host->pdata = pdata;
        host->ops = tmio_mmc_ops;
        mmc->ops = &host->ops;
 
+       platform_set_drvdata(pdev, host);
+
        return host;
 }
 EXPORT_SYMBOL_GPL(tmio_mmc_host_alloc);
 EXPORT_SYMBOL_GPL(tmio_mmc_host_free);
 
 int tmio_mmc_host_probe(struct tmio_mmc_host *_host,
-                       struct tmio_mmc_data *pdata,
                        const struct tmio_mmc_dma_ops *dma_ops)
 {
        struct platform_device *pdev = _host->pdev;
+       struct tmio_mmc_data *pdata = _host->pdata;
        struct mmc_host *mmc = _host->mmc;
        int ret;
        u32 irq_mask = TMIO_MASK_CMD;
 
+       /*
+        * Check the sanity of mmc->f_min to prevent tmio_mmc_set_clock() from
+        * looping forever...
+        */
+       if (mmc->f_min == 0)
+               return -EINVAL;
+
        tmio_mmc_of_parse(pdev, pdata);
 
        if (!(pdata->flags & TMIO_MMC_HAS_IDLE_WAIT))
        if (ret < 0)
                return ret;
 
-       _host->pdata = pdata;
-       platform_set_drvdata(pdev, _host);
-
        _host->set_pwr = pdata->set_pwr;
        _host->set_clk_div = pdata->set_clk_div;
 
        if (pdata->flags & TMIO_MMC_MIN_RCAR2)
                _host->native_hotplug = true;
 
-       if (tmio_mmc_clk_enable(_host) < 0) {
-               mmc->f_max = pdata->hclk;
-               mmc->f_min = mmc->f_max / 512;
-       }
-
-       /*
-        * Check the sanity of mmc->f_min to prevent tmio_mmc_set_clock() from
-        * looping forever...
-        */
-       if (mmc->f_min == 0)
-               return -EINVAL;
-
        /*
         * While using internal tmio hardware logic for card detection, we need
         * to ensure it stays powered for it to work.
 
        pm_runtime_put_sync(&pdev->dev);
        pm_runtime_disable(&pdev->dev);
-
-       tmio_mmc_clk_disable(host);
 }
 EXPORT_SYMBOL_GPL(tmio_mmc_host_remove);