spi/pxa2xx: use GFP_ATOMIC in sg table allocation
authorMika Westerberg <mika.westerberg@linux.intel.com>
Tue, 18 Jun 2013 14:29:44 +0000 (17:29 +0300)
committerMark Brown <broonie@linaro.org>
Tue, 18 Jun 2013 18:11:04 +0000 (19:11 +0100)
pxa2xx_spi_map_dma_buffer() gets called in tasklet context so we can't
sleep when we allocate a new sg table. Use GFP_ATOMIC here instead.

Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Signed-off-by: Mark Brown <broonie@linaro.org>
Cc: stable@vger.kernel.org
drivers/spi/spi-pxa2xx-dma.c

index c735c5a..6427600 100644 (file)
@@ -59,7 +59,7 @@ static int pxa2xx_spi_map_dma_buffer(struct driver_data *drv_data,
                int ret;
 
                sg_free_table(sgt);
-               ret = sg_alloc_table(sgt, nents, GFP_KERNEL);
+               ret = sg_alloc_table(sgt, nents, GFP_ATOMIC);
                if (ret)
                        return ret;
        }