mmc: sdhci-of-arasan: fix clk issue in sdhci_arasan_remove()
authorJisheng Zhang <jszhang@marvell.com>
Tue, 16 Feb 2016 13:08:23 +0000 (21:08 +0800)
committerUlf Hansson <ulf.hansson@linaro.org>
Mon, 29 Feb 2016 10:03:27 +0000 (11:03 +0100)
sdhci_pltfm_unregister() could operate host's registers, it will cause
problems if the clk is already disabled and unprepared. Fix this issue
by moving the clk_disable_unprepare() call to the end of remove
function.

Signed-off-by: Jisheng Zhang <jszhang@marvell.com>
Acked-by: Sören Brinkmann <soren.brinkmann@xilinx.com>
Acked-by: Adrian Hunter <adrian.hunter@intel.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/host/sdhci-of-arasan.c

index 5d9fdb353446f2792f391281dd6fb1f0a0c22f42..8b4f8f7ad06091ae9d2a64b8137e647797b71549 100644 (file)
@@ -201,13 +201,16 @@ clk_dis_ahb:
 
 static int sdhci_arasan_remove(struct platform_device *pdev)
 {
+       int ret;
        struct sdhci_host *host = platform_get_drvdata(pdev);
        struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
        struct sdhci_arasan_data *sdhci_arasan = pltfm_host->priv;
 
+       ret = sdhci_pltfm_unregister(pdev);
+
        clk_disable_unprepare(sdhci_arasan->clk_ahb);
 
-       return sdhci_pltfm_unregister(pdev);
+       return ret;
 }
 
 static const struct of_device_id sdhci_arasan_of_match[] = {