Commit d4426322 authored by Sergei Antonov's avatar Sergei Antonov Committed by Ulf Hansson

mmc: moxart: read scr register without changing byte order

Conversion from big-endian to native is done in a common function
mmc_app_send_scr(). Converting in moxart_transfer_pio() is extra.
Double conversion on a LE system returns an incorrect SCR value,
leads to errors:

mmc0: unrecognised SCR structure version 8

Fixes: 1b66e94e ("mmc: moxart: Add MOXA ART SD/MMC driver")
Signed-off-by: default avatarSergei Antonov <saproj@gmail.com>
Cc: Jonas Jensen <jonas.jensen@gmail.com>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/r/20230627120549.2400325-1-saproj@gmail.comSigned-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent 06c2afb8
...@@ -338,13 +338,7 @@ static void moxart_transfer_pio(struct moxart_host *host) ...@@ -338,13 +338,7 @@ static void moxart_transfer_pio(struct moxart_host *host)
return; return;
} }
for (len = 0; len < remain && len < host->fifo_width;) { for (len = 0; len < remain && len < host->fifo_width;) {
/* SCR data must be read in big endian. */ *sgp = ioread32(host->base + REG_DATA_WINDOW);
if (data->mrq->cmd->opcode == SD_APP_SEND_SCR)
*sgp = ioread32be(host->base +
REG_DATA_WINDOW);
else
*sgp = ioread32(host->base +
REG_DATA_WINDOW);
sgp++; sgp++;
len += 4; len += 4;
} }
......
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