ARM: mxs: do not add dma device by default
authorDong Aisheng <dong.aisheng@linaro.org>
Fri, 4 May 2012 12:12:18 +0000 (20:12 +0800)
committerShawn Guo <shawn.guo@linaro.org>
Sat, 12 May 2012 05:32:18 +0000 (13:32 +0800)
This will cause conflict when dt is enabled.
So let each platform add dma devices respectively.

Cc: Sascha Hauer <s.hauer@pengutronix.de>
Cc: Huang Shijie <b32955@freescale.com>
Signed-off-by: Dong Aisheng <dong.aisheng@linaro.org>
Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
Acked-by: Marek Vasut <marex@denx.de>
Acked-by: Vinod Koul <vinod.koul@intel.com>
arch/arm/mach-mxs/devices/platform-dma.c
arch/arm/mach-mxs/include/mach/common.h
arch/arm/mach-mxs/mm.c

index aff481360212ec32ce2b0ca1ae5a31e4c18aeabd..46824501de003505a6f7332ac819a65d67a5549e 100644 (file)
@@ -14,7 +14,7 @@
 #include <mach/mx28.h>
 #include <mach/devices-common.h>
 
-static struct platform_device *__init mxs_add_dma(const char *devid,
+struct platform_device *__init mxs_add_dma(const char *devid,
                                                resource_size_t base)
 {
        struct resource res[] = {
@@ -29,24 +29,3 @@ static struct platform_device *__init mxs_add_dma(const char *devid,
                                res, ARRAY_SIZE(res), NULL, 0,
                                DMA_BIT_MASK(32));
 }
-
-static int __init mxs_add_mxs_dma(void)
-{
-       char *mx23_apbh = "imx23-dma-apbh";
-       char *mx23_apbx = "imx23-dma-apbx";
-       char *mx28_apbh = "imx28-dma-apbh";
-       char *mx28_apbx = "imx28-dma-apbx";
-
-       if (cpu_is_mx23()) {
-               mxs_add_dma(mx23_apbh, MX23_APBH_DMA_BASE_ADDR);
-               mxs_add_dma(mx23_apbx, MX23_APBX_DMA_BASE_ADDR);
-       }
-
-       if (cpu_is_mx28()) {
-               mxs_add_dma(mx28_apbh, MX28_APBH_DMA_BASE_ADDR);
-               mxs_add_dma(mx28_apbx, MX28_APBX_DMA_BASE_ADDR);
-       }
-
-       return 0;
-}
-arch_initcall(mxs_add_mxs_dma);
index 84af61cf6a629432cc5d0b548d181094adfadb16..5f9a3583266c01c3c6f7e7eab2bb2c632ecda637 100644 (file)
@@ -31,4 +31,7 @@ extern void mx28_init_irq(void);
 
 extern void icoll_init_irq(void);
 
+extern struct platform_device *mxs_add_dma(const char *devid,
+                                               resource_size_t base);
+
 #endif /* __MACH_MXS_COMMON_H__ */
index 67a384edcf5b8f794a6dcf463aef37a48cdce1af..6af4371ec829ea25658b421c01de254515400c1b 100644 (file)
@@ -66,9 +66,15 @@ void __init mx28_init_irq(void)
 void __init mx23_soc_init(void)
 {
        pinctrl_provide_dummies();
+
+       mxs_add_dma("imx23-dma-apbh", MX23_APBH_DMA_BASE_ADDR);
+       mxs_add_dma("imx23-dma-apbx", MX23_APBX_DMA_BASE_ADDR);
 }
 
 void __init mx28_soc_init(void)
 {
        pinctrl_provide_dummies();
+
+       mxs_add_dma("imx28-dma-apbh", MX23_APBH_DMA_BASE_ADDR);
+       mxs_add_dma("imx28-dma-apbx", MX23_APBX_DMA_BASE_ADDR);
 }