]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - arch/avr32/mm/dma-coherent.c
Merge branch 'gemini_fix' of git://git.berlios.de/gemini-board into devel-stable
[karo-tx-linux.git] / arch / avr32 / mm / dma-coherent.c
index 177fea8f7b711e90d87e208db5f9d36adaef3be6..3c0042247ea93661adbf504237be51e3d7730cec 100644 (file)
@@ -7,6 +7,7 @@
  */
 
 #include <linux/dma-mapping.h>
+#include <linux/gfp.h>
 
 #include <asm/addrspace.h>
 #include <asm/cacheflush.h>
@@ -41,6 +42,13 @@ static struct page *__dma_alloc(struct device *dev, size_t size,
        struct page *page, *free, *end;
        int order;
 
+       /* Following is a work-around (a.k.a. hack) to prevent pages
+        * with __GFP_COMP being passed to split_page() which cannot
+        * handle them.  The real problem is that this flag probably
+        * should be 0 on AVR32 as it is not supported on this
+        * platform--see CONFIG_HUGETLB_PAGE. */
+       gfp &= ~(__GFP_COMP);
+
        size = PAGE_ALIGN(size);
        order = get_order(size);