| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _ASM_SPARC64_DMA_MAPPING_H | 
|  | 2 | #define _ASM_SPARC64_DMA_MAPPING_H | 
|  | 3 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 4 | #include <linux/scatterlist.h> | 
| David S. Miller | 42f1423 | 2006-05-23 02:07:22 -0700 | [diff] [blame] | 5 | #include <linux/mm.h> | 
|  | 6 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 7 | #define DMA_ERROR_CODE	(~(dma_addr_t)0x0) | 
| David S. Miller | 9ac6d4a | 2007-05-14 02:56:03 -0700 | [diff] [blame] | 8 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 9 | struct dma_ops { | 
|  | 10 | void *(*alloc_coherent)(struct device *dev, size_t size, | 
|  | 11 | dma_addr_t *dma_handle, gfp_t flag); | 
|  | 12 | void (*free_coherent)(struct device *dev, size_t size, | 
|  | 13 | void *cpu_addr, dma_addr_t dma_handle); | 
|  | 14 | dma_addr_t (*map_single)(struct device *dev, void *cpu_addr, | 
|  | 15 | size_t size, | 
|  | 16 | enum dma_data_direction direction); | 
|  | 17 | void (*unmap_single)(struct device *dev, dma_addr_t dma_addr, | 
|  | 18 | size_t size, | 
|  | 19 | enum dma_data_direction direction); | 
|  | 20 | int (*map_sg)(struct device *dev, struct scatterlist *sg, int nents, | 
|  | 21 | enum dma_data_direction direction); | 
|  | 22 | void (*unmap_sg)(struct device *dev, struct scatterlist *sg, | 
|  | 23 | int nhwentries, | 
|  | 24 | enum dma_data_direction direction); | 
|  | 25 | void (*sync_single_for_cpu)(struct device *dev, | 
|  | 26 | dma_addr_t dma_handle, size_t size, | 
|  | 27 | enum dma_data_direction direction); | 
|  | 28 | void (*sync_single_for_device)(struct device *dev, | 
|  | 29 | dma_addr_t dma_handle, size_t size, | 
|  | 30 | enum dma_data_direction direction); | 
|  | 31 | void (*sync_sg_for_cpu)(struct device *dev, struct scatterlist *sg, | 
|  | 32 | int nelems, | 
|  | 33 | enum dma_data_direction direction); | 
|  | 34 | void (*sync_sg_for_device)(struct device *dev, struct scatterlist *sg, | 
|  | 35 | int nelems, | 
|  | 36 | enum dma_data_direction direction); | 
|  | 37 | }; | 
|  | 38 | extern const struct dma_ops *dma_ops; | 
| David S. Miller | 42f1423 | 2006-05-23 02:07:22 -0700 | [diff] [blame] | 39 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 40 | extern int dma_supported(struct device *dev, u64 mask); | 
|  | 41 | extern int dma_set_mask(struct device *dev, u64 dma_mask); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 42 |  | 
|  | 43 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 44 | dma_addr_t *dma_handle, gfp_t flag) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 46 | return dma_ops->alloc_coherent(dev, size, dma_handle, flag); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 47 | } | 
|  | 48 |  | 
|  | 49 | static inline void dma_free_coherent(struct device *dev, size_t size, | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 50 | void *cpu_addr, dma_addr_t dma_handle) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 51 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 52 | dma_ops->free_coherent(dev, size, cpu_addr, dma_handle); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 53 | } | 
|  | 54 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 55 | static inline dma_addr_t dma_map_single(struct device *dev, void *cpu_addr, | 
|  | 56 | size_t size, | 
|  | 57 | enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 58 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 59 | return dma_ops->map_single(dev, cpu_addr, size, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 60 | } | 
|  | 61 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 62 | static inline void dma_unmap_single(struct device *dev, dma_addr_t dma_addr, | 
|  | 63 | size_t size, | 
|  | 64 | enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 65 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 66 | dma_ops->unmap_single(dev, dma_addr, size, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 67 | } | 
|  | 68 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 69 | static inline dma_addr_t dma_map_page(struct device *dev, struct page *page, | 
|  | 70 | unsigned long offset, size_t size, | 
|  | 71 | enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 72 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 73 | return dma_ops->map_single(dev, page_address(page) + offset, | 
|  | 74 | size, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 75 | } | 
|  | 76 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 77 | static inline void dma_unmap_page(struct device *dev, dma_addr_t dma_address, | 
|  | 78 | size_t size, | 
|  | 79 | enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 80 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 81 | dma_ops->unmap_single(dev, dma_address, size, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 82 | } | 
|  | 83 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 84 | static inline int dma_map_sg(struct device *dev, struct scatterlist *sg, | 
|  | 85 | int nents, enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 86 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 87 | return dma_ops->map_sg(dev, sg, nents, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 88 | } | 
|  | 89 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 90 | static inline void dma_unmap_sg(struct device *dev, struct scatterlist *sg, | 
|  | 91 | int nents, enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 92 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 93 | dma_ops->unmap_sg(dev, sg, nents, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 94 | } | 
|  | 95 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 96 | static inline void dma_sync_single_for_cpu(struct device *dev, | 
|  | 97 | dma_addr_t dma_handle, size_t size, | 
|  | 98 | enum dma_data_direction direction) | 
| Randy Dunlap | 7233589 | 2006-07-05 20:18:39 -0700 | [diff] [blame] | 99 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 100 | dma_ops->sync_single_for_cpu(dev, dma_handle, size, direction); | 
| Randy Dunlap | 7233589 | 2006-07-05 20:18:39 -0700 | [diff] [blame] | 101 | } | 
|  | 102 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 103 | static inline void dma_sync_single_for_device(struct device *dev, | 
|  | 104 | dma_addr_t dma_handle, | 
|  | 105 | size_t size, | 
|  | 106 | enum dma_data_direction direction) | 
| Randy Dunlap | 7233589 | 2006-07-05 20:18:39 -0700 | [diff] [blame] | 107 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 108 | dma_ops->sync_single_for_device(dev, dma_handle, size, direction); | 
| Randy Dunlap | 7233589 | 2006-07-05 20:18:39 -0700 | [diff] [blame] | 109 | } | 
|  | 110 |  | 
| David S. Miller | 6321319 | 2007-07-31 20:43:17 -0700 | [diff] [blame] | 111 | static inline void dma_sync_single_range_for_cpu(struct device *dev, | 
|  | 112 | dma_addr_t dma_handle, | 
|  | 113 | unsigned long offset, | 
|  | 114 | size_t size, | 
|  | 115 | enum dma_data_direction direction) | 
|  | 116 | { | 
|  | 117 | dma_sync_single_for_cpu(dev, dma_handle+offset, size, direction); | 
|  | 118 | } | 
|  | 119 |  | 
|  | 120 | static inline void dma_sync_single_range_for_device(struct device *dev, | 
|  | 121 | dma_addr_t dma_handle, | 
|  | 122 | unsigned long offset, | 
|  | 123 | size_t size, | 
|  | 124 | enum dma_data_direction direction) | 
|  | 125 | { | 
|  | 126 | dma_sync_single_for_device(dev, dma_handle+offset, size, direction); | 
|  | 127 | } | 
|  | 128 |  | 
|  | 129 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 130 | static inline void dma_sync_sg_for_cpu(struct device *dev, | 
|  | 131 | struct scatterlist *sg, int nelems, | 
|  | 132 | enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 133 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 134 | dma_ops->sync_sg_for_cpu(dev, sg, nelems, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 135 | } | 
|  | 136 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 137 | static inline void dma_sync_sg_for_device(struct device *dev, | 
|  | 138 | struct scatterlist *sg, int nelems, | 
|  | 139 | enum dma_data_direction direction) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 140 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 141 | dma_ops->sync_sg_for_device(dev, sg, nelems, direction); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 142 | } | 
|  | 143 |  | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 144 | static inline int dma_mapping_error(dma_addr_t dma_addr) | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 145 | { | 
| David S. Miller | ad7ad57 | 2007-07-27 22:39:14 -0700 | [diff] [blame] | 146 | return (dma_addr == DMA_ERROR_CODE); | 
| David S. Miller | f04dbac | 2007-06-04 23:32:23 -0700 | [diff] [blame] | 147 | } | 
|  | 148 |  | 
| Andrew Morton | e5071b5 | 2007-07-31 01:28:33 -0700 | [diff] [blame] | 149 | static inline int dma_get_cache_alignment(void) | 
|  | 150 | { | 
|  | 151 | /* no easy way to get cache size on all processors, so return | 
|  | 152 | * the maximum possible, to be safe */ | 
|  | 153 | return (1 << INTERNODE_CACHE_SHIFT); | 
|  | 154 | } | 
|  | 155 |  | 
| David S. Miller | 3632142 | 2006-06-25 02:07:52 -0700 | [diff] [blame] | 156 | #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f) | 
|  | 157 | #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h) | 
| Ralf Baechle | f67637e | 2006-12-06 20:38:54 -0800 | [diff] [blame] | 158 | #define dma_is_consistent(d, h)	(1) | 
| David S. Miller | 3632142 | 2006-06-25 02:07:52 -0700 | [diff] [blame] | 159 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 160 | #endif /* _ASM_SPARC64_DMA_MAPPING_H */ |