On 23 April 2015 at 10:45, Rajendra Nayak <rnayak@xxxxxxxxxxxxxx> wrote: > With platform support now in place to manage clocks from within runtime PM > callbacks, get rid of all clock handling from the driver and convert the > driver to use runtime PM apis. > > Signed-off-by: Rajendra Nayak <rnayak@xxxxxxxxxxxxxx> > Cc: <linux-mmc@xxxxxxxxxxxxxxx> > --- > drivers/mmc/host/sdhci-msm.c | 46 +++++++++++--------------------------------- > 1 file changed, 11 insertions(+), 35 deletions(-) > > diff --git a/drivers/mmc/host/sdhci-msm.c b/drivers/mmc/host/sdhci-msm.c > index 4a09f76..3c62a77 100644 > --- a/drivers/mmc/host/sdhci-msm.c > +++ b/drivers/mmc/host/sdhci-msm.c > @@ -19,6 +19,7 @@ > #include <linux/delay.h> > #include <linux/mmc/mmc.h> > #include <linux/slab.h> > +#include <linux/pm_runtime.h> > > #include "sdhci-pltfm.h" > > @@ -56,8 +57,6 @@ > struct sdhci_msm_host { > struct platform_device *pdev; > void __iomem *core_mem; /* MSM SDCC mapped address */ > - struct clk *clk; /* main SD/MMC bus clock */ > - struct clk *pclk; /* SDHC peripheral bus clock */ > struct clk *bus_clk; /* SDHC bus voter clock */ > struct mmc_host *mmc; > struct sdhci_pltfm_data sdhci_msm_pdata; > @@ -469,29 +468,8 @@ static int sdhci_msm_probe(struct platform_device *pdev) > goto pltfm_free; > } > > - /* Setup main peripheral bus clock */ > - msm_host->pclk = devm_clk_get(&pdev->dev, "iface"); > - if (IS_ERR(msm_host->pclk)) { > - ret = PTR_ERR(msm_host->pclk); > - dev_err(&pdev->dev, "Perpheral clk setup failed (%d)\n", ret); > - goto bus_clk_disable; > - } > - > - ret = clk_prepare_enable(msm_host->pclk); > - if (ret) > - goto bus_clk_disable; > - > - /* Setup SDC MMC clock */ > - msm_host->clk = devm_clk_get(&pdev->dev, "core"); > - if (IS_ERR(msm_host->clk)) { > - ret = PTR_ERR(msm_host->clk); > - dev_err(&pdev->dev, "SDC MMC clk setup failed (%d)\n", ret); > - goto pclk_disable; > - } > - > - ret = clk_prepare_enable(msm_host->clk); > - if (ret) > - goto pclk_disable; > + pm_runtime_enable(&pdev->dev); > + pm_runtime_get_sync(&pdev->dev); > > core_memres = platform_get_resource(pdev, IORESOURCE_MEM, 1); > msm_host->core_mem = devm_ioremap_resource(&pdev->dev, core_memres); > @@ -499,7 +477,7 @@ static int sdhci_msm_probe(struct platform_device *pdev) > if (IS_ERR(msm_host->core_mem)) { > dev_err(&pdev->dev, "Failed to remap registers\n"); > ret = PTR_ERR(msm_host->core_mem); > - goto clk_disable; > + goto err; > } > > /* Reset the core and Enable SDHC mode */ > @@ -511,7 +489,7 @@ static int sdhci_msm_probe(struct platform_device *pdev) > if (readl(msm_host->core_mem + CORE_POWER) & CORE_SW_RST) { > dev_err(&pdev->dev, "Stuck in reset\n"); > ret = -ETIMEDOUT; > - goto clk_disable; > + goto err; > } > > /* Set HC_MODE_EN bit in HC_MODE register */ > @@ -545,15 +523,13 @@ static int sdhci_msm_probe(struct platform_device *pdev) > > ret = sdhci_add_host(host); > if (ret) > - goto clk_disable; > + goto err; > > return 0; > > -clk_disable: > - clk_disable_unprepare(msm_host->clk); > -pclk_disable: > - clk_disable_unprepare(msm_host->pclk); > -bus_clk_disable: > +err: > + pm_runtime_put_sync(&pdev->dev); > + pm_runtime_disable(&pdev->dev); > if (!IS_ERR(msm_host->bus_clk)) > clk_disable_unprepare(msm_host->bus_clk); > pltfm_free: > @@ -571,8 +547,8 @@ static int sdhci_msm_remove(struct platform_device *pdev) > > sdhci_remove_host(host, dead); > sdhci_pltfm_free(pdev); > - clk_disable_unprepare(msm_host->clk); > - clk_disable_unprepare(msm_host->pclk); > + pm_runtime_put_sync(&pdev->dev); > + pm_runtime_disable(&pdev->dev); > if (!IS_ERR(msm_host->bus_clk)) > clk_disable_unprepare(msm_host->bus_clk); > return 0; > -- > QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member > of Code Aurora Forum, hosted by The Linux Foundation > > -- > To unsubscribe from this list: send the line "unsubscribe linux-pm" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html This all looks wrong. The driver will no longer work unless CONFIG_PM is set. Kind regards Uffe -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html