[MMC] mmci: allow small data transfers
If a data transfer is small (less than a FIFO size) we would hang waiting for the data to be read due to the PIO interrupt not occuring. We allowed for this in our PIO interrupt handler, but not when setting up a data transfer. Apply the "fix" when setting up a data transfer as well. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
parent
10ee39fe3f
commit
0425a14213
@ -97,6 +97,13 @@ static void mmci_start_data(struct mmci_host *host, struct mmc_data *data)
|
|||||||
if (data->flags & MMC_DATA_READ) {
|
if (data->flags & MMC_DATA_READ) {
|
||||||
datactrl |= MCI_DPSM_DIRECTION;
|
datactrl |= MCI_DPSM_DIRECTION;
|
||||||
irqmask = MCI_RXFIFOHALFFULLMASK;
|
irqmask = MCI_RXFIFOHALFFULLMASK;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we have less than a FIFOSIZE of bytes to transfer,
|
||||||
|
* trigger a PIO interrupt as soon as any data is available.
|
||||||
|
*/
|
||||||
|
if (host->size < MCI_FIFOSIZE)
|
||||||
|
irqmask |= MCI_RXDATAAVLBLMASK;
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
* We don't actually need to include "FIFO empty" here
|
* We don't actually need to include "FIFO empty" here
|
||||||
|
Loading…
Reference in New Issue
Block a user