aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>2010-11-05 13:52:09 -0400
committerUwe Kleine-König <u.kleine-koenig@pengutronix.de>2010-11-17 04:01:31 -0500
commit2eb42d5c287f5e883a4b3ebe668ba880caa351e5 (patch)
tree05bba579ebdc9d945658f76f0b6476a65b69b3c3 /arch
parent9d3d945a8d5be2c915f646e8dff8422486a77030 (diff)
ARM: imx: dynamically allocate mxc-ehci devices
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Diffstat (limited to 'arch')
-rw-r--r--arch/arm/mach-imx/Kconfig4
-rw-r--r--arch/arm/mach-imx/devices-imx27.h7
-rw-r--r--arch/arm/mach-imx/devices.c73
-rw-r--r--arch/arm/mach-imx/devices.h3
-rw-r--r--arch/arm/mach-imx/mach-cpuimx27.c9
-rw-r--r--arch/arm/mach-imx/mach-imx27_visstrim_m10.c6
-rw-r--r--arch/arm/mach-imx/mach-pca100.c9
-rw-r--r--arch/arm/mach-imx/mach-pcm038.c5
-rw-r--r--arch/arm/plat-mxc/devices/Kconfig3
-rw-r--r--arch/arm/plat-mxc/devices/Makefile1
-rw-r--r--arch/arm/plat-mxc/devices/platform-mxc-ehci.c46
-rw-r--r--arch/arm/plat-mxc/include/mach/devices-common.h10
-rw-r--r--arch/arm/plat-mxc/include/mach/mx27.h12
13 files changed, 95 insertions, 93 deletions
diff --git a/arch/arm/mach-imx/Kconfig b/arch/arm/mach-imx/Kconfig
index 8e9297b84830..025e96925561 100644
--- a/arch/arm/mach-imx/Kconfig
+++ b/arch/arm/mach-imx/Kconfig
@@ -102,6 +102,7 @@ config MACH_PCM038
102 select IMX_HAVE_PLATFORM_IMX2_WDT 102 select IMX_HAVE_PLATFORM_IMX2_WDT
103 select IMX_HAVE_PLATFORM_IMX_I2C 103 select IMX_HAVE_PLATFORM_IMX_I2C
104 select IMX_HAVE_PLATFORM_IMX_UART 104 select IMX_HAVE_PLATFORM_IMX_UART
105 select IMX_HAVE_PLATFORM_MXC_EHCI
105 select IMX_HAVE_PLATFORM_MXC_NAND 106 select IMX_HAVE_PLATFORM_MXC_NAND
106 select IMX_HAVE_PLATFORM_MXC_W1 107 select IMX_HAVE_PLATFORM_MXC_W1
107 select IMX_HAVE_PLATFORM_SPI_IMX 108 select IMX_HAVE_PLATFORM_SPI_IMX
@@ -130,6 +131,7 @@ config MACH_CPUIMX27
130 select IMX_HAVE_PLATFORM_IMX2_WDT 131 select IMX_HAVE_PLATFORM_IMX2_WDT
131 select IMX_HAVE_PLATFORM_IMX_I2C 132 select IMX_HAVE_PLATFORM_IMX_I2C
132 select IMX_HAVE_PLATFORM_IMX_UART 133 select IMX_HAVE_PLATFORM_IMX_UART
134 select IMX_HAVE_PLATFORM_MXC_EHCI
133 select IMX_HAVE_PLATFORM_MXC_NAND 135 select IMX_HAVE_PLATFORM_MXC_NAND
134 select IMX_HAVE_PLATFORM_MXC_W1 136 select IMX_HAVE_PLATFORM_MXC_W1
135 select MXC_ULPI if USB_ULPI 137 select MXC_ULPI if USB_ULPI
@@ -183,6 +185,7 @@ config MACH_IMX27_VISSTRIM_M10
183 select IMX_HAVE_PLATFORM_IMX_I2C 185 select IMX_HAVE_PLATFORM_IMX_I2C
184 select IMX_HAVE_PLATFORM_IMX_UART 186 select IMX_HAVE_PLATFORM_IMX_UART
185 select IMX_HAVE_PLATFORM_MXC_MMC 187 select IMX_HAVE_PLATFORM_MXC_MMC
188 select IMX_HAVE_PLATFORM_MXC_EHCI
186 help 189 help
187 Include support for Visstrim_m10 platform and its different variants. 190 Include support for Visstrim_m10 platform and its different variants.
188 This includes specific configurations for the board and its 191 This includes specific configurations for the board and its
@@ -202,6 +205,7 @@ config MACH_PCA100
202 select IMX_HAVE_PLATFORM_IMX_I2C 205 select IMX_HAVE_PLATFORM_IMX_I2C
203 select IMX_HAVE_PLATFORM_IMX_SSI 206 select IMX_HAVE_PLATFORM_IMX_SSI
204 select IMX_HAVE_PLATFORM_IMX_UART 207 select IMX_HAVE_PLATFORM_IMX_UART
208 select IMX_HAVE_PLATFORM_MXC_EHCI
205 select IMX_HAVE_PLATFORM_MXC_MMC 209 select IMX_HAVE_PLATFORM_MXC_MMC
206 select IMX_HAVE_PLATFORM_MXC_NAND 210 select IMX_HAVE_PLATFORM_MXC_NAND
207 select IMX_HAVE_PLATFORM_MXC_W1 211 select IMX_HAVE_PLATFORM_MXC_W1
diff --git a/arch/arm/mach-imx/devices-imx27.h b/arch/arm/mach-imx/devices-imx27.h
index 646674485a0d..51b91553c590 100644
--- a/arch/arm/mach-imx/devices-imx27.h
+++ b/arch/arm/mach-imx/devices-imx27.h
@@ -43,6 +43,13 @@ extern const struct imx_mx2_camera_data imx27_mx2_camera_data __initconst;
43#define imx27_add_mx2_camera(pdata) \ 43#define imx27_add_mx2_camera(pdata) \
44 imx_add_mx2_camera(&imx27_mx2_camera_data, pdata) 44 imx_add_mx2_camera(&imx27_mx2_camera_data, pdata)
45 45
46extern const struct imx_mxc_ehci_data imx27_mxc_ehci_otg_data __initconst;
47#define imx27_add_mxc_ehci_otg(pdata) \
48 imx_add_mxc_ehci(&imx27_mxc_ehci_otg_data, pdata)
49extern const struct imx_mxc_ehci_data imx27_mxc_ehci_hs_data[] __initconst;
50#define imx27_add_mxc_ehci_hs(id, pdata) \
51 imx_add_mxc_ehci(&imx27_mxc_ehci_hs_data[id - 1], pdata)
52
46extern const struct imx_mxc_mmc_data imx27_mxc_mmc_data[] __initconst; 53extern const struct imx_mxc_mmc_data imx27_mxc_mmc_data[] __initconst;
47#define imx27_add_mxc_mmc(id, pdata) \ 54#define imx27_add_mxc_mmc(id, pdata) \
48 imx_add_mxc_mmc(&imx27_mxc_mmc_data[id], pdata) 55 imx_add_mxc_mmc(&imx27_mxc_mmc_data[id], pdata)
diff --git a/arch/arm/mach-imx/devices.c b/arch/arm/mach-imx/devices.c
index 7609e8a8f13c..2a6d70720e99 100644
--- a/arch/arm/mach-imx/devices.c
+++ b/arch/arm/mach-imx/devices.c
@@ -79,12 +79,12 @@ int __init imx1_register_gpios(void)
79#ifdef CONFIG_MACH_MX27 79#ifdef CONFIG_MACH_MX27
80static struct resource otg_resources[] = { 80static struct resource otg_resources[] = {
81 { 81 {
82 .start = MX27_USBOTG_BASE_ADDR, 82 .start = MX27_USB_OTG_BASE_ADDR,
83 .end = MX27_USBOTG_BASE_ADDR + 0x1ff, 83 .end = MX27_USB_OTG_BASE_ADDR + 0x1ff,
84 .flags = IORESOURCE_MEM, 84 .flags = IORESOURCE_MEM,
85 }, { 85 }, {
86 .start = MX27_INT_USB3, 86 .start = MX27_INT_USB_OTG,
87 .end = MX27_INT_USB3, 87 .end = MX27_INT_USB_OTG,
88 .flags = IORESOURCE_IRQ, 88 .flags = IORESOURCE_IRQ,
89 }, 89 },
90}; 90};
@@ -102,71 +102,6 @@ struct platform_device mxc_otg_udc_device = {
102 .resource = otg_resources, 102 .resource = otg_resources,
103 .num_resources = ARRAY_SIZE(otg_resources), 103 .num_resources = ARRAY_SIZE(otg_resources),
104}; 104};
105
106/* OTG host */
107struct platform_device mxc_otg_host = {
108 .name = "mxc-ehci",
109 .id = 0,
110 .dev = {
111 .coherent_dma_mask = DMA_BIT_MASK(32),
112 .dma_mask = &otg_dmamask,
113 },
114 .resource = otg_resources,
115 .num_resources = ARRAY_SIZE(otg_resources),
116};
117
118/* USB host 1 */
119
120static u64 usbh1_dmamask = DMA_BIT_MASK(32);
121
122static struct resource mxc_usbh1_resources[] = {
123 {
124 .start = MX27_USBOTG_BASE_ADDR + 0x200,
125 .end = MX27_USBOTG_BASE_ADDR + 0x3ff,
126 .flags = IORESOURCE_MEM,
127 }, {
128 .start = MX27_INT_USB1,
129 .end = MX27_INT_USB1,
130 .flags = IORESOURCE_IRQ,
131 },
132};
133
134struct platform_device mxc_usbh1 = {
135 .name = "mxc-ehci",
136 .id = 1,
137 .dev = {
138 .coherent_dma_mask = DMA_BIT_MASK(32),
139 .dma_mask = &usbh1_dmamask,
140 },
141 .resource = mxc_usbh1_resources,
142 .num_resources = ARRAY_SIZE(mxc_usbh1_resources),
143};
144
145/* USB host 2 */
146static u64 usbh2_dmamask = DMA_BIT_MASK(32);
147
148static struct resource mxc_usbh2_resources[] = {
149 {
150 .start = MX27_USBOTG_BASE_ADDR + 0x400,
151 .end = MX27_USBOTG_BASE_ADDR + 0x5ff,
152 .flags = IORESOURCE_MEM,
153 }, {
154 .start = MX27_INT_USB2,
155 .end = MX27_INT_USB2,
156 .flags = IORESOURCE_IRQ,
157 },
158};
159
160struct platform_device mxc_usbh2 = {
161 .name = "mxc-ehci",
162 .id = 2,
163 .dev = {
164 .coherent_dma_mask = DMA_BIT_MASK(32),
165 .dma_mask = &usbh2_dmamask,
166 },
167 .resource = mxc_usbh2_resources,
168 .num_resources = ARRAY_SIZE(mxc_usbh2_resources),
169};
170#endif 105#endif
171 106
172#if defined(CONFIG_MACH_MX21) || defined(CONFIG_MACH_MX27) 107#if defined(CONFIG_MACH_MX21) || defined(CONFIG_MACH_MX27)
diff --git a/arch/arm/mach-imx/devices.h b/arch/arm/mach-imx/devices.h
index a45d760f3c77..7a00bba3688e 100644
--- a/arch/arm/mach-imx/devices.h
+++ b/arch/arm/mach-imx/devices.h
@@ -1,8 +1,5 @@
1#if defined(CONFIG_MACH_MX21) || defined(CONFIG_MACH_MX27) 1#if defined(CONFIG_MACH_MX21) || defined(CONFIG_MACH_MX27)
2extern struct platform_device mxc_otg_udc_device; 2extern struct platform_device mxc_otg_udc_device;
3extern struct platform_device mxc_otg_host;
4extern struct platform_device mxc_usbh1;
5extern struct platform_device mxc_usbh2;
6extern struct platform_device mx21_usbhc_device; 3extern struct platform_device mx21_usbhc_device;
7extern struct platform_device imx_kpp_device; 4extern struct platform_device imx_kpp_device;
8#endif 5#endif
diff --git a/arch/arm/mach-imx/mach-cpuimx27.c b/arch/arm/mach-imx/mach-cpuimx27.c
index 06ff79a60901..c70b0382363e 100644
--- a/arch/arm/mach-imx/mach-cpuimx27.c
+++ b/arch/arm/mach-imx/mach-cpuimx27.c
@@ -40,7 +40,6 @@
40#include <mach/hardware.h> 40#include <mach/hardware.h>
41#include <mach/iomux-mx27.h> 41#include <mach/iomux-mx27.h>
42#include <mach/mxc_nand.h> 42#include <mach/mxc_nand.h>
43#include <mach/mxc_ehci.h>
44#include <mach/ulpi.h> 43#include <mach/ulpi.h>
45 44
46#include "devices-imx27.h" 45#include "devices-imx27.h"
@@ -213,12 +212,12 @@ static struct platform_device serial_device = {
213#endif 212#endif
214 213
215#if defined(CONFIG_USB_ULPI) 214#if defined(CONFIG_USB_ULPI)
216static struct mxc_usbh_platform_data otg_pdata = { 215static struct mxc_usbh_platform_data otg_pdata __initdata = {
217 .portsc = MXC_EHCI_MODE_ULPI, 216 .portsc = MXC_EHCI_MODE_ULPI,
218 .flags = MXC_EHCI_INTERFACE_DIFF_UNI, 217 .flags = MXC_EHCI_INTERFACE_DIFF_UNI,
219}; 218};
220 219
221static struct mxc_usbh_platform_data usbh2_pdata = { 220static struct mxc_usbh_platform_data usbh2_pdata __initdata = {
222 .portsc = MXC_EHCI_MODE_ULPI, 221 .portsc = MXC_EHCI_MODE_ULPI,
223 .flags = MXC_EHCI_INTERFACE_DIFF_UNI, 222 .flags = MXC_EHCI_INTERFACE_DIFF_UNI,
224}; 223};
@@ -281,13 +280,13 @@ static void __init eukrea_cpuimx27_init(void)
281 otg_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops, 280 otg_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops,
282 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT); 281 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT);
283 282
284 mxc_register_device(&mxc_otg_host, &otg_pdata); 283 imx27_add_mxc_ehci_otg(&otg_pdata);
285 } 284 }
286 285
287 usbh2_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops, 286 usbh2_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops,
288 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT); 287 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT);
289 288
290 mxc_register_device(&mxc_usbh2, &usbh2_pdata); 289 imx27_add_mxc_ehci_hs(2, &usbh2_pdata);
291#endif 290#endif
292 if (!otg_mode_host) 291 if (!otg_mode_host)
293 mxc_register_device(&mxc_otg_udc_device, &otg_device_pdata); 292 mxc_register_device(&mxc_otg_udc_device, &otg_device_pdata);
diff --git a/arch/arm/mach-imx/mach-imx27_visstrim_m10.c b/arch/arm/mach-imx/mach-imx27_visstrim_m10.c
index deef1fa1138e..c9f12e44a2ab 100644
--- a/arch/arm/mach-imx/mach-imx27_visstrim_m10.c
+++ b/arch/arm/mach-imx/mach-imx27_visstrim_m10.c
@@ -35,7 +35,6 @@
35#include <asm/mach/time.h> 35#include <asm/mach/time.h>
36#include <mach/common.h> 36#include <mach/common.h>
37#include <mach/iomux.h> 37#include <mach/iomux.h>
38#include <mach/mxc_ehci.h>
39 38
40#include "devices-imx27.h" 39#include "devices-imx27.h"
41#include "devices.h" 40#include "devices.h"
@@ -215,7 +214,8 @@ static int otg_phy_init(struct platform_device *pdev)
215 return 0; 214 return 0;
216} 215}
217 216
218static struct mxc_usbh_platform_data visstrim_m10_usbotg_pdata = { 217static const struct mxc_usbh_platform_data
218visstrim_m10_usbotg_pdata __initconst = {
219 .init = otg_phy_init, 219 .init = otg_phy_init,
220 .portsc = MXC_EHCI_MODE_ULPI | MXC_EHCI_UTMI_8BIT, 220 .portsc = MXC_EHCI_MODE_ULPI | MXC_EHCI_UTMI_8BIT,
221 .flags = MXC_EHCI_POWER_PINS_ENABLED, 221 .flags = MXC_EHCI_POWER_PINS_ENABLED,
@@ -237,7 +237,7 @@ static void __init visstrim_m10_board_init(void)
237 imx27_add_imx_i2c(0, &visstrim_m10_i2c_data); 237 imx27_add_imx_i2c(0, &visstrim_m10_i2c_data);
238 imx27_add_imx_i2c(1, &visstrim_m10_i2c_data); 238 imx27_add_imx_i2c(1, &visstrim_m10_i2c_data);
239 imx27_add_mxc_mmc(0, &visstrim_m10_sdhc_pdata); 239 imx27_add_mxc_mmc(0, &visstrim_m10_sdhc_pdata);
240 mxc_register_device(&mxc_otg_host, &visstrim_m10_usbotg_pdata); 240 imx27_add_mxc_ehci_otg(&visstrim_m10_usbotg_pdata);
241 imx27_add_fec(NULL); 241 imx27_add_fec(NULL);
242 platform_add_devices(platform_devices, ARRAY_SIZE(platform_devices)); 242 platform_add_devices(platform_devices, ARRAY_SIZE(platform_devices));
243} 243}
diff --git a/arch/arm/mach-imx/mach-pca100.c b/arch/arm/mach-imx/mach-pca100.c
index b05f528bfc00..683374d94024 100644
--- a/arch/arm/mach-imx/mach-pca100.c
+++ b/arch/arm/mach-imx/mach-pca100.c
@@ -40,7 +40,6 @@
40#include <mach/audmux.h> 40#include <mach/audmux.h>
41#include <mach/mxc_nand.h> 41#include <mach/mxc_nand.h>
42#include <mach/irqs.h> 42#include <mach/irqs.h>
43#include <mach/mxc_ehci.h>
44#include <mach/ulpi.h> 43#include <mach/ulpi.h>
45 44
46#include "devices-imx27.h" 45#include "devices-imx27.h"
@@ -279,7 +278,7 @@ static int otg_phy_init(struct platform_device *pdev)
279 return 0; 278 return 0;
280} 279}
281 280
282static struct mxc_usbh_platform_data otg_pdata = { 281static struct mxc_usbh_platform_data otg_pdata __initdata = {
283 .init = otg_phy_init, 282 .init = otg_phy_init,
284 .portsc = MXC_EHCI_MODE_ULPI, 283 .portsc = MXC_EHCI_MODE_ULPI,
285 .flags = MXC_EHCI_INTERFACE_DIFF_UNI, 284 .flags = MXC_EHCI_INTERFACE_DIFF_UNI,
@@ -291,7 +290,7 @@ static int usbh2_phy_init(struct platform_device *pdev)
291 return 0; 290 return 0;
292} 291}
293 292
294static struct mxc_usbh_platform_data usbh2_pdata = { 293static struct mxc_usbh_platform_data usbh2_pdata __initdata = {
295 .init = usbh2_phy_init, 294 .init = usbh2_phy_init,
296 .portsc = MXC_EHCI_MODE_ULPI, 295 .portsc = MXC_EHCI_MODE_ULPI,
297 .flags = MXC_EHCI_INTERFACE_DIFF_UNI, 296 .flags = MXC_EHCI_INTERFACE_DIFF_UNI,
@@ -410,13 +409,13 @@ static void __init pca100_init(void)
410 otg_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops, 409 otg_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops,
411 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT); 410 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT);
412 411
413 mxc_register_device(&mxc_otg_host, &otg_pdata); 412 imx27_add_mxc_ehci_otg(&otg_pdata);
414 } 413 }
415 414
416 usbh2_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops, 415 usbh2_pdata.otg = otg_ulpi_create(&mxc_ulpi_access_ops,
417 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT); 416 ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT);
418 417
419 mxc_register_device(&mxc_usbh2, &usbh2_pdata); 418 imx27_add_mxc_ehci_hs(2, &usbh2_pdata);
420#endif 419#endif
421 if (!otg_mode_host) { 420 if (!otg_mode_host) {
422 gpio_set_value(OTG_PHY_CS_GPIO, 0); 421 gpio_set_value(OTG_PHY_CS_GPIO, 0);
diff --git a/arch/arm/mach-imx/mach-pcm038.c b/arch/arm/mach-imx/mach-pcm038.c
index b3340cd8ccdd..e209b28bee4d 100644
--- a/arch/arm/mach-imx/mach-pcm038.c
+++ b/arch/arm/mach-imx/mach-pcm038.c
@@ -37,7 +37,6 @@
37#include <mach/hardware.h> 37#include <mach/hardware.h>
38#include <mach/iomux-mx27.h> 38#include <mach/iomux-mx27.h>
39#include <mach/mxc_nand.h> 39#include <mach/mxc_nand.h>
40#include <mach/mxc_ehci.h>
41#include <mach/ulpi.h> 40#include <mach/ulpi.h>
42 41
43#include "devices-imx27.h" 42#include "devices-imx27.h"
@@ -283,7 +282,7 @@ static struct spi_board_info pcm038_spi_board_info[] __initdata = {
283 } 282 }
284}; 283};
285 284
286static struct mxc_usbh_platform_data usbh2_pdata = { 285static const struct mxc_usbh_platform_data usbh2_pdata __initconst = {
287 .portsc = MXC_EHCI_MODE_ULPI, 286 .portsc = MXC_EHCI_MODE_ULPI,
288 .flags = MXC_EHCI_POWER_PINS_ENABLED | MXC_EHCI_INTERFACE_DIFF_UNI, 287 .flags = MXC_EHCI_POWER_PINS_ENABLED | MXC_EHCI_INTERFACE_DIFF_UNI,
289}; 288};
@@ -320,7 +319,7 @@ static void __init pcm038_init(void)
320 spi_register_board_info(pcm038_spi_board_info, 319 spi_register_board_info(pcm038_spi_board_info,
321 ARRAY_SIZE(pcm038_spi_board_info)); 320 ARRAY_SIZE(pcm038_spi_board_info));
322 321
323 mxc_register_device(&mxc_usbh2, &usbh2_pdata); 322 imx27_add_mxc_ehci_hs(2, &usbh2_pdata);
324 323
325 imx27_add_fec(NULL); 324 imx27_add_fec(NULL);
326 platform_add_devices(platform_devices, ARRAY_SIZE(platform_devices)); 325 platform_add_devices(platform_devices, ARRAY_SIZE(platform_devices));
diff --git a/arch/arm/plat-mxc/devices/Kconfig b/arch/arm/plat-mxc/devices/Kconfig
index 6560cf5180b6..d2d096c44c4a 100644
--- a/arch/arm/plat-mxc/devices/Kconfig
+++ b/arch/arm/plat-mxc/devices/Kconfig
@@ -37,6 +37,9 @@ config IMX_HAVE_PLATFORM_MX1_CAMERA
37config IMX_HAVE_PLATFORM_MX2_CAMERA 37config IMX_HAVE_PLATFORM_MX2_CAMERA
38 bool 38 bool
39 39
40config IMX_HAVE_PLATFORM_MXC_EHCI
41 bool
42
40config IMX_HAVE_PLATFORM_MXC_MMC 43config IMX_HAVE_PLATFORM_MXC_MMC
41 bool 44 bool
42 45
diff --git a/arch/arm/plat-mxc/devices/Makefile b/arch/arm/plat-mxc/devices/Makefile
index d2b7a9196ab4..c8734bd23cc4 100644
--- a/arch/arm/plat-mxc/devices/Makefile
+++ b/arch/arm/plat-mxc/devices/Makefile
@@ -11,6 +11,7 @@ obj-$(CONFIG_IMX_HAVE_PLATFORM_IMX_UART) += platform-imx-uart.o
11obj-$(CONFIG_IMX_HAVE_PLATFORM_IMX_UDC) += platform-imx_udc.o 11obj-$(CONFIG_IMX_HAVE_PLATFORM_IMX_UDC) += platform-imx_udc.o
12obj-$(CONFIG_IMX_HAVE_PLATFORM_MX1_CAMERA) += platform-mx1-camera.o 12obj-$(CONFIG_IMX_HAVE_PLATFORM_MX1_CAMERA) += platform-mx1-camera.o
13obj-$(CONFIG_IMX_HAVE_PLATFORM_MX2_CAMERA) += platform-mx2-camera.o 13obj-$(CONFIG_IMX_HAVE_PLATFORM_MX2_CAMERA) += platform-mx2-camera.o
14obj-$(CONFIG_IMX_HAVE_PLATFORM_MXC_EHCI) += platform-mxc-ehci.o
14obj-$(CONFIG_IMX_HAVE_PLATFORM_MXC_MMC) += platform-mxc-mmc.o 15obj-$(CONFIG_IMX_HAVE_PLATFORM_MXC_MMC) += platform-mxc-mmc.o
15obj-$(CONFIG_IMX_HAVE_PLATFORM_MXC_NAND) += platform-mxc_nand.o 16obj-$(CONFIG_IMX_HAVE_PLATFORM_MXC_NAND) += platform-mxc_nand.o
16obj-$(CONFIG_IMX_HAVE_PLATFORM_MXC_PWM) += platform-mxc_pwm.o 17obj-$(CONFIG_IMX_HAVE_PLATFORM_MXC_PWM) += platform-mxc_pwm.o
diff --git a/arch/arm/plat-mxc/devices/platform-mxc-ehci.c b/arch/arm/plat-mxc/devices/platform-mxc-ehci.c
new file mode 100644
index 000000000000..0cb67bb6e5b1
--- /dev/null
+++ b/arch/arm/plat-mxc/devices/platform-mxc-ehci.c
@@ -0,0 +1,46 @@
1/*
2 * Copyright (C) 2010 Pengutronix
3 * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License version 2 as published by the
7 * Free Software Foundation.
8 */
9#include <mach/hardware.h>
10#include <mach/devices-common.h>
11
12#define imx_mxc_ehci_data_entry_single(soc, _id, hs) \
13 { \
14 .id = _id, \
15 .iobase = soc ## _USB_ ## hs ## _BASE_ADDR, \
16 .irq = soc ## _INT_USB_ ## hs, \
17 }
18
19#ifdef CONFIG_SOC_IMX27
20const struct imx_mxc_ehci_data imx27_mxc_ehci_otg_data __initconst =
21 imx_mxc_ehci_data_entry_single(MX27, 0, OTG);
22const struct imx_mxc_ehci_data imx27_mxc_ehci_hs_data[] __initconst = {
23 imx_mxc_ehci_data_entry_single(MX27, 1, HS1),
24 imx_mxc_ehci_data_entry_single(MX27, 2, HS2),
25};
26#endif /* ifdef CONFIG_SOC_IMX27 */
27
28struct platform_device *__init imx_add_mxc_ehci(
29 const struct imx_mxc_ehci_data *data,
30 const struct mxc_usbh_platform_data *pdata)
31{
32 struct resource res[] = {
33 {
34 .start = data->iobase,
35 .end = data->iobase + SZ_512 - 1,
36 .flags = IORESOURCE_MEM,
37 }, {
38 .start = data->irq,
39 .end = data->irq,
40 .flags = IORESOURCE_IRQ,
41 },
42 };
43 return imx_add_platform_device_dmamask("mxc-ehci", data->id,
44 res, ARRAY_SIZE(res),
45 pdata, sizeof(*pdata), DMA_BIT_MASK(32));
46}
diff --git a/arch/arm/plat-mxc/include/mach/devices-common.h b/arch/arm/plat-mxc/include/mach/devices-common.h
index bb3b29c7fc35..7df7a9f8c5ed 100644
--- a/arch/arm/plat-mxc/include/mach/devices-common.h
+++ b/arch/arm/plat-mxc/include/mach/devices-common.h
@@ -151,6 +151,16 @@ struct platform_device *__init imx_add_mx2_camera(
151 const struct imx_mx2_camera_data *data, 151 const struct imx_mx2_camera_data *data,
152 const struct mx2_camera_platform_data *pdata); 152 const struct mx2_camera_platform_data *pdata);
153 153
154#include <mach/mxc_ehci.h>
155struct imx_mxc_ehci_data {
156 int id;
157 resource_size_t iobase;
158 resource_size_t irq;
159};
160struct platform_device *__init imx_add_mxc_ehci(
161 const struct imx_mxc_ehci_data *data,
162 const struct mxc_usbh_platform_data *pdata);
163
154#include <mach/mmc.h> 164#include <mach/mmc.h>
155struct imx_mxc_mmc_data { 165struct imx_mxc_mmc_data {
156 int id; 166 int id;
diff --git a/arch/arm/plat-mxc/include/mach/mx27.h b/arch/arm/plat-mxc/include/mach/mx27.h
index 2734d24e8e1c..45419b3a2d1e 100644
--- a/arch/arm/plat-mxc/include/mach/mx27.h
+++ b/arch/arm/plat-mxc/include/mach/mx27.h
@@ -64,8 +64,10 @@
64#define MX27_LCDC_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x21000) 64#define MX27_LCDC_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x21000)
65#define MX27_SLCDC_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x22000) 65#define MX27_SLCDC_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x22000)
66#define MX27_VPU_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x23000) 66#define MX27_VPU_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x23000)
67#define MX27_USBOTG_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x24000) 67#define MX27_USB_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x24000)
68#define MX27_OTG_BASE_ADDR MX27_USBOTG_BASE_ADDR 68#define MX27_USB_OTG_BASE_ADDR (MX27_USB_BASE_ADDR + 0x0000)
69#define MX27_USB_HS1_BASE_ADDR (MX27_USB_BASE_ADDR + 0x0200)
70#define MX27_USB_HS2_BASE_ADDR (MX27_USB_BASE_ADDR + 0x0400)
69#define MX27_SAHARA_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x25000) 71#define MX27_SAHARA_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x25000)
70#define MX27_EMMAPP_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x26000) 72#define MX27_EMMAPP_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x26000)
71#define MX27_EMMAPRP_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x26400) 73#define MX27_EMMAPRP_BASE_ADDR (MX27_AIPI_BASE_ADDR + 0x26400)
@@ -187,9 +189,9 @@ static inline void mx27_setup_weimcs(size_t cs,
187#define MX27_INT_EMMAPRP 51 189#define MX27_INT_EMMAPRP 51
188#define MX27_INT_EMMAPP 52 190#define MX27_INT_EMMAPP 52
189#define MX27_INT_VPU 53 191#define MX27_INT_VPU 53
190#define MX27_INT_USB1 54 192#define MX27_INT_USB_HS1 54
191#define MX27_INT_USB2 55 193#define MX27_INT_USB_HS2 55
192#define MX27_INT_USB3 56 194#define MX27_INT_USB_OTG 56
193#define MX27_INT_SCC_SMN 57 195#define MX27_INT_SCC_SMN 57
194#define MX27_INT_SCC_SCM 58 196#define MX27_INT_SCC_SCM 58
195#define MX27_INT_SAHARA 59 197#define MX27_INT_SAHARA 59