Commit f3584e5e authored by Venkatraman S's avatar Venkatraman S Committed by Linus Torvalds

omap hsmmc: fix processing of all dma interrupts as block completion

If other informative interrupts are enabled for the DMA channel used by
hsmmc, those are incorrectly treated as block completion.  This patch lets
only the block completion interrupt to be processed.
Signed-off-by: default avatarVenkatraman S <svenkatr@ti.com>
Acked-by: default avatarMadhusudhan Chikkature <madhu.cr@ti.com>
Cc: <linux-mmc@vger.kernel.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 762333e3
...@@ -1273,8 +1273,11 @@ static void omap_hsmmc_dma_cb(int lch, u16 ch_status, void *cb_data) ...@@ -1273,8 +1273,11 @@ static void omap_hsmmc_dma_cb(int lch, u16 ch_status, void *cb_data)
struct mmc_data *data = host->mrq->data; struct mmc_data *data = host->mrq->data;
int dma_ch, req_in_progress; int dma_ch, req_in_progress;
if (ch_status & OMAP2_DMA_MISALIGNED_ERR_IRQ) if (!(ch_status & OMAP_DMA_BLOCK_IRQ)) {
dev_dbg(mmc_dev(host->mmc), "MISALIGNED_ADRS_ERR\n"); dev_warn(mmc_dev(host->mmc), "unexpected dma status %x\n",
ch_status);
return;
}
spin_lock(&host->irq_lock); spin_lock(&host->irq_lock);
if (host->dma_ch < 0) { if (host->dma_ch < 0) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment