Commit 6ade9a2c authored by Wolfram Sang's avatar Wolfram Sang Committed by Ulf Hansson

mmc: sh_mobile_sdhi: improve prerequisite for hw_reset

We need a SCC unit for hw_reset. Those units can only be described in
of_data. So, of_data and a valid SCC offset are prerequisites for
enabling the hw_reset capability. Merge the two 'if' conditions into one
and add a check for an scc offset.
Signed-off-by: default avatarWolfram Sang <wsa+renesas@sang-engineering.com>
Reviewed-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent dc9f1a8d
...@@ -666,27 +666,25 @@ static int sh_mobile_sdhi_probe(struct platform_device *pdev) ...@@ -666,27 +666,25 @@ static int sh_mobile_sdhi_probe(struct platform_device *pdev)
if (ret < 0) if (ret < 0)
goto efree; goto efree;
if (host->mmc->caps & MMC_CAP_UHS_SDR104) { if (of_data && of_data->scc_offset && host->mmc->caps & MMC_CAP_UHS_SDR104) {
const struct sh_mobile_sdhi_scc *taps = of_data->taps;
bool hit = false;
host->mmc->caps |= MMC_CAP_HW_RESET; host->mmc->caps |= MMC_CAP_HW_RESET;
if (of_data) { for (i = 0; i < of_data->taps_num; i++) {
const struct sh_mobile_sdhi_scc *taps = of_data->taps; if (taps[i].clk_rate == 0 ||
bool hit = false; taps[i].clk_rate == host->mmc->f_max) {
host->scc_tappos = taps->tap;
for (i = 0; i < of_data->taps_num; i++) { hit = true;
if (taps[i].clk_rate == 0 || break;
taps[i].clk_rate == host->mmc->f_max) {
host->scc_tappos = taps->tap;
hit = true;
break;
}
} }
}
if (!hit) if (!hit)
dev_warn(&host->pdev->dev, "Unknown clock rate for SDR104\n"); dev_warn(&host->pdev->dev, "Unknown clock rate for SDR104\n");
priv->scc_ctl = host->ctl + of_data->scc_offset; priv->scc_ctl = host->ctl + of_data->scc_offset;
}
} }
i = 0; i = 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