]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
dma-mapping: add a kconfig symbol for arch_teardown_dma_ops availability
authorChristoph Hellwig <hch@lst.de>
Fri, 21 Dec 2018 21:14:44 +0000 (22:14 +0100)
committerChristoph Hellwig <hch@lst.de>
Wed, 13 Feb 2019 18:12:50 +0000 (19:12 +0100)
Signed-off-by: Christoph Hellwig <hch@lst.de>
Acked-by: Catalin Marinas <catalin.marinas@arm.com> # arm64
arch/arm/Kconfig
arch/arm/include/asm/dma-mapping.h
arch/arm64/Kconfig
arch/arm64/include/asm/dma-mapping.h
include/linux/dma-mapping.h
kernel/dma/Kconfig

index c1cf44f008709eabe7a45874aa8278b945e95bf5..4bb36ae71b1440e2a30db05d52a6422080bef81b 100644 (file)
@@ -16,6 +16,7 @@ config ARM
        select ARCH_HAS_SET_MEMORY
        select ARCH_HAS_STRICT_KERNEL_RWX if MMU && !XIP_KERNEL
        select ARCH_HAS_STRICT_MODULE_RWX if MMU
+       select ARCH_HAS_TEARDOWN_DMA_OPS if MMU
        select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
        select ARCH_HAVE_CUSTOM_GPIO_H
        select ARCH_HAS_GCOV_PROFILE_ALL
index a224b6e39e5805fa62bdc6c8264666e02edbde0e..03ba90ffc0f8f1130dd56fef97ecb9bf7a058a44 100644 (file)
@@ -96,11 +96,6 @@ static inline unsigned long dma_max_pfn(struct device *dev)
 }
 #define dma_max_pfn(dev) dma_max_pfn(dev)
 
-#ifdef CONFIG_MMU
-#define arch_teardown_dma_ops arch_teardown_dma_ops
-extern void arch_teardown_dma_ops(struct device *dev);
-#endif
-
 /* do not use this function in a driver */
 static inline bool is_device_dma_coherent(struct device *dev)
 {
index 63909f318d56d35ed7ea6ed3dbca8d6ee06176e9..87ec7be25e97df91c59e98dea541505a6494c54a 100644 (file)
@@ -29,6 +29,7 @@ config ARM64
        select ARCH_HAS_SYNC_DMA_FOR_DEVICE
        select ARCH_HAS_SYNC_DMA_FOR_CPU
        select ARCH_HAS_SYSCALL_WRAPPER
+       select ARCH_HAS_TEARDOWN_DMA_OPS if IOMMU_SUPPORT
        select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
        select ARCH_HAVE_NMI_SAFE_CMPXCHG
        select ARCH_INLINE_READ_LOCK if !PREEMPT
index de96507ee2c13e6890d743a3a13a4697e5938f19..de98191e4c7d408492bd30f73554031cb37b1134 100644 (file)
@@ -29,11 +29,6 @@ static inline const struct dma_map_ops *get_arch_dma_ops(struct bus_type *bus)
        return NULL;
 }
 
-#ifdef CONFIG_IOMMU_DMA
-void arch_teardown_dma_ops(struct device *dev);
-#define arch_teardown_dma_ops  arch_teardown_dma_ops
-#endif
-
 /*
  * Do not use this function in a driver, it is only provided for
  * arch/arm/mm/xen.c, which is used by arm64 as well.
index 2b20d60e615896833f6341b70ec81361217fd33f..4210c5c1dd2153623fa995fe3a00d6dfd55cd7df 100644 (file)
@@ -681,9 +681,13 @@ static inline void arch_setup_dma_ops(struct device *dev, u64 dma_base,
 }
 #endif /* CONFIG_ARCH_HAS_SETUP_DMA_OPS */
 
-#ifndef arch_teardown_dma_ops
-static inline void arch_teardown_dma_ops(struct device *dev) { }
-#endif
+#ifdef CONFIG_ARCH_HAS_TEARDOWN_DMA_OPS
+void arch_teardown_dma_ops(struct device *dev);
+#else
+static inline void arch_teardown_dma_ops(struct device *dev)
+{
+}
+#endif /* CONFIG_ARCH_HAS_TEARDOWN_DMA_OPS */
 
 static inline unsigned int dma_get_max_seg_size(struct device *dev)
 {
index 6014cad35e58214127789d1481cf5e2fd0f62038..bde9179c6ed70920410a2fc1ce32ac105e984a48 100644 (file)
@@ -22,6 +22,9 @@ config HAVE_GENERIC_DMA_COHERENT
 config ARCH_HAS_SETUP_DMA_OPS
        bool
 
+config ARCH_HAS_TEARDOWN_DMA_OPS
+       bool
+
 config ARCH_HAS_SYNC_DMA_FOR_DEVICE
        bool