mmc: sh-mmcif: avoid oops on spurious interrupts
authorGuennadi Liakhovetski <[email protected]>
Tue, 18 Sep 2012 06:42:42 +0000 (06:42 +0000)
committerChris Ball <[email protected]>
Wed, 3 Oct 2012 14:05:28 +0000 (10:05 -0400)
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 <[email protected]>
Signed-off-by: Guennadi Liakhovetski <[email protected]>
Cc: stable <[email protected]>
Signed-off-by: Chris Ball <[email protected]>
drivers/mmc/host/sh_mmcif.c

index 6df3dc3164f73c64914f4a47f2b4dee6950a8afe..11d2bc3b51d578a357fd9b857084db1a89a91741 100644 (file)
@@ -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;