|
@@ -33,14 +33,14 @@ static u64 __maybe_unused get_pfn_limit(struct device *dev)
|
|
|
struct dev_archdata __maybe_unused *sd = &dev->archdata;
|
|
|
|
|
|
#ifdef CONFIG_SWIOTLB
|
|
|
- if (sd->max_direct_dma_addr && dev->dma_ops == &swiotlb_dma_ops)
|
|
|
+ if (sd->max_direct_dma_addr && dev->dma_ops == &powerpc_swiotlb_dma_ops)
|
|
|
pfn = min_t(u64, pfn, sd->max_direct_dma_addr >> PAGE_SHIFT);
|
|
|
#endif
|
|
|
|
|
|
return pfn;
|
|
|
}
|
|
|
|
|
|
-static int dma_direct_dma_supported(struct device *dev, u64 mask)
|
|
|
+static int dma_nommu_dma_supported(struct device *dev, u64 mask)
|
|
|
{
|
|
|
#ifdef CONFIG_PPC64
|
|
|
u64 limit = get_dma_offset(dev) + (memblock_end_of_DRAM() - 1);
|
|
@@ -62,7 +62,7 @@ static int dma_direct_dma_supported(struct device *dev, u64 mask)
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
-void *__dma_direct_alloc_coherent(struct device *dev, size_t size,
|
|
|
+void *__dma_nommu_alloc_coherent(struct device *dev, size_t size,
|
|
|
dma_addr_t *dma_handle, gfp_t flag,
|
|
|
unsigned long attrs)
|
|
|
{
|
|
@@ -105,9 +105,6 @@ void *__dma_direct_alloc_coherent(struct device *dev, size_t size,
|
|
|
};
|
|
|
#endif /* CONFIG_FSL_SOC */
|
|
|
|
|
|
- /* ignore region specifiers */
|
|
|
- flag &= ~(__GFP_HIGHMEM);
|
|
|
-
|
|
|
page = alloc_pages_node(node, flag, get_order(size));
|
|
|
if (page == NULL)
|
|
|
return NULL;
|
|
@@ -119,7 +116,7 @@ void *__dma_direct_alloc_coherent(struct device *dev, size_t size,
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
-void __dma_direct_free_coherent(struct device *dev, size_t size,
|
|
|
+void __dma_nommu_free_coherent(struct device *dev, size_t size,
|
|
|
void *vaddr, dma_addr_t dma_handle,
|
|
|
unsigned long attrs)
|
|
|
{
|
|
@@ -130,7 +127,7 @@ void __dma_direct_free_coherent(struct device *dev, size_t size,
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
-static void *dma_direct_alloc_coherent(struct device *dev, size_t size,
|
|
|
+static void *dma_nommu_alloc_coherent(struct device *dev, size_t size,
|
|
|
dma_addr_t *dma_handle, gfp_t flag,
|
|
|
unsigned long attrs)
|
|
|
{
|
|
@@ -139,8 +136,8 @@ static void *dma_direct_alloc_coherent(struct device *dev, size_t size,
|
|
|
/* The coherent mask may be smaller than the real mask, check if
|
|
|
* we can really use the direct ops
|
|
|
*/
|
|
|
- if (dma_direct_dma_supported(dev, dev->coherent_dma_mask))
|
|
|
- return __dma_direct_alloc_coherent(dev, size, dma_handle,
|
|
|
+ if (dma_nommu_dma_supported(dev, dev->coherent_dma_mask))
|
|
|
+ return __dma_nommu_alloc_coherent(dev, size, dma_handle,
|
|
|
flag, attrs);
|
|
|
|
|
|
/* Ok we can't ... do we have an iommu ? If not, fail */
|
|
@@ -154,15 +151,15 @@ static void *dma_direct_alloc_coherent(struct device *dev, size_t size,
|
|
|
dev_to_node(dev));
|
|
|
}
|
|
|
|
|
|
-static void dma_direct_free_coherent(struct device *dev, size_t size,
|
|
|
+static void dma_nommu_free_coherent(struct device *dev, size_t size,
|
|
|
void *vaddr, dma_addr_t dma_handle,
|
|
|
unsigned long attrs)
|
|
|
{
|
|
|
struct iommu_table *iommu;
|
|
|
|
|
|
- /* See comments in dma_direct_alloc_coherent() */
|
|
|
- if (dma_direct_dma_supported(dev, dev->coherent_dma_mask))
|
|
|
- return __dma_direct_free_coherent(dev, size, vaddr, dma_handle,
|
|
|
+ /* See comments in dma_nommu_alloc_coherent() */
|
|
|
+ if (dma_nommu_dma_supported(dev, dev->coherent_dma_mask))
|
|
|
+ return __dma_nommu_free_coherent(dev, size, vaddr, dma_handle,
|
|
|
attrs);
|
|
|
/* Maybe we used an iommu ... */
|
|
|
iommu = get_iommu_table_base(dev);
|
|
@@ -175,7 +172,7 @@ static void dma_direct_free_coherent(struct device *dev, size_t size,
|
|
|
iommu_free_coherent(iommu, size, vaddr, dma_handle);
|
|
|
}
|
|
|
|
|
|
-int dma_direct_mmap_coherent(struct device *dev, struct vm_area_struct *vma,
|
|
|
+int dma_nommu_mmap_coherent(struct device *dev, struct vm_area_struct *vma,
|
|
|
void *cpu_addr, dma_addr_t handle, size_t size,
|
|
|
unsigned long attrs)
|
|
|
{
|
|
@@ -193,7 +190,7 @@ int dma_direct_mmap_coherent(struct device *dev, struct vm_area_struct *vma,
|
|
|
vma->vm_page_prot);
|
|
|
}
|
|
|
|
|
|
-static int dma_direct_map_sg(struct device *dev, struct scatterlist *sgl,
|
|
|
+static int dma_nommu_map_sg(struct device *dev, struct scatterlist *sgl,
|
|
|
int nents, enum dma_data_direction direction,
|
|
|
unsigned long attrs)
|
|
|
{
|
|
@@ -213,13 +210,13 @@ static int dma_direct_map_sg(struct device *dev, struct scatterlist *sgl,
|
|
|
return nents;
|
|
|
}
|
|
|
|
|
|
-static void dma_direct_unmap_sg(struct device *dev, struct scatterlist *sg,
|
|
|
+static void dma_nommu_unmap_sg(struct device *dev, struct scatterlist *sg,
|
|
|
int nents, enum dma_data_direction direction,
|
|
|
unsigned long attrs)
|
|
|
{
|
|
|
}
|
|
|
|
|
|
-static u64 dma_direct_get_required_mask(struct device *dev)
|
|
|
+static u64 dma_nommu_get_required_mask(struct device *dev)
|
|
|
{
|
|
|
u64 end, mask;
|
|
|
|
|
@@ -231,7 +228,7 @@ static u64 dma_direct_get_required_mask(struct device *dev)
|
|
|
return mask;
|
|
|
}
|
|
|
|
|
|
-static inline dma_addr_t dma_direct_map_page(struct device *dev,
|
|
|
+static inline dma_addr_t dma_nommu_map_page(struct device *dev,
|
|
|
struct page *page,
|
|
|
unsigned long offset,
|
|
|
size_t size,
|
|
@@ -246,7 +243,7 @@ static inline dma_addr_t dma_direct_map_page(struct device *dev,
|
|
|
return page_to_phys(page) + offset + get_dma_offset(dev);
|
|
|
}
|
|
|
|
|
|
-static inline void dma_direct_unmap_page(struct device *dev,
|
|
|
+static inline void dma_nommu_unmap_page(struct device *dev,
|
|
|
dma_addr_t dma_address,
|
|
|
size_t size,
|
|
|
enum dma_data_direction direction,
|
|
@@ -255,7 +252,7 @@ static inline void dma_direct_unmap_page(struct device *dev,
|
|
|
}
|
|
|
|
|
|
#ifdef CONFIG_NOT_COHERENT_CACHE
|
|
|
-static inline void dma_direct_sync_sg(struct device *dev,
|
|
|
+static inline void dma_nommu_sync_sg(struct device *dev,
|
|
|
struct scatterlist *sgl, int nents,
|
|
|
enum dma_data_direction direction)
|
|
|
{
|
|
@@ -266,7 +263,7 @@ static inline void dma_direct_sync_sg(struct device *dev,
|
|
|
__dma_sync_page(sg_page(sg), sg->offset, sg->length, direction);
|
|
|
}
|
|
|
|
|
|
-static inline void dma_direct_sync_single(struct device *dev,
|
|
|
+static inline void dma_nommu_sync_single(struct device *dev,
|
|
|
dma_addr_t dma_handle, size_t size,
|
|
|
enum dma_data_direction direction)
|
|
|
{
|
|
@@ -274,24 +271,24 @@ static inline void dma_direct_sync_single(struct device *dev,
|
|
|
}
|
|
|
#endif
|
|
|
|
|
|
-const struct dma_map_ops dma_direct_ops = {
|
|
|
- .alloc = dma_direct_alloc_coherent,
|
|
|
- .free = dma_direct_free_coherent,
|
|
|
- .mmap = dma_direct_mmap_coherent,
|
|
|
- .map_sg = dma_direct_map_sg,
|
|
|
- .unmap_sg = dma_direct_unmap_sg,
|
|
|
- .dma_supported = dma_direct_dma_supported,
|
|
|
- .map_page = dma_direct_map_page,
|
|
|
- .unmap_page = dma_direct_unmap_page,
|
|
|
- .get_required_mask = dma_direct_get_required_mask,
|
|
|
+const struct dma_map_ops dma_nommu_ops = {
|
|
|
+ .alloc = dma_nommu_alloc_coherent,
|
|
|
+ .free = dma_nommu_free_coherent,
|
|
|
+ .mmap = dma_nommu_mmap_coherent,
|
|
|
+ .map_sg = dma_nommu_map_sg,
|
|
|
+ .unmap_sg = dma_nommu_unmap_sg,
|
|
|
+ .dma_supported = dma_nommu_dma_supported,
|
|
|
+ .map_page = dma_nommu_map_page,
|
|
|
+ .unmap_page = dma_nommu_unmap_page,
|
|
|
+ .get_required_mask = dma_nommu_get_required_mask,
|
|
|
#ifdef CONFIG_NOT_COHERENT_CACHE
|
|
|
- .sync_single_for_cpu = dma_direct_sync_single,
|
|
|
- .sync_single_for_device = dma_direct_sync_single,
|
|
|
- .sync_sg_for_cpu = dma_direct_sync_sg,
|
|
|
- .sync_sg_for_device = dma_direct_sync_sg,
|
|
|
+ .sync_single_for_cpu = dma_nommu_sync_single,
|
|
|
+ .sync_single_for_device = dma_nommu_sync_single,
|
|
|
+ .sync_sg_for_cpu = dma_nommu_sync_sg,
|
|
|
+ .sync_sg_for_device = dma_nommu_sync_sg,
|
|
|
#endif
|
|
|
};
|
|
|
-EXPORT_SYMBOL(dma_direct_ops);
|
|
|
+EXPORT_SYMBOL(dma_nommu_ops);
|
|
|
|
|
|
int dma_set_coherent_mask(struct device *dev, u64 mask)
|
|
|
{
|
|
@@ -302,7 +299,7 @@ int dma_set_coherent_mask(struct device *dev, u64 mask)
|
|
|
* is no dma_op->set_coherent_mask() so we have to do
|
|
|
* things the hard way:
|
|
|
*/
|
|
|
- if (get_dma_ops(dev) != &dma_direct_ops ||
|
|
|
+ if (get_dma_ops(dev) != &dma_nommu_ops ||
|
|
|
get_iommu_table_base(dev) == NULL ||
|
|
|
!dma_iommu_dma_supported(dev, mask))
|
|
|
return -EIO;
|