|
@@ -1136,10 +1136,22 @@ static int __iommu_remove_mapping(struct device *dev, dma_addr_t iova, size_t si
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
+static struct page **__atomic_get_pages(void *addr)
|
|
|
+{
|
|
|
+ struct dma_pool *pool = &atomic_pool;
|
|
|
+ struct page **pages = pool->pages;
|
|
|
+ int offs = (addr - pool->vaddr) >> PAGE_SHIFT;
|
|
|
+
|
|
|
+ return pages + offs;
|
|
|
+}
|
|
|
+
|
|
|
static struct page **__iommu_get_pages(void *cpu_addr, struct dma_attrs *attrs)
|
|
|
{
|
|
|
struct vm_struct *area;
|
|
|
|
|
|
+ if (__in_atomic_pool(cpu_addr, PAGE_SIZE))
|
|
|
+ return __atomic_get_pages(cpu_addr);
|
|
|
+
|
|
|
if (dma_get_attr(DMA_ATTR_NO_KERNEL_MAPPING, attrs))
|
|
|
return cpu_addr;
|
|
|
|