aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-mx25
diff options
context:
space:
mode:
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>2010-11-10 15:27:55 -0500
committerUwe Kleine-König <u.kleine-koenig@pengutronix.de>2010-11-17 04:01:36 -0500
commit2c20b9f19add2248dc867f1f78dcef1eb0944543 (patch)
treec7b6861e16bc9fb9d4d25cb4c5730e4509af5033 /arch/arm/mach-mx25
parente9f0bafb4f3d32d0bc0ea7e946d667a68bae59ce (diff)
ARM: mx25: dynamically allocate mxc-ehci devices
According to the reference manual of the i.MX25 the host controller uses an offset of 0x200 not 0x400 as was specified in the resources for mxc_usbh2. Needs-Testing: yes Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Diffstat (limited to 'arch/arm/mach-mx25')
-rw-r--r--arch/arm/mach-mx25/Kconfig6
-rw-r--r--arch/arm/mach-mx25/devices-imx25.h7
-rw-r--r--arch/arm/mach-mx25/devices.c44
-rw-r--r--arch/arm/mach-mx25/devices.h2
-rw-r--r--arch/arm/mach-mx25/mach-cpuimx25.c9
-rw-r--r--arch/arm/mach-mx25/mach-mx25_3ds.c2
6 files changed, 20 insertions, 50 deletions
diff --git a/arch/arm/mach-mx25/Kconfig b/arch/arm/mach-mx25/Kconfig
index 38ca09a5df9..b55585bf93f 100644
--- a/arch/arm/mach-mx25/Kconfig
+++ b/arch/arm/mach-mx25/Kconfig
@@ -5,16 +5,18 @@ comment "MX25 platforms:"
5config MACH_MX25_3DS 5config MACH_MX25_3DS
6 bool "Support MX25PDK (3DS) Platform" 6 bool "Support MX25PDK (3DS) Platform"
7 select IMX_HAVE_PLATFORM_IMX_UART 7 select IMX_HAVE_PLATFORM_IMX_UART
8 select IMX_HAVE_PLATFORM_MXC_EHCI
8 select IMX_HAVE_PLATFORM_MXC_NAND 9 select IMX_HAVE_PLATFORM_MXC_NAND
9 select IMX_HAVE_PLATFORM_ESDHC 10 select IMX_HAVE_PLATFORM_ESDHC
10 11
11config MACH_EUKREA_CPUIMX25 12config MACH_EUKREA_CPUIMX25
12 bool "Support Eukrea CPUIMX25 Platform" 13 bool "Support Eukrea CPUIMX25 Platform"
14 select IMX_HAVE_PLATFORM_ESDHC
15 select IMX_HAVE_PLATFORM_FLEXCAN
13 select IMX_HAVE_PLATFORM_IMX_I2C 16 select IMX_HAVE_PLATFORM_IMX_I2C
14 select IMX_HAVE_PLATFORM_IMX_UART 17 select IMX_HAVE_PLATFORM_IMX_UART
18 select IMX_HAVE_PLATFORM_MXC_EHCI
15 select IMX_HAVE_PLATFORM_MXC_NAND 19 select IMX_HAVE_PLATFORM_MXC_NAND
16 select IMX_HAVE_PLATFORM_FLEXCAN
17 select IMX_HAVE_PLATFORM_ESDHC
18 select MXC_ULPI if USB_ULPI 20 select MXC_ULPI if USB_ULPI
19 21
20choice 22choice
diff --git a/arch/arm/mach-mx25/devices-imx25.h b/arch/arm/mach-mx25/devices-imx25.h
index f62ce93ccbc..ac343ae7fe4 100644
--- a/arch/arm/mach-mx25/devices-imx25.h
+++ b/arch/arm/mach-mx25/devices-imx25.h
@@ -39,6 +39,13 @@ extern const struct imx_imx_uart_1irq_data imx25_imx_uart_data[] __initconst;
39#define imx25_add_imx_uart3(pdata) imx25_add_imx_uart(3, pdata) 39#define imx25_add_imx_uart3(pdata) imx25_add_imx_uart(3, pdata)
40#define imx25_add_imx_uart4(pdata) imx25_add_imx_uart(4, pdata) 40#define imx25_add_imx_uart4(pdata) imx25_add_imx_uart(4, pdata)
41 41
42extern const struct imx_mxc_ehci_data imx25_mxc_ehci_otg_data __initconst;
43#define imx25_add_mxc_ehci_otg(pdata) \
44 imx_add_mxc_ehci(&imx25_mxc_ehci_otg_data, pdata)
45extern const struct imx_mxc_ehci_data imx25_mxc_ehci_hs_data __initconst;
46#define imx25_add_mxc_ehci_hs(pdata) \
47 imx_add_mxc_ehci(&imx25_mxc_ehci_hs_data, pdata)
48
42extern const struct imx_mxc_nand_data imx25_mxc_nand_data __initconst; 49extern const struct imx_mxc_nand_data imx25_mxc_nand_data __initconst;
43#define imx25_add_mxc_nand(pdata) \ 50#define imx25_add_mxc_nand(pdata) \
44 imx_add_mxc_nand(&imx25_mxc_nand_data, pdata) 51 imx_add_mxc_nand(&imx25_mxc_nand_data, pdata)
diff --git a/arch/arm/mach-mx25/devices.c b/arch/arm/mach-mx25/devices.c
index 92eb1a90b52..4611c763ff1 100644
--- a/arch/arm/mach-mx25/devices.c
+++ b/arch/arm/mach-mx25/devices.c
@@ -26,27 +26,16 @@ static u64 otg_dmamask = DMA_BIT_MASK(32);
26 26
27static struct resource mxc_otg_resources[] = { 27static struct resource mxc_otg_resources[] = {
28 { 28 {
29 .start = MX25_OTG_BASE_ADDR, 29 .start = MX25_USB_OTG_BASE_ADDR,
30 .end = MX25_OTG_BASE_ADDR + 0x1ff, 30 .end = MX25_USB_OTG_BASE_ADDR + 0x1ff,
31 .flags = IORESOURCE_MEM, 31 .flags = IORESOURCE_MEM,
32 }, { 32 }, {
33 .start = 37, 33 .start = MX25_INT_USB_OTG,
34 .end = 37, 34 .end = MX25_INT_USB_OTG,
35 .flags = IORESOURCE_IRQ, 35 .flags = IORESOURCE_IRQ,
36 }, 36 },
37}; 37};
38 38
39struct platform_device mxc_otg = {
40 .name = "mxc-ehci",
41 .id = 0,
42 .dev = {
43 .coherent_dma_mask = 0xffffffff,
44 .dma_mask = &otg_dmamask,
45 },
46 .resource = mxc_otg_resources,
47 .num_resources = ARRAY_SIZE(mxc_otg_resources),
48};
49
50/* OTG gadget device */ 39/* OTG gadget device */
51struct platform_device otg_udc_device = { 40struct platform_device otg_udc_device = {
52 .name = "fsl-usb2-udc", 41 .name = "fsl-usb2-udc",
@@ -59,31 +48,6 @@ struct platform_device otg_udc_device = {
59 .num_resources = ARRAY_SIZE(mxc_otg_resources), 48 .num_resources = ARRAY_SIZE(mxc_otg_resources),
60}; 49};
61 50
62static u64 usbh2_dmamask = DMA_BIT_MASK(32);
63
64static struct resource mxc_usbh2_resources[] = {
65 {
66 .start = MX25_OTG_BASE_ADDR + 0x400,
67 .end = MX25_OTG_BASE_ADDR + 0x5ff,
68 .flags = IORESOURCE_MEM,
69 }, {
70 .start = 35,
71 .end = 35,
72 .flags = IORESOURCE_IRQ,
73 },
74};
75
76struct platform_device mxc_usbh2 = {
77 .name = "mxc-ehci",
78 .id = 1,
79 .dev = {
80 .coherent_dma_mask = 0xffffffff,
81 .dma_mask = &usbh2_dmamask,
82 },
83 .resource = mxc_usbh2_resources,
84 .num_resources = ARRAY_SIZE(mxc_usbh2_resources),
85};
86
87static struct resource mxc_pwm_resources0[] = { 51static struct resource mxc_pwm_resources0[] = {
88 { 52 {
89 .start = 0x53fe0000, 53 .start = 0x53fe0000,
diff --git a/arch/arm/mach-mx25/devices.h b/arch/arm/mach-mx25/devices.h
index 7b70a43c3a4..e6ad6406196 100644
--- a/arch/arm/mach-mx25/devices.h
+++ b/arch/arm/mach-mx25/devices.h
@@ -1,6 +1,4 @@
1extern struct platform_device mxc_otg;
2extern struct platform_device otg_udc_device; 1extern struct platform_device otg_udc_device;
3extern struct platform_device mxc_usbh2;
4extern struct platform_device mxc_pwm_device0; 2extern struct platform_device mxc_pwm_device0;
5extern struct platform_device mxc_pwm_device1; 3extern struct platform_device mxc_pwm_device1;
6extern struct platform_device mxc_pwm_device2; 4extern struct platform_device mxc_pwm_device2;
diff --git a/arch/arm/mach-mx25/mach-cpuimx25.c b/arch/arm/mach-mx25/mach-cpuimx25.c
index f6f9ad60c25..0ee0fe73952 100644
--- a/arch/arm/mach-mx25/mach-cpuimx25.c
+++ b/arch/arm/mach-mx25/mach-cpuimx25.c
@@ -39,7 +39,6 @@
39#include <mach/mx25.h> 39#include <mach/mx25.h>
40#include <mach/mxc_nand.h> 40#include <mach/mxc_nand.h>
41#include <mach/imxfb.h> 41#include <mach/imxfb.h>
42#include <mach/mxc_ehci.h>
43#include <mach/iomux-mx25.h> 42#include <mach/iomux-mx25.h>
44 43
45#include "devices-imx25.h" 44#include "devices-imx25.h"
@@ -87,12 +86,12 @@ static struct i2c_board_info eukrea_cpuimx25_i2c_devices[] = {
87 }, 86 },
88}; 87};
89 88
90static struct mxc_usbh_platform_data otg_pdata = { 89static const struct mxc_usbh_platform_data otg_pdata __initconst = {
91 .portsc = MXC_EHCI_MODE_UTMI, 90 .portsc = MXC_EHCI_MODE_UTMI,
92 .flags = MXC_EHCI_INTERFACE_DIFF_UNI, 91 .flags = MXC_EHCI_INTERFACE_DIFF_UNI,
93}; 92};
94 93
95static struct mxc_usbh_platform_data usbh2_pdata = { 94static const struct mxc_usbh_platform_data usbh2_pdata __initconst = {
96 .portsc = MXC_EHCI_MODE_SERIAL, 95 .portsc = MXC_EHCI_MODE_SERIAL,
97 .flags = MXC_EHCI_INTERFACE_SINGLE_UNI | MXC_EHCI_INTERNAL_PHY | 96 .flags = MXC_EHCI_INTERFACE_SINGLE_UNI | MXC_EHCI_INTERNAL_PHY |
98 MXC_EHCI_IPPUE_DOWN, 97 MXC_EHCI_IPPUE_DOWN,
@@ -134,11 +133,11 @@ static void __init eukrea_cpuimx25_init(void)
134 imx25_add_imx_i2c0(&eukrea_cpuimx25_i2c0_data); 133 imx25_add_imx_i2c0(&eukrea_cpuimx25_i2c0_data);
135 134
136 if (otg_mode_host) 135 if (otg_mode_host)
137 mxc_register_device(&mxc_otg, &otg_pdata); 136 imx25_add_mxc_ehci_otg(&otg_pdata);
138 else 137 else
139 mxc_register_device(&otg_udc_device, &otg_device_pdata); 138 mxc_register_device(&otg_udc_device, &otg_device_pdata);
140 139
141 mxc_register_device(&mxc_usbh2, &usbh2_pdata); 140 imx25_add_mxc_ehci_hs(&usbh2_pdata);
142 141
143#ifdef CONFIG_MACH_EUKREA_MBIMXSD25_BASEBOARD 142#ifdef CONFIG_MACH_EUKREA_MBIMXSD25_BASEBOARD
144 eukrea_mbimxsd25_baseboard_init(); 143 eukrea_mbimxsd25_baseboard_init();
diff --git a/arch/arm/mach-mx25/mach-mx25_3ds.c b/arch/arm/mach-mx25/mach-mx25_3ds.c
index f8be1eb0c06..574c41f510d 100644
--- a/arch/arm/mach-mx25/mach-mx25_3ds.c
+++ b/arch/arm/mach-mx25/mach-mx25_3ds.c
@@ -192,7 +192,7 @@ static void __init mx25pdk_init(void)
192 ARRAY_SIZE(mx25pdk_pads)); 192 ARRAY_SIZE(mx25pdk_pads));
193 193
194 imx25_add_imx_uart0(&uart_pdata); 194 imx25_add_imx_uart0(&uart_pdata);
195 mxc_register_device(&mxc_usbh2, NULL); 195 imx25_add_mxc_ehci_hs(NULL);
196 imx25_add_mxc_nand(&mx25pdk_nand_board_info); 196 imx25_add_mxc_nand(&mx25pdk_nand_board_info);
197 mxc_register_device(&mx25_rtc_device, NULL); 197 mxc_register_device(&mx25_rtc_device, NULL);
198 mxc_register_device(&mx25_fb_device, &mx25pdk_fb_pdata); 198 mxc_register_device(&mx25_fb_device, &mx25pdk_fb_pdata);