From: Guennadi Liakhovetski Date: Tue, 18 Sep 2012 06:42:42 +0000 (+0000) Subject: mmc: sh-mmcif: avoid oops on spurious interrupts X-Git-Tag: next-20120924~61^2~5 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=416dac0f0c6caad98ffc4224517157b8b5192ea3;p=karo-tx-linux.git 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 Signed-off-by: Guennadi Liakhovetski Cc: stable Signed-off-by: Chris Ball --- diff --git a/drivers/mmc/host/sh_mmcif.c b/drivers/mmc/host/sh_mmcif.c index 6df3dc3164f7..11d2bc3b51d5 100644 --- a/drivers/mmc/host/sh_mmcif.c +++ b/drivers/mmc/host/sh_mmcif.c @@ -1231,6 +1231,10 @@ static irqreturn_t sh_mmcif_intr(int irq, void *dev_id) host->sd_error = true; 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 (!host->dma_active) return IRQ_WAKE_THREAD;