swiotlb.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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 *swiotlb_alloc_boot(size_t bytes, unsigned long nslabs);
  21. extern void *swiotlb_alloc(unsigned order, unsigned long nslabs);
  22. extern dma_addr_t swiotlb_phys_to_bus(struct device *hwdev,
  23. phys_addr_t address);
  24. extern phys_addr_t swiotlb_bus_to_phys(dma_addr_t address);
  25. extern int swiotlb_arch_range_needs_mapping(void *ptr, size_t size);
  26. extern void
  27. *swiotlb_alloc_coherent(struct device *hwdev, size_t size,
  28. dma_addr_t *dma_handle, gfp_t flags);
  29. extern void
  30. swiotlb_free_coherent(struct device *hwdev, size_t size,
  31. void *vaddr, dma_addr_t dma_handle);
  32. extern dma_addr_t
  33. swiotlb_map_single(struct device *hwdev, void *ptr, size_t size, int dir);
  34. extern void
  35. swiotlb_unmap_single(struct device *hwdev, dma_addr_t dev_addr,
  36. size_t size, int dir);
  37. extern dma_addr_t
  38. swiotlb_map_single_attrs(struct device *hwdev, void *ptr, size_t size,
  39. int dir, struct dma_attrs *attrs);
  40. extern void
  41. swiotlb_unmap_single_attrs(struct device *hwdev, dma_addr_t dev_addr,
  42. size_t size, int dir, struct dma_attrs *attrs);
  43. extern int
  44. swiotlb_map_sg(struct device *hwdev, struct scatterlist *sg, int nents,
  45. int direction);
  46. extern void
  47. swiotlb_unmap_sg(struct device *hwdev, struct scatterlist *sg, int nents,
  48. int direction);
  49. extern int
  50. swiotlb_map_sg_attrs(struct device *hwdev, struct scatterlist *sgl, int nelems,
  51. int dir, struct dma_attrs *attrs);
  52. extern void
  53. swiotlb_unmap_sg_attrs(struct device *hwdev, struct scatterlist *sgl,
  54. int nelems, int dir, struct dma_attrs *attrs);
  55. extern void
  56. swiotlb_sync_single_for_cpu(struct device *hwdev, dma_addr_t dev_addr,
  57. size_t size, int dir);
  58. extern void
  59. swiotlb_sync_sg_for_cpu(struct device *hwdev, struct scatterlist *sg,
  60. int nelems, int dir);
  61. extern void
  62. swiotlb_sync_single_for_device(struct device *hwdev, dma_addr_t dev_addr,
  63. size_t size, int dir);
  64. extern void
  65. swiotlb_sync_sg_for_device(struct device *hwdev, struct scatterlist *sg,
  66. int nelems, int dir);
  67. extern void
  68. swiotlb_sync_single_range_for_cpu(struct device *hwdev, dma_addr_t dev_addr,
  69. unsigned long offset, size_t size, int dir);
  70. extern void
  71. swiotlb_sync_single_range_for_device(struct device *hwdev, dma_addr_t dev_addr,
  72. unsigned long offset, size_t size,
  73. int dir);
  74. extern int
  75. swiotlb_dma_mapping_error(struct device *hwdev, dma_addr_t dma_addr);
  76. extern int
  77. swiotlb_dma_supported(struct device *hwdev, u64 mask);
  78. #endif /* __LINUX_SWIOTLB_H */