[PATCH] mmci: fixup broken_blockend variant patch v2
Russell King - ARM Linux
linux at arm.linux.org.uk
Wed Jan 19 15:51:58 EST 2011
On Wed, Jan 19, 2011 at 09:34:49PM +0100, Linus Walleij wrote:
> 2011/1/18 Russell King - ARM Linux <linux at arm.linux.org.uk>:
>
> > How reliable is the FIFOCNT register ?
> >
> > What I'm wondering is whether we can get rid of the DATABLOCKEND
> > interrupts completely, and instead read the FIFOCNT register to
> > discover how many blocks have been successfully transferred. FIFOCNT
> > on read gives you the remaining number of words to be transferred into
> > the FIFO from the card, not the number of words still to be read by the
> > host CPU.
>
> Hmm... the FIFOCNT is just the FIFO.
No, FIFOCNT.
The MCIFifoCnt register contains the remaining number of words to be
written to or read from the FIFO. The FIFO counter loads the value from
the data length register (see Data length register, MCIDataLength on page
3-11) when the Enable bit is set in the data control register. If the data
length is not word aligned (multiple of 4), the remaining 1 to 3 bytes are
regarded as a word. Table 3-19 shows the bit assignment of the MCIFifoCnt
register.
static int mmci_pio_read(struct mmci_host *host, char *buffer, unsigned int remain)
{
do {
int count = host_remain - (readl(base + MMCIFIFOCNT) << 2);
if (count > remain)
count = remain;
if (count <= 0)
break;
readsl(base + MMCIFIFO, ptr, count >> 2);
We use FIFOCNT to work out how many bytes are needing to be transferred
from the FIFO on PIO reads.
More information about the linux-arm-kernel
mailing list