diff options
author | Uwe Kleine-König <u.kleine-koenig@pengutronix.de> | 2010-06-23 05:49:34 -0400 |
---|---|---|
committer | Uwe Kleine-König <u.kleine-koenig@pengutronix.de> | 2010-06-30 03:01:00 -0400 |
commit | 6eafde5f02b1f34b7e083d1d6522f40e850bf355 (patch) | |
tree | 67aa1fe1d1cfdff60b1bfcf95ee697167e19f3a1 /arch | |
parent | 16cf5c41514fd94ff1e8b6be091e4b4732688fa6 (diff) |
ARM: imx: dynamically register imx-uart devices (imx35)
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mach-mx3/Kconfig | 2 | ||||
-rw-r--r-- | arch/arm/mach-mx3/devices-imx35.h | 7 | ||||
-rw-r--r-- | arch/arm/mach-mx3/devices.c | 59 | ||||
-rw-r--r-- | arch/arm/mach-mx3/devices.h | 5 | ||||
-rw-r--r-- | arch/arm/mach-mx3/mach-mx35_3ds.c | 6 | ||||
-rw-r--r-- | arch/arm/mach-mx3/mach-pcm043.c | 7 |
6 files changed, 15 insertions, 71 deletions
diff --git a/arch/arm/mach-mx3/Kconfig b/arch/arm/mach-mx3/Kconfig index 7f2d5a6a8e20..594502a4e574 100644 --- a/arch/arm/mach-mx3/Kconfig +++ b/arch/arm/mach-mx3/Kconfig | |||
@@ -116,6 +116,7 @@ config MACH_PCM043 | |||
116 | bool "Support Phytec pcm043 (i.MX35) platforms" | 116 | bool "Support Phytec pcm043 (i.MX35) platforms" |
117 | select ARCH_MX35 | 117 | select ARCH_MX35 |
118 | select IMX_HAVE_PLATFORM_IMX_I2C | 118 | select IMX_HAVE_PLATFORM_IMX_I2C |
119 | select IMX_HAVE_PLATFORM_IMX_UART | ||
119 | select IMX_HAVE_PLATFORM_MXC_NAND | 120 | select IMX_HAVE_PLATFORM_MXC_NAND |
120 | select MXC_ULPI if USB_ULPI | 121 | select MXC_ULPI if USB_ULPI |
121 | help | 122 | help |
@@ -136,6 +137,7 @@ config MACH_ARMADILLO5X0 | |||
136 | config MACH_MX35_3DS | 137 | config MACH_MX35_3DS |
137 | bool "Support MX35PDK platform" | 138 | bool "Support MX35PDK platform" |
138 | select ARCH_MX35 | 139 | select ARCH_MX35 |
140 | select IMX_HAVE_PLATFORM_IMX_UART | ||
139 | default n | 141 | default n |
140 | help | 142 | help |
141 | Include support for MX35PDK platform. This includes specific | 143 | Include support for MX35PDK platform. This includes specific |
diff --git a/arch/arm/mach-mx3/devices-imx35.h b/arch/arm/mach-mx3/devices-imx35.h index b595fa641eea..536d9b9a250b 100644 --- a/arch/arm/mach-mx3/devices-imx35.h +++ b/arch/arm/mach-mx3/devices-imx35.h | |||
@@ -16,6 +16,13 @@ | |||
16 | #define imx35_add_imx_i2c2(pdata) \ | 16 | #define imx35_add_imx_i2c2(pdata) \ |
17 | imx_add_imx_i2c(2, MX35_I2C3_BASE_ADDR, SZ_4K, MX35_INT_I2C3, pdata) | 17 | imx_add_imx_i2c(2, MX35_I2C3_BASE_ADDR, SZ_4K, MX35_INT_I2C3, pdata) |
18 | 18 | ||
19 | #define imx35_add_imx_uart0(pdata) \ | ||
20 | imx_add_imx_uart_1irq(0, MX35_UART1_BASE_ADDR, SZ_16K, MX35_INT_UART1, pdata) | ||
21 | #define imx35_add_imx_uart1(pdata) \ | ||
22 | imx_add_imx_uart_1irq(1, MX35_UART2_BASE_ADDR, SZ_16K, MX35_INT_UART2, pdata) | ||
23 | #define imx35_add_imx_uart2(pdata) \ | ||
24 | imx_add_imx_uart_1irq(2, MX35_UART3_BASE_ADDR, SZ_16K, MX35_INT_UART3, pdata) | ||
25 | |||
19 | #define imx35_add_mxc_nand(pdata) \ | 26 | #define imx35_add_mxc_nand(pdata) \ |
20 | imx_add_mxc_nand_v21(MX35_NFC_BASE_ADDR, MX35_INT_NANDFC, pdata) | 27 | imx_add_mxc_nand_v21(MX35_NFC_BASE_ADDR, MX35_INT_NANDFC, pdata) |
21 | 28 | ||
diff --git a/arch/arm/mach-mx3/devices.c b/arch/arm/mach-mx3/devices.c index 5b428626c05a..a4fd1a26fc91 100644 --- a/arch/arm/mach-mx3/devices.c +++ b/arch/arm/mach-mx3/devices.c | |||
@@ -29,65 +29,6 @@ | |||
29 | 29 | ||
30 | #include "devices.h" | 30 | #include "devices.h" |
31 | 31 | ||
32 | #if defined(CONFIG_ARCH_MX35) | ||
33 | static struct resource uart0[] = { | ||
34 | { | ||
35 | .start = UART1_BASE_ADDR, | ||
36 | .end = UART1_BASE_ADDR + 0x0B5, | ||
37 | .flags = IORESOURCE_MEM, | ||
38 | }, { | ||
39 | .start = MXC_INT_UART1, | ||
40 | .end = MXC_INT_UART1, | ||
41 | .flags = IORESOURCE_IRQ, | ||
42 | }, | ||
43 | }; | ||
44 | |||
45 | struct platform_device mxc_uart_device0 = { | ||
46 | .name = "imx-uart", | ||
47 | .id = 0, | ||
48 | .resource = uart0, | ||
49 | .num_resources = ARRAY_SIZE(uart0), | ||
50 | }; | ||
51 | |||
52 | static struct resource uart1[] = { | ||
53 | { | ||
54 | .start = UART2_BASE_ADDR, | ||
55 | .end = UART2_BASE_ADDR + 0x0B5, | ||
56 | .flags = IORESOURCE_MEM, | ||
57 | }, { | ||
58 | .start = MXC_INT_UART2, | ||
59 | .end = MXC_INT_UART2, | ||
60 | .flags = IORESOURCE_IRQ, | ||
61 | }, | ||
62 | }; | ||
63 | |||
64 | struct platform_device mxc_uart_device1 = { | ||
65 | .name = "imx-uart", | ||
66 | .id = 1, | ||
67 | .resource = uart1, | ||
68 | .num_resources = ARRAY_SIZE(uart1), | ||
69 | }; | ||
70 | |||
71 | static struct resource uart2[] = { | ||
72 | { | ||
73 | .start = UART3_BASE_ADDR, | ||
74 | .end = UART3_BASE_ADDR + 0x0B5, | ||
75 | .flags = IORESOURCE_MEM, | ||
76 | }, { | ||
77 | .start = MXC_INT_UART3, | ||
78 | .end = MXC_INT_UART3, | ||
79 | .flags = IORESOURCE_IRQ, | ||
80 | }, | ||
81 | }; | ||
82 | |||
83 | struct platform_device mxc_uart_device2 = { | ||
84 | .name = "imx-uart", | ||
85 | .id = 2, | ||
86 | .resource = uart2, | ||
87 | .num_resources = ARRAY_SIZE(uart2), | ||
88 | }; | ||
89 | #endif | ||
90 | |||
91 | /* GPIO port description */ | 32 | /* GPIO port description */ |
92 | static struct mxc_gpio_port imx_gpio_ports[] = { | 33 | static struct mxc_gpio_port imx_gpio_ports[] = { |
93 | { | 34 | { |
diff --git a/arch/arm/mach-mx3/devices.h b/arch/arm/mach-mx3/devices.h index 5a156f1d3282..e5535234839f 100644 --- a/arch/arm/mach-mx3/devices.h +++ b/arch/arm/mach-mx3/devices.h | |||
@@ -1,8 +1,3 @@ | |||
1 | #if defined(CONFIG_ARCH_MX35) | ||
2 | extern struct platform_device mxc_uart_device0; | ||
3 | extern struct platform_device mxc_uart_device1; | ||
4 | extern struct platform_device mxc_uart_device2; | ||
5 | #endif | ||
6 | extern struct platform_device mxc_w1_master_device; | 1 | extern struct platform_device mxc_w1_master_device; |
7 | extern struct platform_device mx3_ipu; | 2 | extern struct platform_device mx3_ipu; |
8 | extern struct platform_device mx3_fb; | 3 | extern struct platform_device mx3_fb; |
diff --git a/arch/arm/mach-mx3/mach-mx35_3ds.c b/arch/arm/mach-mx3/mach-mx35_3ds.c index cfac7781f8b4..1c30d7212f17 100644 --- a/arch/arm/mach-mx3/mach-mx35_3ds.c +++ b/arch/arm/mach-mx3/mach-mx35_3ds.c | |||
@@ -34,12 +34,12 @@ | |||
34 | 34 | ||
35 | #include <mach/hardware.h> | 35 | #include <mach/hardware.h> |
36 | #include <mach/common.h> | 36 | #include <mach/common.h> |
37 | #include <mach/imx-uart.h> | ||
38 | #include <mach/iomux-mx35.h> | 37 | #include <mach/iomux-mx35.h> |
39 | 38 | ||
39 | #include "devices-imx35.h" | ||
40 | #include "devices.h" | 40 | #include "devices.h" |
41 | 41 | ||
42 | static struct imxuart_platform_data uart_pdata = { | 42 | static const struct imxuart_platform_data uart_pdata __initconst = { |
43 | .flags = IMXUART_HAVE_RTSCTS, | 43 | .flags = IMXUART_HAVE_RTSCTS, |
44 | }; | 44 | }; |
45 | 45 | ||
@@ -92,7 +92,7 @@ static void __init mxc_board_init(void) | |||
92 | 92 | ||
93 | platform_add_devices(devices, ARRAY_SIZE(devices)); | 93 | platform_add_devices(devices, ARRAY_SIZE(devices)); |
94 | 94 | ||
95 | mxc_register_device(&mxc_uart_device0, &uart_pdata); | 95 | imx35_add_imx_uart0(&uart_pdata); |
96 | 96 | ||
97 | mxc_register_device(&mxc_otg_udc_device, &usb_pdata); | 97 | mxc_register_device(&mxc_otg_udc_device, &usb_pdata); |
98 | } | 98 | } |
diff --git a/arch/arm/mach-mx3/mach-pcm043.c b/arch/arm/mach-mx3/mach-pcm043.c index 21305c67afcf..97cc3642f805 100644 --- a/arch/arm/mach-mx3/mach-pcm043.c +++ b/arch/arm/mach-mx3/mach-pcm043.c | |||
@@ -36,7 +36,6 @@ | |||
36 | 36 | ||
37 | #include <mach/hardware.h> | 37 | #include <mach/hardware.h> |
38 | #include <mach/common.h> | 38 | #include <mach/common.h> |
39 | #include <mach/imx-uart.h> | ||
40 | #include <mach/iomux-mx35.h> | 39 | #include <mach/iomux-mx35.h> |
41 | #include <mach/ipu.h> | 40 | #include <mach/ipu.h> |
42 | #include <mach/mx3fb.h> | 41 | #include <mach/mx3fb.h> |
@@ -115,7 +114,7 @@ static struct platform_device pcm043_flash = { | |||
115 | .num_resources = 1, | 114 | .num_resources = 1, |
116 | }; | 115 | }; |
117 | 116 | ||
118 | static struct imxuart_platform_data uart_pdata = { | 117 | static const struct imxuart_platform_data uart_pdata __initconst = { |
119 | .flags = IMXUART_HAVE_RTSCTS, | 118 | .flags = IMXUART_HAVE_RTSCTS, |
120 | }; | 119 | }; |
121 | 120 | ||
@@ -355,11 +354,11 @@ static void __init mxc_board_init(void) | |||
355 | 354 | ||
356 | platform_add_devices(devices, ARRAY_SIZE(devices)); | 355 | platform_add_devices(devices, ARRAY_SIZE(devices)); |
357 | 356 | ||
358 | mxc_register_device(&mxc_uart_device0, &uart_pdata); | 357 | imx35_add_imx_uart0(&uart_pdata); |
359 | imx35_add_mxc_nand(&pcm037_nand_board_info); | 358 | imx35_add_mxc_nand(&pcm037_nand_board_info); |
360 | mxc_register_device(&imx_ssi_device0, &pcm043_ssi_pdata); | 359 | mxc_register_device(&imx_ssi_device0, &pcm043_ssi_pdata); |
361 | 360 | ||
362 | mxc_register_device(&mxc_uart_device1, &uart_pdata); | 361 | imx35_add_imx_uart1(&uart_pdata); |
363 | 362 | ||
364 | #if defined CONFIG_I2C_IMX || defined CONFIG_I2C_IMX_MODULE | 363 | #if defined CONFIG_I2C_IMX || defined CONFIG_I2C_IMX_MODULE |
365 | i2c_register_board_info(0, pcm043_i2c_devices, | 364 | i2c_register_board_info(0, pcm043_i2c_devices, |