Skip to content

Commit 3e68abf

Browse files
Andy-ld Lustorulf
authored andcommitted
mmc: mtk-sd: Fix register settings for hs400(es) mode
For hs400(es) mode, the 'hs400-ds-delay' is typically configured in the dts. However, some projects may only define 'mediatek,hs400-ds-dly3', which can lead to initialization failures in hs400es mode. CMD13 reported response crc error in the mmc_switch_status() just after switching to hs400es mode. [ 1.914038][ T82] mmc0: mmc_select_hs400es failed, error -84 [ 1.914954][ T82] mmc0: error -84 whilst initialising MMC card Currently, the hs400_ds_dly3 value is set within the tuning function. This means that the PAD_DS_DLY3 field is not configured before tuning process, which is the reason for the above-mentioned CMD13 response crc error. Move the PAD_DS_DLY3 field configuration into msdc_prepare_hs400_tuning(), and add a value check of hs400_ds_delay to prevent overwriting by zero when the 'hs400-ds-delay' is not set in the dts. In addition, since hs400(es) only tune the PAD_DS_DLY1, the PAD_DS_DLY2_SEL bit should be cleared to bypass it. Fixes: c4ac38c ("mmc: mtk-sd: Add HS400 online tuning support") Signed-off-by: Andy-ld Lu <[email protected]> Reviewed-by: AngeloGioacchino Del Regno <[email protected]> Cc: [email protected] Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Ulf Hansson <[email protected]>
1 parent ac5a41b commit 3e68abf

File tree

1 file changed

+20
-11
lines changed

1 file changed

+20
-11
lines changed

drivers/mmc/host/mtk-sd.c

Lines changed: 20 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -273,6 +273,7 @@
273273
#define MSDC_PAD_TUNE_CMD2_SEL BIT(21) /* RW */
274274

275275
#define PAD_DS_TUNE_DLY_SEL BIT(0) /* RW */
276+
#define PAD_DS_TUNE_DLY2_SEL BIT(1) /* RW */
276277
#define PAD_DS_TUNE_DLY1 GENMASK(6, 2) /* RW */
277278
#define PAD_DS_TUNE_DLY2 GENMASK(11, 7) /* RW */
278279
#define PAD_DS_TUNE_DLY3 GENMASK(16, 12) /* RW */
@@ -318,6 +319,7 @@
318319

319320
/* EMMC50_PAD_DS_TUNE mask */
320321
#define PAD_DS_DLY_SEL BIT(16) /* RW */
322+
#define PAD_DS_DLY2_SEL BIT(15) /* RW */
321323
#define PAD_DS_DLY1 GENMASK(14, 10) /* RW */
322324
#define PAD_DS_DLY3 GENMASK(4, 0) /* RW */
323325

@@ -2504,13 +2506,23 @@ static int msdc_execute_tuning(struct mmc_host *mmc, u32 opcode)
25042506
static int msdc_prepare_hs400_tuning(struct mmc_host *mmc, struct mmc_ios *ios)
25052507
{
25062508
struct msdc_host *host = mmc_priv(mmc);
2509+
25072510
host->hs400_mode = true;
25082511

2509-
if (host->top_base)
2510-
writel(host->hs400_ds_delay,
2511-
host->top_base + EMMC50_PAD_DS_TUNE);
2512-
else
2513-
writel(host->hs400_ds_delay, host->base + PAD_DS_TUNE);
2512+
if (host->top_base) {
2513+
if (host->hs400_ds_dly3)
2514+
sdr_set_field(host->top_base + EMMC50_PAD_DS_TUNE,
2515+
PAD_DS_DLY3, host->hs400_ds_dly3);
2516+
if (host->hs400_ds_delay)
2517+
writel(host->hs400_ds_delay,
2518+
host->top_base + EMMC50_PAD_DS_TUNE);
2519+
} else {
2520+
if (host->hs400_ds_dly3)
2521+
sdr_set_field(host->base + PAD_DS_TUNE,
2522+
PAD_DS_TUNE_DLY3, host->hs400_ds_dly3);
2523+
if (host->hs400_ds_delay)
2524+
writel(host->hs400_ds_delay, host->base + PAD_DS_TUNE);
2525+
}
25142526
/* hs400 mode must set it to 0 */
25152527
sdr_clr_bits(host->base + MSDC_PATCH_BIT2, MSDC_PATCH_BIT2_CFGCRCSTS);
25162528
/* to improve read performance, set outstanding to 2 */
@@ -2530,14 +2542,11 @@ static int msdc_execute_hs400_tuning(struct mmc_host *mmc, struct mmc_card *card
25302542
if (host->top_base) {
25312543
sdr_set_bits(host->top_base + EMMC50_PAD_DS_TUNE,
25322544
PAD_DS_DLY_SEL);
2533-
if (host->hs400_ds_dly3)
2534-
sdr_set_field(host->top_base + EMMC50_PAD_DS_TUNE,
2535-
PAD_DS_DLY3, host->hs400_ds_dly3);
2545+
sdr_clr_bits(host->top_base + EMMC50_PAD_DS_TUNE,
2546+
PAD_DS_DLY2_SEL);
25362547
} else {
25372548
sdr_set_bits(host->base + PAD_DS_TUNE, PAD_DS_TUNE_DLY_SEL);
2538-
if (host->hs400_ds_dly3)
2539-
sdr_set_field(host->base + PAD_DS_TUNE,
2540-
PAD_DS_TUNE_DLY3, host->hs400_ds_dly3);
2549+
sdr_clr_bits(host->base + PAD_DS_TUNE, PAD_DS_TUNE_DLY2_SEL);
25412550
}
25422551

25432552
host->hs400_tuning = true;

0 commit comments

Comments
 (0)