diff options
Diffstat (limited to 'include/asm-generic')
-rw-r--r-- | include/asm-generic/dma-mapping-common.h | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/include/asm-generic/dma-mapping-common.h b/include/asm-generic/dma-mapping-common.h index 9073aeb3bb1a..de8bf89940f8 100644 --- a/include/asm-generic/dma-mapping-common.h +++ b/include/asm-generic/dma-mapping-common.h | |||
@@ -213,4 +213,22 @@ static inline int dma_mmap_writecombine(struct device *dev, struct vm_area_struc | |||
213 | return dma_mmap_attrs(dev, vma, cpu_addr, dma_addr, size, &attrs); | 213 | return dma_mmap_attrs(dev, vma, cpu_addr, dma_addr, size, &attrs); |
214 | } | 214 | } |
215 | 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 | |||
216 | #endif | 234 | #endif |