Commit 854034e2 authored by Yangtao Li's avatar Yangtao Li Committed by Ulf Hansson

mmc: sdhci_am654: Properly handle failures in .remove()

Returning an error code in a platform driver's remove function is wrong
most of the time and there is an effort to make the callback return
void. To prepare this rework the function not to exit early.

Cc: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: default avatarYangtao Li <frank.li@vivo.com>
Acked-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
Link: https://lore.kernel.org/r/20230727070051.17778-59-frank.li@vivo.comSigned-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent 8d777034
...@@ -870,16 +870,17 @@ static int sdhci_am654_remove(struct platform_device *pdev) ...@@ -870,16 +870,17 @@ static int sdhci_am654_remove(struct platform_device *pdev)
{ {
struct sdhci_host *host = platform_get_drvdata(pdev); struct sdhci_host *host = platform_get_drvdata(pdev);
struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host); struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
struct device *dev = &pdev->dev;
int ret; int ret;
ret = pm_runtime_resume_and_get(&pdev->dev); ret = pm_runtime_get_sync(dev);
if (ret < 0) if (ret < 0)
return ret; dev_err(dev, "pm_runtime_get_sync() Failed\n");
sdhci_remove_host(host, true); sdhci_remove_host(host, true);
clk_disable_unprepare(pltfm_host->clk); clk_disable_unprepare(pltfm_host->clk);
pm_runtime_disable(&pdev->dev); pm_runtime_disable(dev);
pm_runtime_put_noidle(&pdev->dev); pm_runtime_put_noidle(dev);
sdhci_pltfm_free(pdev); sdhci_pltfm_free(pdev);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment