82 lines
2.8 KiB
Diff
82 lines
2.8 KiB
Diff
|
author Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com> 2015-05-15 02:00:05 +0300
|
||
|
committer John Stultz <john.stultz@linaro.org> 2017-05-12 12:39:34 -0700
|
||
|
commit 6dd93436bf11ccd9fef459b8dc9f58c8635a6230 (patch)
|
||
|
tree 8855dd8b458c81c573d372354a3743bfde1691c0
|
||
|
parent da8cb6993ea1b433adec1059b65db265b2fe85f3 (diff)
|
||
|
download flo-6dd93436bf11ccd9fef459b8dc9f58c8635a6230.tar.gz
|
||
|
of: dma: Make of_dma_deconfigure() public
|
||
|
As part of moving DMA initializing to probe time the
|
||
|
of_dma_deconfigure() function will need to be called from different
|
||
|
source files. Make it public and move it to drivers/of/device.c where
|
||
|
the of_dma_configure() function is.
|
||
|
|
||
|
Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
|
||
|
Diffstat
|
||
|
-rw-r--r-- drivers/of/device.c 12
|
||
|
|
||
|
-rw-r--r-- drivers/of/platform.c 5
|
||
|
|
||
|
-rw-r--r-- include/linux/of_device.h 3
|
||
|
|
||
|
3 files changed, 15 insertions, 5 deletions
|
||
|
diff --git a/drivers/of/device.c b/drivers/of/device.c
|
||
|
index b1e6beb..0d378c0 100644
|
||
|
--- a/drivers/of/device.c
|
||
|
+++ b/drivers/of/device.c
|
||
|
@@ -151,6 +151,18 @@ void of_dma_configure(struct device *dev, struct device_node *np)
|
||
|
}
|
||
|
EXPORT_SYMBOL_GPL(of_dma_configure);
|
||
|
|
||
|
+/**
|
||
|
+ * of_dma_deconfigure - Clean up DMA configuration
|
||
|
+ * @dev: Device for which to clean up DMA configuration
|
||
|
+ *
|
||
|
+ * Clean up all configuration performed by of_dma_configure_ops() and free all
|
||
|
+ * resources that have been allocated.
|
||
|
+ */
|
||
|
+void of_dma_deconfigure(struct device *dev)
|
||
|
+{
|
||
|
+ arch_teardown_dma_ops(dev);
|
||
|
+}
|
||
|
+
|
||
|
int of_device_register(struct platform_device *pdev)
|
||
|
{
|
||
|
device_initialize(&pdev->dev);
|
||
|
diff --git a/drivers/of/platform.c b/drivers/of/platform.c
|
||
|
index 5dfcc96..5344db5 100644
|
||
|
--- a/drivers/of/platform.c
|
||
|
+++ b/drivers/of/platform.c
|
||
|
@@ -158,11 +158,6 @@ struct platform_device *of_device_alloc(struct device_node *np,
|
||
|
}
|
||
|
EXPORT_SYMBOL(of_device_alloc);
|
||
|
|
||
|
-static void of_dma_deconfigure(struct device *dev)
|
||
|
-{
|
||
|
- arch_teardown_dma_ops(dev);
|
||
|
-}
|
||
|
-
|
||
|
/**
|
||
|
* of_platform_device_create_pdata - Alloc, initialize and register an of_device
|
||
|
* @np: pointer to node to create device for
|
||
|
diff --git a/include/linux/of_device.h b/include/linux/of_device.h
|
||
|
index c12dace..af98455 100644
|
||
|
--- a/include/linux/of_device.h
|
||
|
+++ b/include/linux/of_device.h
|
||
|
@@ -56,6 +56,7 @@ static inline struct device_node *of_cpu_device_node_get(int cpu)
|
||
|
}
|
||
|
|
||
|
void of_dma_configure(struct device *dev, struct device_node *np);
|
||
|
+void of_dma_deconfigure(struct device *dev);
|
||
|
#else /* CONFIG_OF */
|
||
|
|
||
|
static inline int of_driver_match_device(struct device *dev,
|
||
|
@@ -105,6 +106,8 @@ static inline struct device_node *of_cpu_device_node_get(int cpu)
|
||
|
}
|
||
|
static inline void of_dma_configure(struct device *dev, struct device_node *np)
|
||
|
{}
|
||
|
+static inline void of_dma_deconfigure(struct device *dev)
|
||
|
+{}
|
||
|
#endif /* CONFIG_OF */
|
||
|
|
||
|
#endif /* _LINUX_OF_DEVICE_H */
|