diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-01-31 11:32:27 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-01-31 11:32:27 -0800 | 
| commit | 2382dc9a3eca644147be83dd2cd0dd64dc9e3e8c (patch) | |
| tree | 71a152721a9b9b11875bf5ea053edb72c9b3a94e /lib/dma-noop.c | |
| parent | 28bc6fb9596fe1e577d09fc17ee6e1bb051c6ba3 (diff) | |
| parent | 04f56534786c885f578c24461bcd782fe9a787cf (diff) | |
Merge tag 'dma-mapping-4.16' of git://git.infradead.org/users/hch/dma-mapping
Pull dma mapping updates from Christoph Hellwig:
 "Except for a runtime warning fix from Christian this is all about
  consolidation of the generic no-IOMMU code, a well as the glue code
  for swiotlb.
  All the code is based on the x86 implementation with hooks to allow
  all architectures that aren't cache coherent to use it.
  The x86 conversion itself has been deferred because the x86
  maintainers were a little busy in the last months"
* tag 'dma-mapping-4.16' of git://git.infradead.org/users/hch/dma-mapping: (57 commits)
  MAINTAINERS: add the iommu list for swiotlb and xen-swiotlb
  arm64: use swiotlb_alloc and swiotlb_free
  arm64: replace ZONE_DMA with ZONE_DMA32
  mips: use swiotlb_{alloc,free}
  mips/netlogic: remove swiotlb support
  tile: use generic swiotlb_ops
  tile: replace ZONE_DMA with ZONE_DMA32
  unicore32: use generic swiotlb_ops
  ia64: remove an ifdef around the content of pci-dma.c
  ia64: clean up swiotlb support
  ia64: use generic swiotlb_ops
  ia64: replace ZONE_DMA with ZONE_DMA32
  swiotlb: remove various exports
  swiotlb: refactor coherent buffer allocation
  swiotlb: refactor coherent buffer freeing
  swiotlb: wire up ->dma_supported in swiotlb_dma_ops
  swiotlb: add common swiotlb_map_ops
  swiotlb: rename swiotlb_free to swiotlb_exit
  x86: rename swiotlb_dma_ops
  powerpc: rename swiotlb_dma_ops
  ...
Diffstat (limited to 'lib/dma-noop.c')
| -rw-r--r-- | lib/dma-noop.c | 68 | 
1 files changed, 0 insertions, 68 deletions
| diff --git a/lib/dma-noop.c b/lib/dma-noop.c deleted file mode 100644 index a10185b0c2d4..000000000000 --- a/lib/dma-noop.c +++ /dev/null @@ -1,68 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 -/* - *	lib/dma-noop.c - * - * DMA operations that map to physical addresses without flushing memory. - */ -#include <linux/export.h> -#include <linux/mm.h> -#include <linux/dma-mapping.h> -#include <linux/scatterlist.h> -#include <linux/pfn.h> - -static void *dma_noop_alloc(struct device *dev, size_t size, -			    dma_addr_t *dma_handle, gfp_t gfp, -			    unsigned long attrs) -{ -	void *ret; - -	ret = (void *)__get_free_pages(gfp, get_order(size)); -	if (ret) -		*dma_handle = virt_to_phys(ret) - PFN_PHYS(dev->dma_pfn_offset); - -	return ret; -} - -static void dma_noop_free(struct device *dev, size_t size, -			  void *cpu_addr, dma_addr_t dma_addr, -			  unsigned long attrs) -{ -	free_pages((unsigned long)cpu_addr, get_order(size)); -} - -static dma_addr_t dma_noop_map_page(struct device *dev, struct page *page, -				      unsigned long offset, size_t size, -				      enum dma_data_direction dir, -				      unsigned long attrs) -{ -	return page_to_phys(page) + offset - PFN_PHYS(dev->dma_pfn_offset); -} - -static int dma_noop_map_sg(struct device *dev, struct scatterlist *sgl, int nents, -			     enum dma_data_direction dir, -			     unsigned long attrs) -{ -	int i; -	struct scatterlist *sg; - -	for_each_sg(sgl, sg, nents, i) { -		dma_addr_t offset = PFN_PHYS(dev->dma_pfn_offset); -		void *va; - -		BUG_ON(!sg_page(sg)); -		va = sg_virt(sg); -		sg_dma_address(sg) = (dma_addr_t)virt_to_phys(va) - offset; -		sg_dma_len(sg) = sg->length; -	} - -	return nents; -} - -const struct dma_map_ops dma_noop_ops = { -	.alloc			= dma_noop_alloc, -	.free			= dma_noop_free, -	.map_page		= dma_noop_map_page, -	.map_sg			= dma_noop_map_sg, -}; - -EXPORT_SYMBOL(dma_noop_ops); | 
