From: Jisheng Zhang Date: Sun, 4 Jan 2015 15:15:48 +0000 (+0800) Subject: mmc: sdhci-pxav3: fix pm unbalanced issue in -> remove() X-Git-Tag: v4.0-rc1~124^2~41 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=20f1f2d7d4a497ce6c51866e23ce5f452e3aeb99;p=users%2Fhch%2Fmisc.git mmc: sdhci-pxav3: fix pm unbalanced issue in -> remove() This patch calls pm_runtime_put_noidle() to restore the device's usage counter in the ->remove() implementation. Signed-off-by: Jisheng Zhang Signed-off-by: Ulf Hansson --- diff --git a/drivers/mmc/host/sdhci-pxav3.c b/drivers/mmc/host/sdhci-pxav3.c index 1255dd2b91c1..4de39fb6dc2d 100644 --- a/drivers/mmc/host/sdhci-pxav3.c +++ b/drivers/mmc/host/sdhci-pxav3.c @@ -412,8 +412,10 @@ static int sdhci_pxav3_remove(struct platform_device *pdev) struct sdhci_pxa *pxa = pltfm_host->priv; pm_runtime_get_sync(&pdev->dev); - sdhci_remove_host(host, 1); pm_runtime_disable(&pdev->dev); + pm_runtime_put_noidle(&pdev->dev); + + sdhci_remove_host(host, 1); clk_disable_unprepare(pxa->clk_io); if (!IS_ERR(pxa->clk_core))