mmc: sh-mmcif: avoid oops on spurious interrupts
On some systems, e.g., kzm9g, MMCIF interfaces can produce spurious interrupts without any active request. To prevent the Oops, that results in such cases, don't dereference the mmc request pointer until we make sure, that we are indeed processing such a request. Reported-by: Tetsuyuki Kobayashi <koba@kmckk.co.jp> Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de> Cc: stable <stable@vger.kernel.org> Signed-off-by: Chris Ball <cjb@laptop.org>
This commit is contained in:
parent
7a7eb3286b
commit
8464dd52d3
@ -1231,6 +1231,10 @@ static irqreturn_t sh_mmcif_intr(int irq, void *dev_id)
|
|||||||
host->sd_error = true;
|
host->sd_error = true;
|
||||||
dev_dbg(&host->pd->dev, "int err state = %08x\n", state);
|
dev_dbg(&host->pd->dev, "int err state = %08x\n", state);
|
||||||
}
|
}
|
||||||
|
if (host->state == STATE_IDLE) {
|
||||||
|
dev_info(&host->pd->dev, "Spurious IRQ status 0x%x", state);
|
||||||
|
return IRQ_HANDLED;
|
||||||
|
}
|
||||||
if (state & ~(INT_CMD12RBE | INT_CMD12CRE)) {
|
if (state & ~(INT_CMD12RBE | INT_CMD12CRE)) {
|
||||||
if (!host->dma_active)
|
if (!host->dma_active)
|
||||||
return IRQ_WAKE_THREAD;
|
return IRQ_WAKE_THREAD;
|
||||||
|
Loading…
Reference in New Issue
Block a user