Adrian Hunter <adrian.hunter@xxxxxxxxx> wrote: > Venkatraman S wrote: >> >> On Tue, Apr 13, 2010 at 3:17 PM, Adrian Hunter <adrian.hunter@xxxxxxxxx> >> wrote: >>> >>> Venkatraman S wrote: >>>> >>>> This patch addresses the possible race condition between the dma >>>> callback and hsmmc callback. >>> >>> Can you explain the problem in more detail? If the final DMA interrupt >>> comes before TC then all should be well. >> >> Actually it isn't, with descriptor loading. If the DMA callback arrives >> "too early", the MMC TC is missed sometimes. The last transfer in the log >> below is actually stalled waiting for TC. This happens more often when the >> transfer is large (> 300 blocks) > > You seem to be saying that, in the case of descriptor loading, the DMA > callback > does not indicate that the DMA is complete. Isn't that a problem with > descriptor > loading? > My understanding from the existing code <snip> /* * If for some reason the DMA transfer is still active, * we wait for timeout period and free the dma */ if (host->dma_ch != -1) { set_current_state(TASK_UNINTERRUPTIBLE); </snip> is that it's rare, but not impossible, for the DMA to be active even when the TC has been received. At the same time, I found one issue in descriptor loading after I sent the email yesterday, which could fix the problem I am seeing. >> >>> If it comes after, then we need >>> to be sure that the DMA has finished - particularly in the "read" case. >>> Neither the existing code nor this patch seems to address that issue. >>> >> With this patch the assumption is that MMC TC correctly signals the >> end of read / write as requested. I don't know if there are any specific >> reasons >> to believe otherwise. > > It would be nice if there were a way to check that the DMA is complete. i.e. > if TC is received but DMA is not complete then set an error by calling > omap_hsmmc_dma_cleanup() instead of omap_hsmmc_xfer_done() > Yes, I was testing such a mechanism as well. Is it better to abort the transfer by setting an error, or do the omap_hsmmc_xfer_done() at the callback of whichever interrupt comes last ? -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html