Skip to content

Commit

Permalink
mmc: sh_mmcif: Make sure the device stays active when needed in ->pro…
Browse files Browse the repository at this point in the history
…be()

While accessing the device, make sure it stays active by increasing the
runtime PM usage count for it.

Let's also defer to enable runtime PM until we really need access to the
device. This also enables the error path in ->probe() to become simpler.

Signed-off-by: Ulf Hansson <[email protected]>
  • Loading branch information
storulf committed May 2, 2016
1 parent 04974df commit 88ac2a2
Showing 1 changed file with 8 additions and 7 deletions.
15 changes: 8 additions & 7 deletions drivers/mmc/host/sh_mmcif.c
Original file line number Diff line number Diff line change
Expand Up @@ -1519,23 +1519,23 @@ static int sh_mmcif_probe(struct platform_device *pdev)

platform_set_drvdata(pdev, host);

pm_runtime_enable(dev);
host->power = false;

host->clk = devm_clk_get(dev, NULL);
if (IS_ERR(host->clk)) {
ret = PTR_ERR(host->clk);
dev_err(dev, "cannot get clock: %d\n", ret);
goto err_pm;
goto err_host;
}

ret = clk_prepare_enable(host->clk);
if (ret < 0)
goto err_pm;
goto err_host;

sh_mmcif_clk_setup(host);

ret = pm_runtime_resume(dev);
pm_runtime_enable(dev);
host->power = false;

ret = pm_runtime_get_sync(dev);
if (ret < 0)
goto err_clk;

Expand Down Expand Up @@ -1579,12 +1579,13 @@ static int sh_mmcif_probe(struct platform_device *pdev)
sh_mmcif_readl(host->addr, MMCIF_CE_VERSION) & 0xffff,
clk_get_rate(host->clk) / 1000000UL);

pm_runtime_put(dev);
clk_disable_unprepare(host->clk);
return ret;

err_clk:
clk_disable_unprepare(host->clk);
err_pm:
pm_runtime_put_sync(dev);
pm_runtime_disable(dev);
err_host:
mmc_free_host(mmc);
Expand Down

0 comments on commit 88ac2a2

Please sign in to comment.