mmc: msm_sdcc: Fix bug in PIO mode when data size is not word aligned
The current code for PIO doesn't transfer whole data when data size is not in multiple of 4 bytes. The last few bytes are not written to the card resulting in no DATAEND interrupt from SDCC. This patch allows data transfer for non-aligned data size in PIO mode. Signed-off-by: Sahitya Tummala <stummala@codeaurora.org> Signed-off-by: David Brown <davidb@codeaurora.org>
This commit is contained in:
Родитель
b08bb35d1a
Коммит
71dd9106af
|
@ -613,6 +613,9 @@ msmsdcc_pio_read(struct msmsdcc_host *host, char *buffer, unsigned int remain)
|
||||||
uint32_t *ptr = (uint32_t *) buffer;
|
uint32_t *ptr = (uint32_t *) buffer;
|
||||||
int count = 0;
|
int count = 0;
|
||||||
|
|
||||||
|
if (remain % 4)
|
||||||
|
remain = ((remain >> 2) + 1) << 2;
|
||||||
|
|
||||||
while (msmsdcc_readl(host, MMCISTATUS) & MCI_RXDATAAVLBL) {
|
while (msmsdcc_readl(host, MMCISTATUS) & MCI_RXDATAAVLBL) {
|
||||||
*ptr = msmsdcc_readl(host, MMCIFIFO + (count % MCI_FIFOSIZE));
|
*ptr = msmsdcc_readl(host, MMCIFIFO + (count % MCI_FIFOSIZE));
|
||||||
ptr++;
|
ptr++;
|
||||||
|
@ -633,13 +636,14 @@ msmsdcc_pio_write(struct msmsdcc_host *host, char *buffer,
|
||||||
char *ptr = buffer;
|
char *ptr = buffer;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
unsigned int count, maxcnt;
|
unsigned int count, maxcnt, sz;
|
||||||
|
|
||||||
maxcnt = status & MCI_TXFIFOEMPTY ? MCI_FIFOSIZE :
|
maxcnt = status & MCI_TXFIFOEMPTY ? MCI_FIFOSIZE :
|
||||||
MCI_FIFOHALFSIZE;
|
MCI_FIFOHALFSIZE;
|
||||||
count = min(remain, maxcnt);
|
count = min(remain, maxcnt);
|
||||||
|
|
||||||
writesl(base + MMCIFIFO, ptr, count >> 2);
|
sz = count % 4 ? (count >> 2) + 1 : (count >> 2);
|
||||||
|
writesl(base + MMCIFIFO, ptr, sz);
|
||||||
ptr += count;
|
ptr += count;
|
||||||
remain -= count;
|
remain -= count;
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче