]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
dma-mapping: Add dma_release_coherent_memory to DMA API
authorMark-PK Tsai <mark-pk.tsai@mediatek.com>
Fri, 22 Apr 2022 06:24:35 +0000 (14:24 +0800)
committerMathieu Poirier <mathieu.poirier@linaro.org>
Fri, 24 Jun 2022 15:30:54 +0000 (09:30 -0600)
Add dma_release_coherent_memory to DMA API to allow dma
user call it to release dev->dma_mem when the device is
removed.

Signed-off-by: Mark-PK Tsai <mark-pk.tsai@mediatek.com>
Acked-by: Christoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/r/20220422062436.14384-2-mark-pk.tsai@mediatek.com
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
include/linux/dma-map-ops.h
kernel/dma/coherent.c

index 0d5b06b3a4a619a836ff445f60efd7afddcf0251..53db9655efe991c0b8d21516727c873ed8a32393 100644 (file)
@@ -166,6 +166,7 @@ static inline void dma_pernuma_cma_reserve(void) { }
 #ifdef CONFIG_DMA_DECLARE_COHERENT
 int dma_declare_coherent_memory(struct device *dev, phys_addr_t phys_addr,
                dma_addr_t device_addr, size_t size);
+void dma_release_coherent_memory(struct device *dev);
 int dma_alloc_from_dev_coherent(struct device *dev, ssize_t size,
                dma_addr_t *dma_handle, void **ret);
 int dma_release_from_dev_coherent(struct device *dev, int order, void *vaddr);
@@ -177,6 +178,8 @@ static inline int dma_declare_coherent_memory(struct device *dev,
 {
        return -ENOSYS;
 }
+
+#define dma_release_coherent_memory(dev) (0)
 #define dma_alloc_from_dev_coherent(dev, size, handle, ret) (0)
 #define dma_release_from_dev_coherent(dev, order, vaddr) (0)
 #define dma_mmap_from_dev_coherent(dev, vma, vaddr, order, ret) (0)
index 375fb3c9538d29ef87f10a1b3602fe390ee382bf..c21abc77c53e9a95d9749ff6fcb38f919cb08cee 100644 (file)
@@ -74,7 +74,7 @@ out_unmap_membase:
        return ERR_PTR(-ENOMEM);
 }
 
-static void dma_release_coherent_memory(struct dma_coherent_mem *mem)
+static void _dma_release_coherent_memory(struct dma_coherent_mem *mem)
 {
        if (!mem)
                return;
@@ -126,10 +126,16 @@ int dma_declare_coherent_memory(struct device *dev, phys_addr_t phys_addr,
 
        ret = dma_assign_coherent_memory(dev, mem);
        if (ret)
-               dma_release_coherent_memory(mem);
+               _dma_release_coherent_memory(mem);
        return ret;
 }
 
+void dma_release_coherent_memory(struct device *dev)
+{
+       if (dev)
+               _dma_release_coherent_memory(dev->dma_mem);
+}
+
 static void *__dma_alloc_from_coherent(struct device *dev,
                                       struct dma_coherent_mem *mem,
                                       ssize_t size, dma_addr_t *dma_handle)