Commit 7f55eb10 authored by Arvind Yadav's avatar Arvind Yadav Committed by Ulf Hansson

mmc: sdhci-st: Handle return value of clk_prepare_enable

clk_prepare_enable() can fail here and we must check its return value.
Signed-off-by: default avatarArvind Yadav <arvind.yadav.cs@gmail.com>
Signed-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent cc4a41fe
...@@ -394,8 +394,17 @@ static int sdhci_st_probe(struct platform_device *pdev) ...@@ -394,8 +394,17 @@ static int sdhci_st_probe(struct platform_device *pdev)
goto err_of; goto err_of;
} }
clk_prepare_enable(clk); ret = clk_prepare_enable(clk);
clk_prepare_enable(icnclk); if (ret) {
dev_err(&pdev->dev, "Failed to prepare clock\n");
goto err_of;
}
ret = clk_prepare_enable(icnclk);
if (ret) {
dev_err(&pdev->dev, "Failed to prepare icn clock\n");
goto err_icnclk;
}
/* Configure the FlashSS Top registers for setting eMMC TX/RX delay */ /* Configure the FlashSS Top registers for setting eMMC TX/RX delay */
res = platform_get_resource_byname(pdev, IORESOURCE_MEM, res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
...@@ -429,6 +438,7 @@ static int sdhci_st_probe(struct platform_device *pdev) ...@@ -429,6 +438,7 @@ static int sdhci_st_probe(struct platform_device *pdev)
err_out: err_out:
clk_disable_unprepare(icnclk); clk_disable_unprepare(icnclk);
err_icnclk:
clk_disable_unprepare(clk); clk_disable_unprepare(clk);
err_of: err_of:
sdhci_pltfm_free(pdev); sdhci_pltfm_free(pdev);
...@@ -487,9 +497,17 @@ static int sdhci_st_resume(struct device *dev) ...@@ -487,9 +497,17 @@ static int sdhci_st_resume(struct device *dev)
struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host); struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
struct st_mmc_platform_data *pdata = sdhci_pltfm_priv(pltfm_host); struct st_mmc_platform_data *pdata = sdhci_pltfm_priv(pltfm_host);
struct device_node *np = dev->of_node; struct device_node *np = dev->of_node;
int ret;
ret = clk_prepare_enable(pltfm_host->clk);
if (ret)
return ret;
clk_prepare_enable(pltfm_host->clk); ret = clk_prepare_enable(pdata->icnclk);
clk_prepare_enable(pdata->icnclk); if (ret) {
clk_disable_unprepare(pltfm_host->clk);
return ret;
}
if (pdata->rstc) if (pdata->rstc)
reset_control_deassert(pdata->rstc); reset_control_deassert(pdata->rstc);
......
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