提交 d25749af 编写于 作者: D Damian Hobson-Garcia 提交者: Catalin Marinas

arm64: Provide default implementation for dma_{alloc,free}_attrs

Most architectures that define CONFIG_HAS_DMA, have implementations for
both dma_alloc_attrs() and dma_free_attrs().  All achitectures that do
not define CONFIG_HAS_DMA also have both of these definitions provided
by dma-mapping-broken.h.

Add default implementations for these functions on arm64.
Signed-off-by: NDamian Hobson-Garcia <dhobsong@igel.co.jp>
Signed-off-by: NCatalin Marinas <catalin.marinas@arm.com>
上级 d683b96b
...@@ -81,8 +81,12 @@ static inline void dma_mark_clean(void *addr, size_t size) ...@@ -81,8 +81,12 @@ static inline void dma_mark_clean(void *addr, size_t size)
{ {
} }
static inline void *dma_alloc_coherent(struct device *dev, size_t size, #define dma_alloc_coherent(d, s, h, f) dma_alloc_attrs(d, s, h, f, NULL)
dma_addr_t *dma_handle, gfp_t flags) #define dma_free_coherent(d, s, h, f) dma_free_attrs(d, s, h, f, NULL)
static inline void *dma_alloc_attrs(struct device *dev, size_t size,
dma_addr_t *dma_handle, gfp_t flags,
struct dma_attrs *attrs)
{ {
struct dma_map_ops *ops = get_dma_ops(dev); struct dma_map_ops *ops = get_dma_ops(dev);
void *vaddr; void *vaddr;
...@@ -90,13 +94,14 @@ static inline void *dma_alloc_coherent(struct device *dev, size_t size, ...@@ -90,13 +94,14 @@ static inline void *dma_alloc_coherent(struct device *dev, size_t size,
if (dma_alloc_from_coherent(dev, size, dma_handle, &vaddr)) if (dma_alloc_from_coherent(dev, size, dma_handle, &vaddr))
return vaddr; return vaddr;
vaddr = ops->alloc(dev, size, dma_handle, flags, NULL); vaddr = ops->alloc(dev, size, dma_handle, flags, attrs);
debug_dma_alloc_coherent(dev, size, *dma_handle, vaddr); debug_dma_alloc_coherent(dev, size, *dma_handle, vaddr);
return vaddr; return vaddr;
} }
static inline void dma_free_coherent(struct device *dev, size_t size, static inline void dma_free_attrs(struct device *dev, size_t size,
void *vaddr, dma_addr_t dev_addr) void *vaddr, dma_addr_t dev_addr,
struct dma_attrs *attrs)
{ {
struct dma_map_ops *ops = get_dma_ops(dev); struct dma_map_ops *ops = get_dma_ops(dev);
...@@ -104,7 +109,7 @@ static inline void dma_free_coherent(struct device *dev, size_t size, ...@@ -104,7 +109,7 @@ static inline void dma_free_coherent(struct device *dev, size_t size,
return; return;
debug_dma_free_coherent(dev, size, vaddr, dev_addr); debug_dma_free_coherent(dev, size, vaddr, dev_addr);
ops->free(dev, size, vaddr, dev_addr, NULL); ops->free(dev, size, vaddr, dev_addr, attrs);
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册