|
@@ -4,6 +4,7 @@
|
|
#include <linux/gfp.h>
|
|
#include <linux/gfp.h>
|
|
#include <linux/highmem.h>
|
|
#include <linux/highmem.h>
|
|
#include <linux/export.h>
|
|
#include <linux/export.h>
|
|
|
|
+#include <linux/memblock.h>
|
|
#include <linux/of_address.h>
|
|
#include <linux/of_address.h>
|
|
#include <linux/slab.h>
|
|
#include <linux/slab.h>
|
|
#include <linux/types.h>
|
|
#include <linux/types.h>
|
|
@@ -21,6 +22,20 @@
|
|
#include <asm/xen/hypercall.h>
|
|
#include <asm/xen/hypercall.h>
|
|
#include <asm/xen/interface.h>
|
|
#include <asm/xen/interface.h>
|
|
|
|
|
|
|
|
+unsigned long xen_get_swiotlb_free_pages(unsigned int order)
|
|
|
|
+{
|
|
|
|
+ struct memblock_region *reg;
|
|
|
|
+ gfp_t flags = __GFP_NOWARN;
|
|
|
|
+
|
|
|
|
+ for_each_memblock(memory, reg) {
|
|
|
|
+ if (reg->base < (phys_addr_t)0xffffffff) {
|
|
|
|
+ flags |= __GFP_DMA;
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return __get_free_pages(flags, order);
|
|
|
|
+}
|
|
|
|
+
|
|
enum dma_cache_op {
|
|
enum dma_cache_op {
|
|
DMA_UNMAP,
|
|
DMA_UNMAP,
|
|
DMA_MAP,
|
|
DMA_MAP,
|