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: Wolfram Sang <wsa+renesas@sang-engineering.com> Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be> Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
This commit is contained in:
parent
dc9f1a8d79
commit
6ade9a2c2d
|
@ -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)
|
|
||||||
dev_warn(&host->pdev->dev, "Unknown clock rate for SDR104\n");
|
|
||||||
|
|
||||||
priv->scc_ctl = host->ctl + of_data->scc_offset;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!hit)
|
||||||
|
dev_warn(&host->pdev->dev, "Unknown clock rate for SDR104\n");
|
||||||
|
|
||||||
|
priv->scc_ctl = host->ctl + of_data->scc_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
|
|
Loading…
Reference in New Issue