swiotlb.h 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #ifndef __LINUX_SWIOTLB_H
  2. #define __LINUX_SWIOTLB_H
  3. #include <linux/types.h>
  4. struct device;
  5. struct dma_attrs;
  6. struct scatterlist;
  7. /*
  8. * Maximum allowable number of contiguous slabs to map,
  9. * must be a power of 2. What is the appropriate value ?
  10. * The complexity of {map,unmap}_single is linearly dependent on this value.
  11. */
  12. #define IO_TLB_SEGSIZE 128
  13. /*
  14. * log of the size of each IO TLB slab. The number of slabs is command line
  15. * controllable.
  16. */
  17. #define IO_TLB_SHIFT 11
  18. extern void
  19. swiotlb_init(void);
  20. extern void
  21. *swiotlb_alloc_coherent(struct device *hwdev, size_t size,
  22. dma_addr_t *dma_handle, gfp_t flags);
  23. extern void
  24. swiotlb_free_coherent(struct device *hwdev, size_t size,
  25. void *vaddr, dma_addr_t dma_handle);
  26. extern dma_addr_t swiotlb_map_page(struct device *dev, struct page *page,
  27. unsigned long offset, size_t size,
  28. enum dma_data_direction dir,
  29. struct dma_attrs *attrs);
  30. extern void swiotlb_unmap_page(struct device *hwdev, dma_addr_t dev_addr,
  31. size_t size, enum dma_data_direction dir,
  32. struct dma_attrs *attrs);
  33. extern int
  34. swiotlb_map_sg(struct device *hwdev, struct scatterlist *sg, int nents,
  35. int direction);
  36. extern void
  37. swiotlb_unmap_sg(struct device *hwdev, struct scatterlist *sg, int nents,
  38. int direction);
  39. extern int
  40. swiotlb_map_sg_attrs(struct device *hwdev, struct scatterlist *sgl, int nelems,
  41. enum dma_data_direction dir, struct dma_attrs *attrs);
  42. extern void
  43. swiotlb_unmap_sg_attrs(struct device *hwdev, struct scatterlist *sgl,
  44. int nelems, enum dma_data_direction dir,
  45. struct dma_attrs *attrs);
  46. extern void
  47. swiotlb_sync_single_for_cpu(struct device *hwdev, dma_addr_t dev_addr,
  48. size_t size, enum dma_data_direction dir);
  49. extern void
  50. swiotlb_sync_sg_for_cpu(struct device *hwdev, struct scatterlist *sg,
  51. int nelems, enum dma_data_direction dir);
  52. extern void
  53. swiotlb_sync_single_for_device(struct device *hwdev, dma_addr_t dev_addr,
  54. size_t size, enum dma_data_direction dir);
  55. extern void
  56. swiotlb_sync_sg_for_device(struct device *hwdev, struct scatterlist *sg,
  57. int nelems, enum dma_data_direction dir);
  58. extern void
  59. swiotlb_sync_single_range_for_cpu(struct device *hwdev, dma_addr_t dev_addr,
  60. unsigned long offset, size_t size,
  61. enum dma_data_direction dir);
  62. extern void
  63. swiotlb_sync_single_range_for_device(struct device *hwdev, dma_addr_t dev_addr,
  64. unsigned long offset, size_t size,
  65. enum dma_data_direction dir);
  66. extern int
  67. swiotlb_dma_mapping_error(struct device *hwdev, dma_addr_t dma_addr);
  68. extern int
  69. swiotlb_dma_supported(struct device *hwdev, u64 mask);
  70. #endif /* __LINUX_SWIOTLB_H */