Hello. Russell King wrote:
From: Sergei Shtylyov <sshtylyov@xxxxxxxxxxxxx> Date: Mon, 04 Jan 2010 22:14:55 +0300
I suggest that we completely ignore the "FIFO empty" bit. dma_test_irq() method which is called eventually when doing FMA should yield the needed result WRT FIFO flushing, filtering out .
Can someone implement and test such a revised patch?
Do we have any guarantee that the interrupt bit in this register will only be set when the DMA FIFOs on the card have emptied?
Unlike the SFF status register's interrupt bit, which is defined by SFF to only be asserted when the drive signals an interrupt _and_ the FIFOs have emptied, there seems to be no such words in the PDC20246 data which suggests that the same is true of the interrupt bit in this alternative register.
So what? The SFF status register will be read eventually.
Therefore, I would suggest that using this alternative bit could be unsafe with shared interrupts without also qualifying it with the FIFO empty bit - we could end up disabling the DMA before the transfer has completed, thereby corrupting the last few words of a transfer from the drive.
How so?
What was the reason for checking this alternate promise-special register in the first place, rather than the SFF BM-DMA status register?
It's not "rather then" -- we're checking both. MBR, Sergei -- To unsubscribe from this list: send the line "unsubscribe linux-ide" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html