diff options
Diffstat (limited to 'include')
| -rw-r--r-- | include/asm-generic/dma-coherent.h | 1 | ||||
| -rw-r--r-- | include/asm-generic/dma-mapping-common.h | 55 | ||||
| -rw-r--r-- | include/linux/dma-attrs.h | 2 | ||||
| -rw-r--r-- | include/linux/dma-mapping.h | 3 | ||||
| -rw-r--r-- | include/linux/scatterlist.h | 4 | ||||
| -rw-r--r-- | include/linux/vmalloc.h | 9 |
6 files changed, 70 insertions, 4 deletions
diff --git a/include/asm-generic/dma-coherent.h b/include/asm-generic/dma-coherent.h index abfb2682de7f..2be8a2dbc868 100644 --- a/include/asm-generic/dma-coherent.h +++ b/include/asm-generic/dma-coherent.h | |||
| @@ -29,6 +29,7 @@ dma_mark_declared_memory_occupied(struct device *dev, | |||
| 29 | #else | 29 | #else |
| 30 | #define dma_alloc_from_coherent(dev, size, handle, ret) (0) | 30 | #define dma_alloc_from_coherent(dev, size, handle, ret) (0) |
| 31 | #define dma_release_from_coherent(dev, order, vaddr) (0) | 31 | #define dma_release_from_coherent(dev, order, vaddr) (0) |
| 32 | #define dma_mmap_from_coherent(dev, vma, vaddr, order, ret) (0) | ||
| 32 | #endif | 33 | #endif |
| 33 | 34 | ||
| 34 | #endif | 35 | #endif |
diff --git a/include/asm-generic/dma-mapping-common.h b/include/asm-generic/dma-mapping-common.h index 2e248d8924dc..de8bf89940f8 100644 --- a/include/asm-generic/dma-mapping-common.h +++ b/include/asm-generic/dma-mapping-common.h | |||
| @@ -176,4 +176,59 @@ dma_sync_sg_for_device(struct device *dev, struct scatterlist *sg, | |||
| 176 | #define dma_map_sg(d, s, n, r) dma_map_sg_attrs(d, s, n, r, NULL) | 176 | #define dma_map_sg(d, s, n, r) dma_map_sg_attrs(d, s, n, r, NULL) |
| 177 | #define dma_unmap_sg(d, s, n, r) dma_unmap_sg_attrs(d, s, n, r, NULL) | 177 | #define dma_unmap_sg(d, s, n, r) dma_unmap_sg_attrs(d, s, n, r, NULL) |
| 178 | 178 | ||
| 179 | extern int dma_common_mmap(struct device *dev, struct vm_area_struct *vma, | ||
| 180 | void *cpu_addr, dma_addr_t dma_addr, size_t size); | ||
| 181 | |||
| 182 | /** | ||
| 183 | * dma_mmap_attrs - map a coherent DMA allocation into user space | ||
| 184 | * @dev: valid struct device pointer, or NULL for ISA and EISA-like devices | ||
| 185 | * @vma: vm_area_struct describing requested user mapping | ||
| 186 | * @cpu_addr: kernel CPU-view address returned from dma_alloc_attrs | ||
| 187 | * @handle: device-view address returned from dma_alloc_attrs | ||
| 188 | * @size: size of memory originally requested in dma_alloc_attrs | ||
| 189 | * @attrs: attributes of mapping properties requested in dma_alloc_attrs | ||
| 190 | * | ||
| 191 | * Map a coherent DMA buffer previously allocated by dma_alloc_attrs | ||
| 192 | * into user space. The coherent DMA buffer must not be freed by the | ||
| 193 | * driver until the user space mapping has been released. | ||
| 194 | */ | ||
| 195 | static inline int | ||
| 196 | dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, void *cpu_addr, | ||
| 197 | dma_addr_t dma_addr, size_t size, struct dma_attrs *attrs) | ||
| 198 | { | ||
| 199 | struct dma_map_ops *ops = get_dma_ops(dev); | ||
| 200 | BUG_ON(!ops); | ||
| 201 | if (ops->mmap) | ||
| 202 | return ops->mmap(dev, vma, cpu_addr, dma_addr, size, attrs); | ||
| 203 | return dma_common_mmap(dev, vma, cpu_addr, dma_addr, size); | ||
| 204 | } | ||
| 205 | |||
| 206 | #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) | ||
| 207 | |||
| 208 | static inline int dma_mmap_writecombine(struct device *dev, struct vm_area_struct *vma, | ||
| 209 | void *cpu_addr, dma_addr_t dma_addr, size_t size) | ||
| 210 | { | ||
| 211 | DEFINE_DMA_ATTRS(attrs); | ||
| 212 | dma_set_attr(DMA_ATTR_WRITE_COMBINE, &attrs); | ||
| 213 | return dma_mmap_attrs(dev, vma, cpu_addr, dma_addr, size, &attrs); | ||
| 214 | } | ||
| 215 | |||
| 216 | int | ||
| 217 | dma_common_get_sgtable(struct device *dev, struct sg_table *sgt, | ||
| 218 | void *cpu_addr, dma_addr_t dma_addr, size_t size); | ||
| 219 | |||
| 220 | static inline int | ||
| 221 | dma_get_sgtable_attrs(struct device *dev, struct sg_table *sgt, void *cpu_addr, | ||
| 222 | dma_addr_t dma_addr, size_t size, struct dma_attrs *attrs) | ||
| 223 | { | ||
| 224 | struct dma_map_ops *ops = get_dma_ops(dev); | ||
| 225 | BUG_ON(!ops); | ||
| 226 | if (ops->get_sgtable) | ||
| 227 | return ops->get_sgtable(dev, sgt, cpu_addr, dma_addr, size, | ||
| 228 | attrs); | ||
| 229 | return dma_common_get_sgtable(dev, sgt, cpu_addr, dma_addr, size); | ||
| 230 | } | ||
| 231 | |||
| 232 | #define dma_get_sgtable(d, t, v, h, s) dma_get_sgtable_attrs(d, t, v, h, s, NULL) | ||
| 233 | |||
| 179 | #endif | 234 | #endif |
diff --git a/include/linux/dma-attrs.h b/include/linux/dma-attrs.h index 547ab568d3ae..f83f793223ff 100644 --- a/include/linux/dma-attrs.h +++ b/include/linux/dma-attrs.h | |||
| @@ -15,6 +15,8 @@ enum dma_attr { | |||
| 15 | DMA_ATTR_WEAK_ORDERING, | 15 | DMA_ATTR_WEAK_ORDERING, |
| 16 | DMA_ATTR_WRITE_COMBINE, | 16 | DMA_ATTR_WRITE_COMBINE, |
| 17 | DMA_ATTR_NON_CONSISTENT, | 17 | DMA_ATTR_NON_CONSISTENT, |
| 18 | DMA_ATTR_NO_KERNEL_MAPPING, | ||
| 19 | DMA_ATTR_SKIP_CPU_SYNC, | ||
| 18 | DMA_ATTR_MAX, | 20 | DMA_ATTR_MAX, |
| 19 | }; | 21 | }; |
| 20 | 22 | ||
diff --git a/include/linux/dma-mapping.h b/include/linux/dma-mapping.h index dfc099e56a66..94af41858513 100644 --- a/include/linux/dma-mapping.h +++ b/include/linux/dma-mapping.h | |||
| @@ -18,6 +18,9 @@ struct dma_map_ops { | |||
| 18 | int (*mmap)(struct device *, struct vm_area_struct *, | 18 | int (*mmap)(struct device *, struct vm_area_struct *, |
| 19 | void *, dma_addr_t, size_t, struct dma_attrs *attrs); | 19 | void *, dma_addr_t, size_t, struct dma_attrs *attrs); |
| 20 | 20 | ||
| 21 | int (*get_sgtable)(struct device *dev, struct sg_table *sgt, void *, | ||
| 22 | dma_addr_t, size_t, struct dma_attrs *attrs); | ||
| 23 | |||
| 21 | dma_addr_t (*map_page)(struct device *dev, struct page *page, | 24 | dma_addr_t (*map_page)(struct device *dev, struct page *page, |
| 22 | unsigned long offset, size_t size, | 25 | unsigned long offset, size_t size, |
| 23 | enum dma_data_direction dir, | 26 | enum dma_data_direction dir, |
diff --git a/include/linux/scatterlist.h b/include/linux/scatterlist.h index ac9586dadfa5..7b600da9a635 100644 --- a/include/linux/scatterlist.h +++ b/include/linux/scatterlist.h | |||
| @@ -214,6 +214,10 @@ void sg_free_table(struct sg_table *); | |||
| 214 | int __sg_alloc_table(struct sg_table *, unsigned int, unsigned int, gfp_t, | 214 | int __sg_alloc_table(struct sg_table *, unsigned int, unsigned int, gfp_t, |
| 215 | sg_alloc_fn *); | 215 | sg_alloc_fn *); |
| 216 | int sg_alloc_table(struct sg_table *, unsigned int, gfp_t); | 216 | int sg_alloc_table(struct sg_table *, unsigned int, gfp_t); |
| 217 | int sg_alloc_table_from_pages(struct sg_table *sgt, | ||
| 218 | struct page **pages, unsigned int n_pages, | ||
| 219 | unsigned long offset, unsigned long size, | ||
| 220 | gfp_t gfp_mask); | ||
| 217 | 221 | ||
| 218 | size_t sg_copy_from_buffer(struct scatterlist *sgl, unsigned int nents, | 222 | size_t sg_copy_from_buffer(struct scatterlist *sgl, unsigned int nents, |
| 219 | void *buf, size_t buflen); | 223 | void *buf, size_t buflen); |
diff --git a/include/linux/vmalloc.h b/include/linux/vmalloc.h index dcdfc2bda922..6071e911c7f4 100644 --- a/include/linux/vmalloc.h +++ b/include/linux/vmalloc.h | |||
| @@ -32,7 +32,7 @@ struct vm_struct { | |||
| 32 | struct page **pages; | 32 | struct page **pages; |
| 33 | unsigned int nr_pages; | 33 | unsigned int nr_pages; |
| 34 | phys_addr_t phys_addr; | 34 | phys_addr_t phys_addr; |
| 35 | void *caller; | 35 | const void *caller; |
| 36 | }; | 36 | }; |
| 37 | 37 | ||
| 38 | /* | 38 | /* |
| @@ -62,7 +62,7 @@ extern void *vmalloc_32_user(unsigned long size); | |||
| 62 | extern void *__vmalloc(unsigned long size, gfp_t gfp_mask, pgprot_t prot); | 62 | extern void *__vmalloc(unsigned long size, gfp_t gfp_mask, pgprot_t prot); |
| 63 | extern void *__vmalloc_node_range(unsigned long size, unsigned long align, | 63 | extern void *__vmalloc_node_range(unsigned long size, unsigned long align, |
| 64 | unsigned long start, unsigned long end, gfp_t gfp_mask, | 64 | unsigned long start, unsigned long end, gfp_t gfp_mask, |
| 65 | pgprot_t prot, int node, void *caller); | 65 | pgprot_t prot, int node, const void *caller); |
| 66 | extern void vfree(const void *addr); | 66 | extern void vfree(const void *addr); |
| 67 | 67 | ||
| 68 | extern void *vmap(struct page **pages, unsigned int count, | 68 | extern void *vmap(struct page **pages, unsigned int count, |
| @@ -85,14 +85,15 @@ static inline size_t get_vm_area_size(const struct vm_struct *area) | |||
| 85 | 85 | ||
| 86 | extern struct vm_struct *get_vm_area(unsigned long size, unsigned long flags); | 86 | extern struct vm_struct *get_vm_area(unsigned long size, unsigned long flags); |
| 87 | extern struct vm_struct *get_vm_area_caller(unsigned long size, | 87 | extern struct vm_struct *get_vm_area_caller(unsigned long size, |
| 88 | unsigned long flags, void *caller); | 88 | unsigned long flags, const void *caller); |
| 89 | extern struct vm_struct *__get_vm_area(unsigned long size, unsigned long flags, | 89 | extern struct vm_struct *__get_vm_area(unsigned long size, unsigned long flags, |
| 90 | unsigned long start, unsigned long end); | 90 | unsigned long start, unsigned long end); |
| 91 | extern struct vm_struct *__get_vm_area_caller(unsigned long size, | 91 | extern struct vm_struct *__get_vm_area_caller(unsigned long size, |
| 92 | unsigned long flags, | 92 | unsigned long flags, |
| 93 | unsigned long start, unsigned long end, | 93 | unsigned long start, unsigned long end, |
| 94 | void *caller); | 94 | const void *caller); |
| 95 | extern struct vm_struct *remove_vm_area(const void *addr); | 95 | extern struct vm_struct *remove_vm_area(const void *addr); |
| 96 | extern struct vm_struct *find_vm_area(const void *addr); | ||
| 96 | 97 | ||
| 97 | extern int map_vm_area(struct vm_struct *area, pgprot_t prot, | 98 | extern int map_vm_area(struct vm_struct *area, pgprot_t prot, |
| 98 | struct page ***pages); | 99 | struct page ***pages); |
