swiotlb.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. #ifndef __LINUX_SWIOTLB_H
  2. #define __LINUX_SWIOTLB_H
  3. #include <linux/dma-direction.h>
  4. #include <linux/init.h>
  5. #include <linux/types.h>
  6. struct device;
  7. struct page;
  8. struct scatterlist;
  9. enum swiotlb_force {
  10. SWIOTLB_NORMAL, /* Default - depending on HW DMA mask etc. */
  11. SWIOTLB_FORCE, /* swiotlb=force */
  12. SWIOTLB_NO_FORCE, /* swiotlb=noforce */
  13. };
  14. extern enum swiotlb_force swiotlb_force;
  15. /*
  16. * Maximum allowable number of contiguous slabs to map,
  17. * must be a power of 2. What is the appropriate value ?
  18. * The complexity of {map,unmap}_single is linearly dependent on this value.
  19. */
  20. #define IO_TLB_SEGSIZE 128
  21. /*
  22. * log of the size of each IO TLB slab. The number of slabs is command line
  23. * controllable.
  24. */
  25. #define IO_TLB_SHIFT 11
  26. extern void swiotlb_init(int verbose);
  27. int swiotlb_init_with_tbl(char *tlb, unsigned long nslabs, int verbose);
  28. extern unsigned long swiotlb_nr_tbl(void);
  29. unsigned long swiotlb_size_or_default(void);
  30. extern int swiotlb_late_init_with_tbl(char *tlb, unsigned long nslabs);
  31. /*
  32. * Enumeration for sync targets
  33. */
  34. enum dma_sync_target {
  35. SYNC_FOR_CPU = 0,
  36. SYNC_FOR_DEVICE = 1,
  37. };
  38. /* define the last possible byte of physical address space as a mapping error */
  39. #define SWIOTLB_MAP_ERROR (~(phys_addr_t)0x0)
  40. extern phys_addr_t swiotlb_tbl_map_single(struct device *hwdev,
  41. dma_addr_t tbl_dma_addr,
  42. phys_addr_t phys, size_t size,
  43. enum dma_data_direction dir);
  44. extern void swiotlb_tbl_unmap_single(struct device *hwdev,
  45. phys_addr_t tlb_addr,
  46. size_t size, enum dma_data_direction dir);
  47. extern void swiotlb_tbl_sync_single(struct device *hwdev,
  48. phys_addr_t tlb_addr,
  49. size_t size, enum dma_data_direction dir,
  50. enum dma_sync_target target);
  51. /* Accessory functions. */
  52. extern void
  53. *swiotlb_alloc_coherent(struct device *hwdev, size_t size,
  54. dma_addr_t *dma_handle, gfp_t flags);
  55. extern void
  56. swiotlb_free_coherent(struct device *hwdev, size_t size,
  57. void *vaddr, dma_addr_t dma_handle);
  58. extern dma_addr_t swiotlb_map_page(struct device *dev, struct page *page,
  59. unsigned long offset, size_t size,
  60. enum dma_data_direction dir,
  61. unsigned long attrs);
  62. extern void swiotlb_unmap_page(struct device *hwdev, dma_addr_t dev_addr,
  63. size_t size, enum dma_data_direction dir,
  64. unsigned long attrs);
  65. extern int
  66. swiotlb_map_sg(struct device *hwdev, struct scatterlist *sg, int nents,
  67. enum dma_data_direction dir);
  68. extern void
  69. swiotlb_unmap_sg(struct device *hwdev, struct scatterlist *sg, int nents,
  70. enum dma_data_direction dir);
  71. extern int
  72. swiotlb_map_sg_attrs(struct device *hwdev, struct scatterlist *sgl, int nelems,
  73. enum dma_data_direction dir,
  74. unsigned long attrs);
  75. extern void
  76. swiotlb_unmap_sg_attrs(struct device *hwdev, struct scatterlist *sgl,
  77. int nelems, enum dma_data_direction dir,
  78. unsigned long attrs);
  79. extern void
  80. swiotlb_sync_single_for_cpu(struct device *hwdev, dma_addr_t dev_addr,
  81. size_t size, enum dma_data_direction dir);
  82. extern void
  83. swiotlb_sync_sg_for_cpu(struct device *hwdev, struct scatterlist *sg,
  84. int nelems, enum dma_data_direction dir);
  85. extern void
  86. swiotlb_sync_single_for_device(struct device *hwdev, dma_addr_t dev_addr,
  87. size_t size, enum dma_data_direction dir);
  88. extern void
  89. swiotlb_sync_sg_for_device(struct device *hwdev, struct scatterlist *sg,
  90. int nelems, enum dma_data_direction dir);
  91. extern int
  92. swiotlb_dma_mapping_error(struct device *hwdev, dma_addr_t dma_addr);
  93. extern int
  94. swiotlb_dma_supported(struct device *hwdev, u64 mask);
  95. #ifdef CONFIG_SWIOTLB
  96. extern void __init swiotlb_free(void);
  97. #else
  98. static inline void swiotlb_free(void) { }
  99. #endif
  100. extern void swiotlb_print_info(void);
  101. extern int is_swiotlb_buffer(phys_addr_t paddr);
  102. #endif /* __LINUX_SWIOTLB_H */