• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* include this file if the platform implements the dma_ DMA Mapping API
3  * and wants to provide the pci_ DMA Mapping API in terms of it */
4 
5 #ifndef _ASM_GENERIC_PCI_DMA_COMPAT_H
6 #define _ASM_GENERIC_PCI_DMA_COMPAT_H
7 
8 #include <linux/dma-mapping.h>
9 
10 /* This defines the direction arg to the DMA mapping routines. */
11 #define PCI_DMA_BIDIRECTIONAL	DMA_BIDIRECTIONAL
12 #define PCI_DMA_TODEVICE	DMA_TO_DEVICE
13 #define PCI_DMA_FROMDEVICE	DMA_FROM_DEVICE
14 #define PCI_DMA_NONE		DMA_NONE
15 
16 static inline void *
pci_alloc_consistent(struct pci_dev * hwdev,size_t size,dma_addr_t * dma_handle)17 pci_alloc_consistent(struct pci_dev *hwdev, size_t size,
18 		     dma_addr_t *dma_handle)
19 {
20 	return dma_alloc_coherent(&hwdev->dev, size, dma_handle, GFP_ATOMIC);
21 }
22 
23 static inline void *
pci_zalloc_consistent(struct pci_dev * hwdev,size_t size,dma_addr_t * dma_handle)24 pci_zalloc_consistent(struct pci_dev *hwdev, size_t size,
25 		      dma_addr_t *dma_handle)
26 {
27 	return dma_alloc_coherent(&hwdev->dev, size, dma_handle, GFP_ATOMIC);
28 }
29 
30 static inline void
pci_free_consistent(struct pci_dev * hwdev,size_t size,void * vaddr,dma_addr_t dma_handle)31 pci_free_consistent(struct pci_dev *hwdev, size_t size,
32 		    void *vaddr, dma_addr_t dma_handle)
33 {
34 	dma_free_coherent(&hwdev->dev, size, vaddr, dma_handle);
35 }
36 
37 static inline dma_addr_t
pci_map_single(struct pci_dev * hwdev,void * ptr,size_t size,int direction)38 pci_map_single(struct pci_dev *hwdev, void *ptr, size_t size, int direction)
39 {
40 	return dma_map_single(&hwdev->dev, ptr, size, (enum dma_data_direction)direction);
41 }
42 
43 static inline void
pci_unmap_single(struct pci_dev * hwdev,dma_addr_t dma_addr,size_t size,int direction)44 pci_unmap_single(struct pci_dev *hwdev, dma_addr_t dma_addr,
45 		 size_t size, int direction)
46 {
47 	dma_unmap_single(&hwdev->dev, dma_addr, size, (enum dma_data_direction)direction);
48 }
49 
50 static inline dma_addr_t
pci_map_page(struct pci_dev * hwdev,struct page * page,unsigned long offset,size_t size,int direction)51 pci_map_page(struct pci_dev *hwdev, struct page *page,
52 	     unsigned long offset, size_t size, int direction)
53 {
54 	return dma_map_page(&hwdev->dev, page, offset, size, (enum dma_data_direction)direction);
55 }
56 
57 static inline void
pci_unmap_page(struct pci_dev * hwdev,dma_addr_t dma_address,size_t size,int direction)58 pci_unmap_page(struct pci_dev *hwdev, dma_addr_t dma_address,
59 	       size_t size, int direction)
60 {
61 	dma_unmap_page(&hwdev->dev, dma_address, size, (enum dma_data_direction)direction);
62 }
63 
64 static inline int
pci_map_sg(struct pci_dev * hwdev,struct scatterlist * sg,int nents,int direction)65 pci_map_sg(struct pci_dev *hwdev, struct scatterlist *sg,
66 	   int nents, int direction)
67 {
68 	return dma_map_sg(&hwdev->dev, sg, nents, (enum dma_data_direction)direction);
69 }
70 
71 static inline void
pci_unmap_sg(struct pci_dev * hwdev,struct scatterlist * sg,int nents,int direction)72 pci_unmap_sg(struct pci_dev *hwdev, struct scatterlist *sg,
73 	     int nents, int direction)
74 {
75 	dma_unmap_sg(&hwdev->dev, sg, nents, (enum dma_data_direction)direction);
76 }
77 
78 static inline void
pci_dma_sync_single_for_cpu(struct pci_dev * hwdev,dma_addr_t dma_handle,size_t size,int direction)79 pci_dma_sync_single_for_cpu(struct pci_dev *hwdev, dma_addr_t dma_handle,
80 		    size_t size, int direction)
81 {
82 	dma_sync_single_for_cpu(&hwdev->dev, dma_handle, size, (enum dma_data_direction)direction);
83 }
84 
85 static inline void
pci_dma_sync_single_for_device(struct pci_dev * hwdev,dma_addr_t dma_handle,size_t size,int direction)86 pci_dma_sync_single_for_device(struct pci_dev *hwdev, dma_addr_t dma_handle,
87 		    size_t size, int direction)
88 {
89 	dma_sync_single_for_device(&hwdev->dev, dma_handle, size, (enum dma_data_direction)direction);
90 }
91 
92 static inline void
pci_dma_sync_sg_for_cpu(struct pci_dev * hwdev,struct scatterlist * sg,int nelems,int direction)93 pci_dma_sync_sg_for_cpu(struct pci_dev *hwdev, struct scatterlist *sg,
94 		int nelems, int direction)
95 {
96 	dma_sync_sg_for_cpu(&hwdev->dev, sg, nelems, (enum dma_data_direction)direction);
97 }
98 
99 static inline void
pci_dma_sync_sg_for_device(struct pci_dev * hwdev,struct scatterlist * sg,int nelems,int direction)100 pci_dma_sync_sg_for_device(struct pci_dev *hwdev, struct scatterlist *sg,
101 		int nelems, int direction)
102 {
103 	dma_sync_sg_for_device(&hwdev->dev, sg, nelems, (enum dma_data_direction)direction);
104 }
105 
106 static inline int
pci_dma_mapping_error(struct pci_dev * pdev,dma_addr_t dma_addr)107 pci_dma_mapping_error(struct pci_dev *pdev, dma_addr_t dma_addr)
108 {
109 	return dma_mapping_error(&pdev->dev, dma_addr);
110 }
111 
112 #ifdef CONFIG_PCI
pci_set_dma_mask(struct pci_dev * dev,u64 mask)113 static inline int pci_set_dma_mask(struct pci_dev *dev, u64 mask)
114 {
115 	return dma_set_mask(&dev->dev, mask);
116 }
117 
pci_set_consistent_dma_mask(struct pci_dev * dev,u64 mask)118 static inline int pci_set_consistent_dma_mask(struct pci_dev *dev, u64 mask)
119 {
120 	return dma_set_coherent_mask(&dev->dev, mask);
121 }
122 #else
pci_set_dma_mask(struct pci_dev * dev,u64 mask)123 static inline int pci_set_dma_mask(struct pci_dev *dev, u64 mask)
124 { return -EIO; }
pci_set_consistent_dma_mask(struct pci_dev * dev,u64 mask)125 static inline int pci_set_consistent_dma_mask(struct pci_dev *dev, u64 mask)
126 { return -EIO; }
127 #endif
128 
129 #endif
130