wimax/i2400m/sdio: clear the INTR status bit after reading size
authorCindy H Kao <cindy.h.kao@intel.com>
Tue, 11 Aug 2009 01:36:15 +0000 (18:36 -0700)
committerInaky Perez-Gonzalez <inaky@linux.intel.com>
Mon, 19 Oct 2009 06:55:45 +0000 (15:55 +0900)
In order to avoid issues during high-load traffic, the interrupt
status register has to be cleared ONLY after the RX size is read.

Signed-off-by: Cindy H Kao <cindy.h.kao@intel.com>
Signed-off-by: Inaky Perez-Gonzalez <inaky@linux.intel.com>
drivers/net/wimax/i2400m/sdio-rx.c

index f6ca51ab216d263b39b8716bbcd41693b808f5bf..1c9046914bd17aadfd225a0ad9c5c0078f52082d 100644 (file)
@@ -138,6 +138,11 @@ void i2400ms_rx(struct i2400ms *i2400ms)
                ret = rx_size;
                goto error_get_size;
        }
+       /*
+        * Hardware quirk: make sure to clear the INTR status register
+        * AFTER getting the data transfer size.
+        */
+       sdio_writeb(func, 1, I2400MS_INTR_CLEAR_ADDR, &ret);
 
        ret = -ENOMEM;
        skb = alloc_skb(rx_size, GFP_ATOMIC);
@@ -209,7 +214,6 @@ void i2400ms_irq(struct sdio_func *func)
                dev_err(dev, "RX: BUG? got IRQ but no interrupt ready?\n");
                goto error_no_irq;
        }
-       sdio_writeb(func, 1, I2400MS_INTR_CLEAR_ADDR, &ret);
        i2400ms_rx(i2400ms);
 error_no_irq:
        d_fnend(6, dev, "(i2400ms %p) = void\n", i2400ms);