diff options
author | Kevin Hilman <khilman@deeprootsystems.com> | 2010-10-01 16:24:10 -0400 |
---|---|---|
committer | Kevin Hilman <khilman@deeprootsystems.com> | 2010-10-01 16:24:10 -0400 |
commit | 69758ab7a1e2de5636a2188d5357dd03140bf1d8 (patch) | |
tree | 13d65cbee4cc6bfed697bd164a15529ad86c2b25 /arch/arm/mach-omap2 | |
parent | 963bfb0939232e415c7bfb19b08dce300eb148d9 (diff) | |
parent | 257f23d87f9309fee41d468575404b9371bf4c7d (diff) |
manual merge for pm-hwmod-uart due to conflicts
Diffstat (limited to 'arch/arm/mach-omap2')
-rw-r--r-- | arch/arm/mach-omap2/Kconfig | 11 | ||||
-rw-r--r-- | arch/arm/mach-omap2/board-3630sdp.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-omap2/board-zoom-peripherals.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clock3xxx_data.c | 22 | ||||
-rw-r--r-- | arch/arm/mach-omap2/cm-regbits-34xx.h | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap2/omap_hwmod_2420_data.c | 193 | ||||
-rw-r--r-- | arch/arm/mach-omap2/omap_hwmod_2430_data.c | 193 | ||||
-rw-r--r-- | arch/arm/mach-omap2/omap_hwmod_3xxx_data.c | 253 | ||||
-rw-r--r-- | arch/arm/mach-omap2/omap_hwmod_44xx_data.c | 235 | ||||
-rw-r--r-- | arch/arm/mach-omap2/pm34xx.c | 17 | ||||
-rw-r--r-- | arch/arm/mach-omap2/prcm-common.h | 5 | ||||
-rw-r--r-- | arch/arm/mach-omap2/prm-regbits-34xx.h | 1 | ||||
-rw-r--r-- | arch/arm/mach-omap2/serial.c | 555 |
13 files changed, 1210 insertions, 279 deletions
diff --git a/arch/arm/mach-omap2/Kconfig b/arch/arm/mach-omap2/Kconfig index 1c4b2377862b..91dd215d05f0 100644 --- a/arch/arm/mach-omap2/Kconfig +++ b/arch/arm/mach-omap2/Kconfig | |||
@@ -11,9 +11,8 @@ config ARCH_OMAP2PLUS_TYPICAL | |||
11 | select PM_RUNTIME | 11 | select PM_RUNTIME |
12 | select VFP | 12 | select VFP |
13 | select NEON if ARCH_OMAP3 || ARCH_OMAP4 | 13 | select NEON if ARCH_OMAP3 || ARCH_OMAP4 |
14 | select SERIAL_8250 | 14 | select SERIAL_OMAP |
15 | select SERIAL_CORE_CONSOLE | 15 | select SERIAL_OMAP_CONSOLE |
16 | select SERIAL_8250_CONSOLE | ||
17 | select I2C | 16 | select I2C |
18 | select I2C_OMAP | 17 | select I2C_OMAP |
19 | select MFD | 18 | select MFD |
@@ -222,12 +221,18 @@ config MACH_OMAP_ZOOM2 | |||
222 | depends on ARCH_OMAP3 | 221 | depends on ARCH_OMAP3 |
223 | default y | 222 | default y |
224 | select OMAP_PACKAGE_CBB | 223 | select OMAP_PACKAGE_CBB |
224 | select SERIAL_8250 | ||
225 | select SERIAL_CORE_CONSOLE | ||
226 | select SERIAL_8250_CONSOLE | ||
225 | 227 | ||
226 | config MACH_OMAP_ZOOM3 | 228 | config MACH_OMAP_ZOOM3 |
227 | bool "OMAP3630 Zoom3 board" | 229 | bool "OMAP3630 Zoom3 board" |
228 | depends on ARCH_OMAP3 | 230 | depends on ARCH_OMAP3 |
229 | default y | 231 | default y |
230 | select OMAP_PACKAGE_CBP | 232 | select OMAP_PACKAGE_CBP |
233 | select SERIAL_8250 | ||
234 | select SERIAL_CORE_CONSOLE | ||
235 | select SERIAL_8250_CONSOLE | ||
231 | 236 | ||
232 | config MACH_CM_T35 | 237 | config MACH_CM_T35 |
233 | bool "CompuLab CM-T35 module" | 238 | bool "CompuLab CM-T35 module" |
diff --git a/arch/arm/mach-omap2/board-3630sdp.c b/arch/arm/mach-omap2/board-3630sdp.c index b359c3f7bb39..d5104519ab03 100644 --- a/arch/arm/mach-omap2/board-3630sdp.c +++ b/arch/arm/mach-omap2/board-3630sdp.c | |||
@@ -208,7 +208,6 @@ static struct flash_partitions sdp_flash_partitions[] = { | |||
208 | static void __init omap_sdp_init(void) | 208 | static void __init omap_sdp_init(void) |
209 | { | 209 | { |
210 | omap3_mux_init(board_mux, OMAP_PACKAGE_CBP); | 210 | omap3_mux_init(board_mux, OMAP_PACKAGE_CBP); |
211 | omap_serial_init(); | ||
212 | zoom_peripherals_init(); | 211 | zoom_peripherals_init(); |
213 | board_smc91x_init(); | 212 | board_smc91x_init(); |
214 | board_flash_init(sdp_flash_partitions, chip_sel_sdp); | 213 | board_flash_init(sdp_flash_partitions, chip_sel_sdp); |
diff --git a/arch/arm/mach-omap2/board-zoom-peripherals.c b/arch/arm/mach-omap2/board-zoom-peripherals.c index e5eac46bbac9..35066b355bd5 100644 --- a/arch/arm/mach-omap2/board-zoom-peripherals.c +++ b/arch/arm/mach-omap2/board-zoom-peripherals.c | |||
@@ -283,4 +283,5 @@ void __init zoom_peripherals_init(void) | |||
283 | omap_i2c_init(); | 283 | omap_i2c_init(); |
284 | usb_musb_init(&musb_board_data); | 284 | usb_musb_init(&musb_board_data); |
285 | enable_board_wakeup_source(); | 285 | enable_board_wakeup_source(); |
286 | omap_serial_init(); | ||
286 | } | 287 | } |
diff --git a/arch/arm/mach-omap2/clock3xxx_data.c b/arch/arm/mach-omap2/clock3xxx_data.c index c73906d17458..ba01ec0cae45 100644 --- a/arch/arm/mach-omap2/clock3xxx_data.c +++ b/arch/arm/mach-omap2/clock3xxx_data.c | |||
@@ -2465,6 +2465,16 @@ static struct clk uart3_fck = { | |||
2465 | .recalc = &followparent_recalc, | 2465 | .recalc = &followparent_recalc, |
2466 | }; | 2466 | }; |
2467 | 2467 | ||
2468 | static struct clk uart4_fck = { | ||
2469 | .name = "uart4_fck", | ||
2470 | .ops = &clkops_omap2_dflt_wait, | ||
2471 | .parent = &per_48m_fck, | ||
2472 | .enable_reg = OMAP_CM_REGADDR(OMAP3430_PER_MOD, CM_FCLKEN), | ||
2473 | .enable_bit = OMAP3630_EN_UART4_SHIFT, | ||
2474 | .clkdm_name = "per_clkdm", | ||
2475 | .recalc = &followparent_recalc, | ||
2476 | }; | ||
2477 | |||
2468 | static struct clk gpt2_fck = { | 2478 | static struct clk gpt2_fck = { |
2469 | .name = "gpt2_fck", | 2479 | .name = "gpt2_fck", |
2470 | .ops = &clkops_omap2_dflt_wait, | 2480 | .ops = &clkops_omap2_dflt_wait, |
@@ -2715,6 +2725,16 @@ static struct clk uart3_ick = { | |||
2715 | .recalc = &followparent_recalc, | 2725 | .recalc = &followparent_recalc, |
2716 | }; | 2726 | }; |
2717 | 2727 | ||
2728 | static struct clk uart4_ick = { | ||
2729 | .name = "uart4_ick", | ||
2730 | .ops = &clkops_omap2_dflt_wait, | ||
2731 | .parent = &per_l4_ick, | ||
2732 | .enable_reg = OMAP_CM_REGADDR(OMAP3430_PER_MOD, CM_ICLKEN), | ||
2733 | .enable_bit = OMAP3630_EN_UART4_SHIFT, | ||
2734 | .clkdm_name = "per_clkdm", | ||
2735 | .recalc = &followparent_recalc, | ||
2736 | }; | ||
2737 | |||
2718 | static struct clk gpt9_ick = { | 2738 | static struct clk gpt9_ick = { |
2719 | .name = "gpt9_ick", | 2739 | .name = "gpt9_ick", |
2720 | .ops = &clkops_omap2_dflt_wait, | 2740 | .ops = &clkops_omap2_dflt_wait, |
@@ -3349,6 +3369,7 @@ static struct omap_clk omap3xxx_clks[] = { | |||
3349 | CLK(NULL, "per_96m_fck", &per_96m_fck, CK_3XXX), | 3369 | CLK(NULL, "per_96m_fck", &per_96m_fck, CK_3XXX), |
3350 | CLK(NULL, "per_48m_fck", &per_48m_fck, CK_3XXX), | 3370 | CLK(NULL, "per_48m_fck", &per_48m_fck, CK_3XXX), |
3351 | CLK(NULL, "uart3_fck", &uart3_fck, CK_3XXX), | 3371 | CLK(NULL, "uart3_fck", &uart3_fck, CK_3XXX), |
3372 | CLK(NULL, "uart4_fck", &uart4_fck, CK_36XX), | ||
3352 | CLK(NULL, "gpt2_fck", &gpt2_fck, CK_3XXX), | 3373 | CLK(NULL, "gpt2_fck", &gpt2_fck, CK_3XXX), |
3353 | CLK(NULL, "gpt3_fck", &gpt3_fck, CK_3XXX), | 3374 | CLK(NULL, "gpt3_fck", &gpt3_fck, CK_3XXX), |
3354 | CLK(NULL, "gpt4_fck", &gpt4_fck, CK_3XXX), | 3375 | CLK(NULL, "gpt4_fck", &gpt4_fck, CK_3XXX), |
@@ -3372,6 +3393,7 @@ static struct omap_clk omap3xxx_clks[] = { | |||
3372 | CLK(NULL, "gpio2_ick", &gpio2_ick, CK_3XXX), | 3393 | CLK(NULL, "gpio2_ick", &gpio2_ick, CK_3XXX), |
3373 | CLK(NULL, "wdt3_ick", &wdt3_ick, CK_3XXX), | 3394 | CLK(NULL, "wdt3_ick", &wdt3_ick, CK_3XXX), |
3374 | CLK(NULL, "uart3_ick", &uart3_ick, CK_3XXX), | 3395 | CLK(NULL, "uart3_ick", &uart3_ick, CK_3XXX), |
3396 | CLK(NULL, "uart4_ick", &uart4_ick, CK_36XX), | ||
3375 | CLK(NULL, "gpt9_ick", &gpt9_ick, CK_3XXX), | 3397 | CLK(NULL, "gpt9_ick", &gpt9_ick, CK_3XXX), |
3376 | CLK(NULL, "gpt8_ick", &gpt8_ick, CK_3XXX), | 3398 | CLK(NULL, "gpt8_ick", &gpt8_ick, CK_3XXX), |
3377 | CLK(NULL, "gpt7_ick", &gpt7_ick, CK_3XXX), | 3399 | CLK(NULL, "gpt7_ick", &gpt7_ick, CK_3XXX), |
diff --git a/arch/arm/mach-omap2/cm-regbits-34xx.h b/arch/arm/mach-omap2/cm-regbits-34xx.h index fe82b79d5f3b..4f959a7d881c 100644 --- a/arch/arm/mach-omap2/cm-regbits-34xx.h +++ b/arch/arm/mach-omap2/cm-regbits-34xx.h | |||
@@ -649,6 +649,8 @@ | |||
649 | #define OMAP3430_ST_MCBSP2_MASK (1 << 0) | 649 | #define OMAP3430_ST_MCBSP2_MASK (1 << 0) |
650 | 650 | ||
651 | /* CM_AUTOIDLE_PER */ | 651 | /* CM_AUTOIDLE_PER */ |
652 | #define OMAP3630_AUTO_UART4_MASK (1 << 18) | ||
653 | #define OMAP3630_AUTO_UART4_SHIFT 18 | ||
652 | #define OMAP3430_AUTO_GPIO6_MASK (1 << 17) | 654 | #define OMAP3430_AUTO_GPIO6_MASK (1 << 17) |
653 | #define OMAP3430_AUTO_GPIO6_SHIFT 17 | 655 | #define OMAP3430_AUTO_GPIO6_SHIFT 17 |
654 | #define OMAP3430_AUTO_GPIO5_MASK (1 << 16) | 656 | #define OMAP3430_AUTO_GPIO5_MASK (1 << 16) |
diff --git a/arch/arm/mach-omap2/omap_hwmod_2420_data.c b/arch/arm/mach-omap2/omap_hwmod_2420_data.c index 66678d98ad96..adf6e3632a2b 100644 --- a/arch/arm/mach-omap2/omap_hwmod_2420_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_2420_data.c | |||
@@ -15,6 +15,7 @@ | |||
15 | #include <mach/irqs.h> | 15 | #include <mach/irqs.h> |
16 | #include <plat/cpu.h> | 16 | #include <plat/cpu.h> |
17 | #include <plat/dma.h> | 17 | #include <plat/dma.h> |
18 | #include <plat/serial.h> | ||
18 | 19 | ||
19 | #include "omap_hwmod_common_data.h" | 20 | #include "omap_hwmod_common_data.h" |
20 | 21 | ||
@@ -73,6 +74,9 @@ static struct omap_hwmod omap2420_l3_main_hwmod = { | |||
73 | }; | 74 | }; |
74 | 75 | ||
75 | static struct omap_hwmod omap2420_l4_wkup_hwmod; | 76 | static struct omap_hwmod omap2420_l4_wkup_hwmod; |
77 | static struct omap_hwmod omap2420_uart1_hwmod; | ||
78 | static struct omap_hwmod omap2420_uart2_hwmod; | ||
79 | static struct omap_hwmod omap2420_uart3_hwmod; | ||
76 | 80 | ||
77 | /* L4_CORE -> L4_WKUP interface */ | 81 | /* L4_CORE -> L4_WKUP interface */ |
78 | static struct omap_hwmod_ocp_if omap2420_l4_core__l4_wkup = { | 82 | static struct omap_hwmod_ocp_if omap2420_l4_core__l4_wkup = { |
@@ -81,6 +85,60 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__l4_wkup = { | |||
81 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 85 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
82 | }; | 86 | }; |
83 | 87 | ||
88 | /* L4 CORE -> UART1 interface */ | ||
89 | static struct omap_hwmod_addr_space omap2420_uart1_addr_space[] = { | ||
90 | { | ||
91 | .pa_start = OMAP2_UART1_BASE, | ||
92 | .pa_end = OMAP2_UART1_BASE + SZ_8K - 1, | ||
93 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
94 | }, | ||
95 | }; | ||
96 | |||
97 | static struct omap_hwmod_ocp_if omap2_l4_core__uart1 = { | ||
98 | .master = &omap2420_l4_core_hwmod, | ||
99 | .slave = &omap2420_uart1_hwmod, | ||
100 | .clk = "uart1_ick", | ||
101 | .addr = omap2420_uart1_addr_space, | ||
102 | .addr_cnt = ARRAY_SIZE(omap2420_uart1_addr_space), | ||
103 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
104 | }; | ||
105 | |||
106 | /* L4 CORE -> UART2 interface */ | ||
107 | static struct omap_hwmod_addr_space omap2420_uart2_addr_space[] = { | ||
108 | { | ||
109 | .pa_start = OMAP2_UART2_BASE, | ||
110 | .pa_end = OMAP2_UART2_BASE + SZ_1K - 1, | ||
111 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
112 | }, | ||
113 | }; | ||
114 | |||
115 | static struct omap_hwmod_ocp_if omap2_l4_core__uart2 = { | ||
116 | .master = &omap2420_l4_core_hwmod, | ||
117 | .slave = &omap2420_uart2_hwmod, | ||
118 | .clk = "uart2_ick", | ||
119 | .addr = omap2420_uart2_addr_space, | ||
120 | .addr_cnt = ARRAY_SIZE(omap2420_uart2_addr_space), | ||
121 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
122 | }; | ||
123 | |||
124 | /* L4 PER -> UART3 interface */ | ||
125 | static struct omap_hwmod_addr_space omap2420_uart3_addr_space[] = { | ||
126 | { | ||
127 | .pa_start = OMAP2_UART3_BASE, | ||
128 | .pa_end = OMAP2_UART3_BASE + SZ_1K - 1, | ||
129 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
130 | }, | ||
131 | }; | ||
132 | |||
133 | static struct omap_hwmod_ocp_if omap2_l4_core__uart3 = { | ||
134 | .master = &omap2420_l4_core_hwmod, | ||
135 | .slave = &omap2420_uart3_hwmod, | ||
136 | .clk = "uart3_ick", | ||
137 | .addr = omap2420_uart3_addr_space, | ||
138 | .addr_cnt = ARRAY_SIZE(omap2420_uart3_addr_space), | ||
139 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
140 | }; | ||
141 | |||
84 | /* Slave interfaces on the L4_CORE interconnect */ | 142 | /* Slave interfaces on the L4_CORE interconnect */ |
85 | static struct omap_hwmod_ocp_if *omap2420_l4_core_slaves[] = { | 143 | static struct omap_hwmod_ocp_if *omap2420_l4_core_slaves[] = { |
86 | &omap2420_l3_main__l4_core, | 144 | &omap2420_l3_main__l4_core, |
@@ -89,6 +147,9 @@ static struct omap_hwmod_ocp_if *omap2420_l4_core_slaves[] = { | |||
89 | /* Master interfaces on the L4_CORE interconnect */ | 147 | /* Master interfaces on the L4_CORE interconnect */ |
90 | static struct omap_hwmod_ocp_if *omap2420_l4_core_masters[] = { | 148 | static struct omap_hwmod_ocp_if *omap2420_l4_core_masters[] = { |
91 | &omap2420_l4_core__l4_wkup, | 149 | &omap2420_l4_core__l4_wkup, |
150 | &omap2_l4_core__uart1, | ||
151 | &omap2_l4_core__uart2, | ||
152 | &omap2_l4_core__uart3, | ||
92 | }; | 153 | }; |
93 | 154 | ||
94 | /* L4 CORE */ | 155 | /* L4 CORE */ |
@@ -228,6 +289,135 @@ static struct omap_hwmod omap2420_wd_timer2_hwmod = { | |||
228 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), | 289 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), |
229 | }; | 290 | }; |
230 | 291 | ||
292 | /* UART */ | ||
293 | |||
294 | static struct omap_hwmod_class_sysconfig uart_sysc = { | ||
295 | .rev_offs = 0x50, | ||
296 | .sysc_offs = 0x54, | ||
297 | .syss_offs = 0x58, | ||
298 | .sysc_flags = (SYSC_HAS_SIDLEMODE | | ||
299 | SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET | | ||
300 | SYSC_HAS_AUTOIDLE), | ||
301 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART), | ||
302 | .sysc_fields = &omap_hwmod_sysc_type1, | ||
303 | }; | ||
304 | |||
305 | static struct omap_hwmod_class uart_class = { | ||
306 | .name = "uart", | ||
307 | .sysc = &uart_sysc, | ||
308 | }; | ||
309 | |||
310 | /* UART1 */ | ||
311 | |||
312 | static struct omap_hwmod_irq_info uart1_mpu_irqs[] = { | ||
313 | { .irq = INT_24XX_UART1_IRQ, }, | ||
314 | }; | ||
315 | |||
316 | static struct omap_hwmod_dma_info uart1_sdma_reqs[] = { | ||
317 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, }, | ||
318 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, }, | ||
319 | }; | ||
320 | |||
321 | static struct omap_hwmod_ocp_if *omap2420_uart1_slaves[] = { | ||
322 | &omap2_l4_core__uart1, | ||
323 | }; | ||
324 | |||
325 | static struct omap_hwmod omap2420_uart1_hwmod = { | ||
326 | .name = "uart1", | ||
327 | .mpu_irqs = uart1_mpu_irqs, | ||
328 | .mpu_irqs_cnt = ARRAY_SIZE(uart1_mpu_irqs), | ||
329 | .sdma_reqs = uart1_sdma_reqs, | ||
330 | .sdma_reqs_cnt = ARRAY_SIZE(uart1_sdma_reqs), | ||
331 | .main_clk = "uart1_fck", | ||
332 | .prcm = { | ||
333 | .omap2 = { | ||
334 | .module_offs = CORE_MOD, | ||
335 | .prcm_reg_id = 1, | ||
336 | .module_bit = OMAP24XX_EN_UART1_SHIFT, | ||
337 | .idlest_reg_id = 1, | ||
338 | .idlest_idle_bit = OMAP24XX_EN_UART1_SHIFT, | ||
339 | }, | ||
340 | }, | ||
341 | .slaves = omap2420_uart1_slaves, | ||
342 | .slaves_cnt = ARRAY_SIZE(omap2420_uart1_slaves), | ||
343 | .class = &uart_class, | ||
344 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), | ||
345 | }; | ||
346 | |||
347 | /* UART2 */ | ||
348 | |||
349 | static struct omap_hwmod_irq_info uart2_mpu_irqs[] = { | ||
350 | { .irq = INT_24XX_UART2_IRQ, }, | ||
351 | }; | ||
352 | |||
353 | static struct omap_hwmod_dma_info uart2_sdma_reqs[] = { | ||
354 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, }, | ||
355 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, }, | ||
356 | }; | ||
357 | |||
358 | static struct omap_hwmod_ocp_if *omap2420_uart2_slaves[] = { | ||
359 | &omap2_l4_core__uart2, | ||
360 | }; | ||
361 | |||
362 | static struct omap_hwmod omap2420_uart2_hwmod = { | ||
363 | .name = "uart2", | ||
364 | .mpu_irqs = uart2_mpu_irqs, | ||
365 | .mpu_irqs_cnt = ARRAY_SIZE(uart2_mpu_irqs), | ||
366 | .sdma_reqs = uart2_sdma_reqs, | ||
367 | .sdma_reqs_cnt = ARRAY_SIZE(uart2_sdma_reqs), | ||
368 | .main_clk = "uart2_fck", | ||
369 | .prcm = { | ||
370 | .omap2 = { | ||
371 | .module_offs = CORE_MOD, | ||
372 | .prcm_reg_id = 1, | ||
373 | .module_bit = OMAP24XX_EN_UART2_SHIFT, | ||
374 | .idlest_reg_id = 1, | ||
375 | .idlest_idle_bit = OMAP24XX_EN_UART2_SHIFT, | ||
376 | }, | ||
377 | }, | ||
378 | .slaves = omap2420_uart2_slaves, | ||
379 | .slaves_cnt = ARRAY_SIZE(omap2420_uart2_slaves), | ||
380 | .class = &uart_class, | ||
381 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), | ||
382 | }; | ||
383 | |||
384 | /* UART3 */ | ||
385 | |||
386 | static struct omap_hwmod_irq_info uart3_mpu_irqs[] = { | ||
387 | { .irq = INT_24XX_UART3_IRQ, }, | ||
388 | }; | ||
389 | |||
390 | static struct omap_hwmod_dma_info uart3_sdma_reqs[] = { | ||
391 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, }, | ||
392 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, }, | ||
393 | }; | ||
394 | |||
395 | static struct omap_hwmod_ocp_if *omap2420_uart3_slaves[] = { | ||
396 | &omap2_l4_core__uart3, | ||
397 | }; | ||
398 | |||
399 | static struct omap_hwmod omap2420_uart3_hwmod = { | ||
400 | .name = "uart3", | ||
401 | .mpu_irqs = uart3_mpu_irqs, | ||
402 | .mpu_irqs_cnt = ARRAY_SIZE(uart3_mpu_irqs), | ||
403 | .sdma_reqs = uart3_sdma_reqs, | ||
404 | .sdma_reqs_cnt = ARRAY_SIZE(uart3_sdma_reqs), | ||
405 | .main_clk = "uart3_fck", | ||
406 | .prcm = { | ||
407 | .omap2 = { | ||
408 | .module_offs = CORE_MOD, | ||
409 | .prcm_reg_id = 2, | ||
410 | .module_bit = OMAP24XX_EN_UART3_SHIFT, | ||
411 | .idlest_reg_id = 2, | ||
412 | .idlest_idle_bit = OMAP24XX_EN_UART3_SHIFT, | ||
413 | }, | ||
414 | }, | ||
415 | .slaves = omap2420_uart3_slaves, | ||
416 | .slaves_cnt = ARRAY_SIZE(omap2420_uart3_slaves), | ||
417 | .class = &uart_class, | ||
418 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), | ||
419 | }; | ||
420 | |||
231 | static __initdata struct omap_hwmod *omap2420_hwmods[] = { | 421 | static __initdata struct omap_hwmod *omap2420_hwmods[] = { |
232 | &omap2420_l3_main_hwmod, | 422 | &omap2420_l3_main_hwmod, |
233 | &omap2420_l4_core_hwmod, | 423 | &omap2420_l4_core_hwmod, |
@@ -235,6 +425,9 @@ static __initdata struct omap_hwmod *omap2420_hwmods[] = { | |||
235 | &omap2420_mpu_hwmod, | 425 | &omap2420_mpu_hwmod, |
236 | &omap2420_iva_hwmod, | 426 | &omap2420_iva_hwmod, |
237 | &omap2420_wd_timer2_hwmod, | 427 | &omap2420_wd_timer2_hwmod, |
428 | &omap2420_uart1_hwmod, | ||
429 | &omap2420_uart2_hwmod, | ||
430 | &omap2420_uart3_hwmod, | ||
238 | NULL, | 431 | NULL, |
239 | }; | 432 | }; |
240 | 433 | ||
diff --git a/arch/arm/mach-omap2/omap_hwmod_2430_data.c b/arch/arm/mach-omap2/omap_hwmod_2430_data.c index 7ec927aa23de..12d939e456cf 100644 --- a/arch/arm/mach-omap2/omap_hwmod_2430_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_2430_data.c | |||
@@ -15,6 +15,7 @@ | |||
15 | #include <mach/irqs.h> | 15 | #include <mach/irqs.h> |
16 | #include <plat/cpu.h> | 16 | #include <plat/cpu.h> |
17 | #include <plat/dma.h> | 17 | #include <plat/dma.h> |
18 | #include <plat/serial.h> | ||
18 | 19 | ||
19 | #include "omap_hwmod_common_data.h" | 20 | #include "omap_hwmod_common_data.h" |
20 | 21 | ||
@@ -73,6 +74,9 @@ static struct omap_hwmod omap2430_l3_main_hwmod = { | |||
73 | }; | 74 | }; |
74 | 75 | ||
75 | static struct omap_hwmod omap2430_l4_wkup_hwmod; | 76 | static struct omap_hwmod omap2430_l4_wkup_hwmod; |
77 | static struct omap_hwmod omap2430_uart1_hwmod; | ||
78 | static struct omap_hwmod omap2430_uart2_hwmod; | ||
79 | static struct omap_hwmod omap2430_uart3_hwmod; | ||
76 | 80 | ||
77 | /* L4_CORE -> L4_WKUP interface */ | 81 | /* L4_CORE -> L4_WKUP interface */ |
78 | static struct omap_hwmod_ocp_if omap2430_l4_core__l4_wkup = { | 82 | static struct omap_hwmod_ocp_if omap2430_l4_core__l4_wkup = { |
@@ -81,6 +85,60 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__l4_wkup = { | |||
81 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 85 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
82 | }; | 86 | }; |
83 | 87 | ||
88 | /* L4 CORE -> UART1 interface */ | ||
89 | static struct omap_hwmod_addr_space omap2430_uart1_addr_space[] = { | ||
90 | { | ||
91 | .pa_start = OMAP2_UART1_BASE, | ||
92 | .pa_end = OMAP2_UART1_BASE + SZ_8K - 1, | ||
93 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
94 | }, | ||
95 | }; | ||
96 | |||
97 | static struct omap_hwmod_ocp_if omap2_l4_core__uart1 = { | ||
98 | .master = &omap2430_l4_core_hwmod, | ||
99 | .slave = &omap2430_uart1_hwmod, | ||
100 | .clk = "uart1_ick", | ||
101 | .addr = omap2430_uart1_addr_space, | ||
102 | .addr_cnt = ARRAY_SIZE(omap2430_uart1_addr_space), | ||
103 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
104 | }; | ||
105 | |||
106 | /* L4 CORE -> UART2 interface */ | ||
107 | static struct omap_hwmod_addr_space omap2430_uart2_addr_space[] = { | ||
108 | { | ||
109 | .pa_start = OMAP2_UART2_BASE, | ||
110 | .pa_end = OMAP2_UART2_BASE + SZ_1K - 1, | ||
111 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
112 | }, | ||
113 | }; | ||
114 | |||
115 | static struct omap_hwmod_ocp_if omap2_l4_core__uart2 = { | ||
116 | .master = &omap2430_l4_core_hwmod, | ||
117 | .slave = &omap2430_uart2_hwmod, | ||
118 | .clk = "uart2_ick", | ||
119 | .addr = omap2430_uart2_addr_space, | ||
120 | .addr_cnt = ARRAY_SIZE(omap2430_uart2_addr_space), | ||
121 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
122 | }; | ||
123 | |||
124 | /* L4 PER -> UART3 interface */ | ||
125 | static struct omap_hwmod_addr_space omap2430_uart3_addr_space[] = { | ||
126 | { | ||
127 | .pa_start = OMAP2_UART3_BASE, | ||
128 | .pa_end = OMAP2_UART3_BASE + SZ_1K - 1, | ||
129 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
130 | }, | ||
131 | }; | ||
132 | |||
133 | static struct omap_hwmod_ocp_if omap2_l4_core__uart3 = { | ||
134 | .master = &omap2430_l4_core_hwmod, | ||
135 | .slave = &omap2430_uart3_hwmod, | ||
136 | .clk = "uart3_ick", | ||
137 | .addr = omap2430_uart3_addr_space, | ||
138 | .addr_cnt = ARRAY_SIZE(omap2430_uart3_addr_space), | ||
139 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
140 | }; | ||
141 | |||
84 | /* Slave interfaces on the L4_CORE interconnect */ | 142 | /* Slave interfaces on the L4_CORE interconnect */ |
85 | static struct omap_hwmod_ocp_if *omap2430_l4_core_slaves[] = { | 143 | static struct omap_hwmod_ocp_if *omap2430_l4_core_slaves[] = { |
86 | &omap2430_l3_main__l4_core, | 144 | &omap2430_l3_main__l4_core, |
@@ -106,6 +164,9 @@ static struct omap_hwmod omap2430_l4_core_hwmod = { | |||
106 | /* Slave interfaces on the L4_WKUP interconnect */ | 164 | /* Slave interfaces on the L4_WKUP interconnect */ |
107 | static struct omap_hwmod_ocp_if *omap2430_l4_wkup_slaves[] = { | 165 | static struct omap_hwmod_ocp_if *omap2430_l4_wkup_slaves[] = { |
108 | &omap2430_l4_core__l4_wkup, | 166 | &omap2430_l4_core__l4_wkup, |
167 | &omap2_l4_core__uart1, | ||
168 | &omap2_l4_core__uart2, | ||
169 | &omap2_l4_core__uart3, | ||
109 | }; | 170 | }; |
110 | 171 | ||
111 | /* Master interfaces on the L4_WKUP interconnect */ | 172 | /* Master interfaces on the L4_WKUP interconnect */ |
@@ -228,6 +289,135 @@ static struct omap_hwmod omap2430_wd_timer2_hwmod = { | |||
228 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), | 289 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), |
229 | }; | 290 | }; |
230 | 291 | ||
292 | /* UART */ | ||
293 | |||
294 | static struct omap_hwmod_class_sysconfig uart_sysc = { | ||
295 | .rev_offs = 0x50, | ||
296 | .sysc_offs = 0x54, | ||
297 | .syss_offs = 0x58, | ||
298 | .sysc_flags = (SYSC_HAS_SIDLEMODE | | ||
299 | SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET | | ||
300 | SYSC_HAS_AUTOIDLE), | ||
301 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART), | ||
302 | .sysc_fields = &omap_hwmod_sysc_type1, | ||
303 | }; | ||
304 | |||
305 | static struct omap_hwmod_class uart_class = { | ||
306 | .name = "uart", | ||
307 | .sysc = &uart_sysc, | ||
308 | }; | ||
309 | |||
310 | /* UART1 */ | ||
311 | |||
312 | static struct omap_hwmod_irq_info uart1_mpu_irqs[] = { | ||
313 | { .irq = INT_24XX_UART1_IRQ, }, | ||
314 | }; | ||
315 | |||
316 | static struct omap_hwmod_dma_info uart1_sdma_reqs[] = { | ||
317 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, }, | ||
318 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, }, | ||
319 | }; | ||
320 | |||
321 | static struct omap_hwmod_ocp_if *omap2430_uart1_slaves[] = { | ||
322 | &omap2_l4_core__uart1, | ||
323 | }; | ||
324 | |||
325 | static struct omap_hwmod omap2430_uart1_hwmod = { | ||
326 | .name = "uart1", | ||
327 | .mpu_irqs = uart1_mpu_irqs, | ||
328 | .mpu_irqs_cnt = ARRAY_SIZE(uart1_mpu_irqs), | ||
329 | .sdma_reqs = uart1_sdma_reqs, | ||
330 | .sdma_reqs_cnt = ARRAY_SIZE(uart1_sdma_reqs), | ||
331 | .main_clk = "uart1_fck", | ||
332 | .prcm = { | ||
333 | .omap2 = { | ||
334 | .module_offs = CORE_MOD, | ||
335 | .prcm_reg_id = 1, | ||
336 | .module_bit = OMAP24XX_EN_UART1_SHIFT, | ||
337 | .idlest_reg_id = 1, | ||
338 | .idlest_idle_bit = OMAP24XX_EN_UART1_SHIFT, | ||
339 | }, | ||
340 | }, | ||
341 | .slaves = omap2430_uart1_slaves, | ||
342 | .slaves_cnt = ARRAY_SIZE(omap2430_uart1_slaves), | ||
343 | .class = &uart_class, | ||
344 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), | ||
345 | }; | ||
346 | |||
347 | /* UART2 */ | ||
348 | |||
349 | static struct omap_hwmod_irq_info uart2_mpu_irqs[] = { | ||
350 | { .irq = INT_24XX_UART2_IRQ, }, | ||
351 | }; | ||
352 | |||
353 | static struct omap_hwmod_dma_info uart2_sdma_reqs[] = { | ||
354 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, }, | ||
355 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, }, | ||
356 | }; | ||
357 | |||
358 | static struct omap_hwmod_ocp_if *omap2430_uart2_slaves[] = { | ||
359 | &omap2_l4_core__uart2, | ||
360 | }; | ||
361 | |||
362 | static struct omap_hwmod omap2430_uart2_hwmod = { | ||
363 | .name = "uart2", | ||
364 | .mpu_irqs = uart2_mpu_irqs, | ||
365 | .mpu_irqs_cnt = ARRAY_SIZE(uart2_mpu_irqs), | ||
366 | .sdma_reqs = uart2_sdma_reqs, | ||
367 | .sdma_reqs_cnt = ARRAY_SIZE(uart2_sdma_reqs), | ||
368 | .main_clk = "uart2_fck", | ||
369 | .prcm = { | ||
370 | .omap2 = { | ||
371 | .module_offs = CORE_MOD, | ||
372 | .prcm_reg_id = 1, | ||
373 | .module_bit = OMAP24XX_EN_UART2_SHIFT, | ||
374 | .idlest_reg_id = 1, | ||
375 | .idlest_idle_bit = OMAP24XX_EN_UART2_SHIFT, | ||
376 | }, | ||
377 | }, | ||
378 | .slaves = omap2430_uart2_slaves, | ||
379 | .slaves_cnt = ARRAY_SIZE(omap2430_uart2_slaves), | ||
380 | .class = &uart_class, | ||
381 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), | ||
382 | }; | ||
383 | |||
384 | /* UART3 */ | ||
385 | |||
386 | static struct omap_hwmod_irq_info uart3_mpu_irqs[] = { | ||
387 | { .irq = INT_24XX_UART3_IRQ, }, | ||
388 | }; | ||
389 | |||
390 | static struct omap_hwmod_dma_info uart3_sdma_reqs[] = { | ||
391 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, }, | ||
392 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, }, | ||
393 | }; | ||
394 | |||
395 | static struct omap_hwmod_ocp_if *omap2430_uart3_slaves[] = { | ||
396 | &omap2_l4_core__uart3, | ||
397 | }; | ||
398 | |||
399 | static struct omap_hwmod omap2430_uart3_hwmod = { | ||
400 | .name = "uart3", | ||
401 | .mpu_irqs = uart3_mpu_irqs, | ||
402 | .mpu_irqs_cnt = ARRAY_SIZE(uart3_mpu_irqs), | ||
403 | .sdma_reqs = uart3_sdma_reqs, | ||
404 | .sdma_reqs_cnt = ARRAY_SIZE(uart3_sdma_reqs), | ||
405 | .main_clk = "uart3_fck", | ||
406 | .prcm = { | ||
407 | .omap2 = { | ||
408 | .module_offs = CORE_MOD, | ||
409 | .prcm_reg_id = 2, | ||
410 | .module_bit = OMAP24XX_EN_UART3_SHIFT, | ||
411 | .idlest_reg_id = 2, | ||
412 | .idlest_idle_bit = OMAP24XX_EN_UART3_SHIFT, | ||
413 | }, | ||
414 | }, | ||
415 | .slaves = omap2430_uart3_slaves, | ||
416 | .slaves_cnt = ARRAY_SIZE(omap2430_uart3_slaves), | ||
417 | .class = &uart_class, | ||
418 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), | ||
419 | }; | ||
420 | |||
231 | static __initdata struct omap_hwmod *omap2430_hwmods[] = { | 421 | static __initdata struct omap_hwmod *omap2430_hwmods[] = { |
232 | &omap2430_l3_main_hwmod, | 422 | &omap2430_l3_main_hwmod, |
233 | &omap2430_l4_core_hwmod, | 423 | &omap2430_l4_core_hwmod, |
@@ -235,6 +425,9 @@ static __initdata struct omap_hwmod *omap2430_hwmods[] = { | |||
235 | &omap2430_mpu_hwmod, | 425 | &omap2430_mpu_hwmod, |
236 | &omap2430_iva_hwmod, | 426 | &omap2430_iva_hwmod, |
237 | &omap2430_wd_timer2_hwmod, | 427 | &omap2430_wd_timer2_hwmod, |
428 | &omap2430_uart1_hwmod, | ||
429 | &omap2430_uart2_hwmod, | ||
430 | &omap2430_uart3_hwmod, | ||
238 | NULL, | 431 | NULL, |
239 | }; | 432 | }; |
240 | 433 | ||
diff --git a/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c b/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c index 5bfe9c933144..cb97ecf0a3f6 100644 --- a/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c | |||
@@ -17,6 +17,7 @@ | |||
17 | #include <mach/irqs.h> | 17 | #include <mach/irqs.h> |
18 | #include <plat/cpu.h> | 18 | #include <plat/cpu.h> |
19 | #include <plat/dma.h> | 19 | #include <plat/dma.h> |
20 | #include <plat/serial.h> | ||
20 | 21 | ||
21 | #include "omap_hwmod_common_data.h" | 22 | #include "omap_hwmod_common_data.h" |
22 | 23 | ||
@@ -84,6 +85,10 @@ static struct omap_hwmod omap3xxx_l3_main_hwmod = { | |||
84 | }; | 85 | }; |
85 | 86 | ||
86 | static struct omap_hwmod omap3xxx_l4_wkup_hwmod; | 87 | static struct omap_hwmod omap3xxx_l4_wkup_hwmod; |
88 | static struct omap_hwmod omap3xxx_uart1_hwmod; | ||
89 | static struct omap_hwmod omap3xxx_uart2_hwmod; | ||
90 | static struct omap_hwmod omap3xxx_uart3_hwmod; | ||
91 | static struct omap_hwmod omap3xxx_uart4_hwmod; | ||
87 | 92 | ||
88 | /* L4_CORE -> L4_WKUP interface */ | 93 | /* L4_CORE -> L4_WKUP interface */ |
89 | static struct omap_hwmod_ocp_if omap3xxx_l4_core__l4_wkup = { | 94 | static struct omap_hwmod_ocp_if omap3xxx_l4_core__l4_wkup = { |
@@ -92,6 +97,78 @@ static struct omap_hwmod_ocp_if omap3xxx_l4_core__l4_wkup = { | |||
92 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 97 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
93 | }; | 98 | }; |
94 | 99 | ||
100 | /* L4 CORE -> UART1 interface */ | ||
101 | static struct omap_hwmod_addr_space omap3xxx_uart1_addr_space[] = { | ||
102 | { | ||
103 | .pa_start = OMAP3_UART1_BASE, | ||
104 | .pa_end = OMAP3_UART1_BASE + SZ_8K - 1, | ||
105 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
106 | }, | ||
107 | }; | ||
108 | |||
109 | static struct omap_hwmod_ocp_if omap3_l4_core__uart1 = { | ||
110 | .master = &omap3xxx_l4_core_hwmod, | ||
111 | .slave = &omap3xxx_uart1_hwmod, | ||
112 | .clk = "uart1_ick", | ||
113 | .addr = omap3xxx_uart1_addr_space, | ||
114 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart1_addr_space), | ||
115 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
116 | }; | ||
117 | |||
118 | /* L4 CORE -> UART2 interface */ | ||
119 | static struct omap_hwmod_addr_space omap3xxx_uart2_addr_space[] = { | ||
120 | { | ||
121 | .pa_start = OMAP3_UART2_BASE, | ||
122 | .pa_end = OMAP3_UART2_BASE + SZ_1K - 1, | ||
123 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
124 | }, | ||
125 | }; | ||
126 | |||
127 | static struct omap_hwmod_ocp_if omap3_l4_core__uart2 = { | ||
128 | .master = &omap3xxx_l4_core_hwmod, | ||
129 | .slave = &omap3xxx_uart2_hwmod, | ||
130 | .clk = "uart2_ick", | ||
131 | .addr = omap3xxx_uart2_addr_space, | ||
132 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart2_addr_space), | ||
133 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
134 | }; | ||
135 | |||
136 | /* L4 PER -> UART3 interface */ | ||
137 | static struct omap_hwmod_addr_space omap3xxx_uart3_addr_space[] = { | ||
138 | { | ||
139 | .pa_start = OMAP3_UART3_BASE, | ||
140 | .pa_end = OMAP3_UART3_BASE + SZ_1K - 1, | ||
141 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
142 | }, | ||
143 | }; | ||
144 | |||
145 | static struct omap_hwmod_ocp_if omap3_l4_per__uart3 = { | ||
146 | .master = &omap3xxx_l4_per_hwmod, | ||
147 | .slave = &omap3xxx_uart3_hwmod, | ||
148 | .clk = "uart3_ick", | ||
149 | .addr = omap3xxx_uart3_addr_space, | ||
150 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart3_addr_space), | ||
151 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
152 | }; | ||
153 | |||
154 | /* L4 PER -> UART4 interface */ | ||
155 | static struct omap_hwmod_addr_space omap3xxx_uart4_addr_space[] = { | ||
156 | { | ||
157 | .pa_start = OMAP3_UART4_BASE, | ||
158 | .pa_end = OMAP3_UART4_BASE + SZ_1K - 1, | ||
159 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
160 | }, | ||
161 | }; | ||
162 | |||
163 | static struct omap_hwmod_ocp_if omap3_l4_per__uart4 = { | ||
164 | .master = &omap3xxx_l4_per_hwmod, | ||
165 | .slave = &omap3xxx_uart4_hwmod, | ||
166 | .clk = "uart4_ick", | ||
167 | .addr = omap3xxx_uart4_addr_space, | ||
168 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart4_addr_space), | ||
169 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
170 | }; | ||
171 | |||
95 | /* Slave interfaces on the L4_CORE interconnect */ | 172 | /* Slave interfaces on the L4_CORE interconnect */ |
96 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_slaves[] = { | 173 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_slaves[] = { |
97 | &omap3xxx_l3_main__l4_core, | 174 | &omap3xxx_l3_main__l4_core, |
@@ -100,6 +177,8 @@ static struct omap_hwmod_ocp_if *omap3xxx_l4_core_slaves[] = { | |||
100 | /* Master interfaces on the L4_CORE interconnect */ | 177 | /* Master interfaces on the L4_CORE interconnect */ |
101 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_masters[] = { | 178 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_masters[] = { |
102 | &omap3xxx_l4_core__l4_wkup, | 179 | &omap3xxx_l4_core__l4_wkup, |
180 | &omap3_l4_core__uart1, | ||
181 | &omap3_l4_core__uart2, | ||
103 | }; | 182 | }; |
104 | 183 | ||
105 | /* L4 CORE */ | 184 | /* L4 CORE */ |
@@ -121,6 +200,8 @@ static struct omap_hwmod_ocp_if *omap3xxx_l4_per_slaves[] = { | |||
121 | 200 | ||
122 | /* Master interfaces on the L4_PER interconnect */ | 201 | /* Master interfaces on the L4_PER interconnect */ |
123 | static struct omap_hwmod_ocp_if *omap3xxx_l4_per_masters[] = { | 202 | static struct omap_hwmod_ocp_if *omap3xxx_l4_per_masters[] = { |
203 | &omap3_l4_per__uart3, | ||
204 | &omap3_l4_per__uart4, | ||
124 | }; | 205 | }; |
125 | 206 | ||
126 | /* L4 PER */ | 207 | /* L4 PER */ |
@@ -262,6 +343,172 @@ static struct omap_hwmod omap3xxx_wd_timer2_hwmod = { | |||
262 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), | 343 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), |
263 | }; | 344 | }; |
264 | 345 | ||
346 | /* UART common */ | ||
347 | |||
348 | static struct omap_hwmod_class_sysconfig uart_sysc = { | ||
349 | .rev_offs = 0x50, | ||
350 | .sysc_offs = 0x54, | ||
351 | .syss_offs = 0x58, | ||
352 | .sysc_flags = (SYSC_HAS_SIDLEMODE | | ||
353 | SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET | | ||
354 | SYSC_HAS_AUTOIDLE), | ||
355 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART), | ||
356 | .sysc_fields = &omap_hwmod_sysc_type1, | ||
357 | }; | ||
358 | |||
359 | static struct omap_hwmod_class uart_class = { | ||
360 | .name = "uart", | ||
361 | .sysc = &uart_sysc, | ||
362 | }; | ||
363 | |||
364 | /* UART1 */ | ||
365 | |||
366 | static struct omap_hwmod_irq_info uart1_mpu_irqs[] = { | ||
367 | { .irq = INT_24XX_UART1_IRQ, }, | ||
368 | }; | ||
369 | |||
370 | static struct omap_hwmod_dma_info uart1_sdma_reqs[] = { | ||
371 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, }, | ||
372 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, }, | ||
373 | }; | ||
374 | |||
375 | static struct omap_hwmod_ocp_if *omap3xxx_uart1_slaves[] = { | ||
376 | &omap3_l4_core__uart1, | ||
377 | }; | ||
378 | |||
379 | static struct omap_hwmod omap3xxx_uart1_hwmod = { | ||
380 | .name = "uart1", | ||
381 | .mpu_irqs = uart1_mpu_irqs, | ||
382 | .mpu_irqs_cnt = ARRAY_SIZE(uart1_mpu_irqs), | ||
383 | .sdma_reqs = uart1_sdma_reqs, | ||
384 | .sdma_reqs_cnt = ARRAY_SIZE(uart1_sdma_reqs), | ||
385 | .main_clk = "uart1_fck", | ||
386 | .prcm = { | ||
387 | .omap2 = { | ||
388 | .module_offs = CORE_MOD, | ||
389 | .prcm_reg_id = 1, | ||
390 | .module_bit = OMAP3430_EN_UART1_SHIFT, | ||
391 | .idlest_reg_id = 1, | ||
392 | .idlest_idle_bit = OMAP3430_EN_UART1_SHIFT, | ||
393 | }, | ||
394 | }, | ||
395 | .slaves = omap3xxx_uart1_slaves, | ||
396 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart1_slaves), | ||
397 | .class = &uart_class, | ||
398 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), | ||
399 | }; | ||
400 | |||
401 | /* UART2 */ | ||
402 | |||
403 | static struct omap_hwmod_irq_info uart2_mpu_irqs[] = { | ||
404 | { .irq = INT_24XX_UART2_IRQ, }, | ||
405 | }; | ||
406 | |||
407 | static struct omap_hwmod_dma_info uart2_sdma_reqs[] = { | ||
408 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, }, | ||
409 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, }, | ||
410 | }; | ||
411 | |||
412 | static struct omap_hwmod_ocp_if *omap3xxx_uart2_slaves[] = { | ||
413 | &omap3_l4_core__uart2, | ||
414 | }; | ||
415 | |||
416 | static struct omap_hwmod omap3xxx_uart2_hwmod = { | ||
417 | .name = "uart2", | ||
418 | .mpu_irqs = uart2_mpu_irqs, | ||
419 | .mpu_irqs_cnt = ARRAY_SIZE(uart2_mpu_irqs), | ||
420 | .sdma_reqs = uart2_sdma_reqs, | ||
421 | .sdma_reqs_cnt = ARRAY_SIZE(uart2_sdma_reqs), | ||
422 | .main_clk = "uart2_fck", | ||
423 | .prcm = { | ||
424 | .omap2 = { | ||
425 | .module_offs = CORE_MOD, | ||
426 | .prcm_reg_id = 1, | ||
427 | .module_bit = OMAP3430_EN_UART2_SHIFT, | ||
428 | .idlest_reg_id = 1, | ||
429 | .idlest_idle_bit = OMAP3430_EN_UART2_SHIFT, | ||
430 | }, | ||
431 | }, | ||
432 | .slaves = omap3xxx_uart2_slaves, | ||
433 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart2_slaves), | ||
434 | .class = &uart_class, | ||
435 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), | ||
436 | }; | ||
437 | |||
438 | /* UART3 */ | ||
439 | |||
440 | static struct omap_hwmod_irq_info uart3_mpu_irqs[] = { | ||
441 | { .irq = INT_24XX_UART3_IRQ, }, | ||
442 | }; | ||
443 | |||
444 | static struct omap_hwmod_dma_info uart3_sdma_reqs[] = { | ||
445 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, }, | ||
446 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, }, | ||
447 | }; | ||
448 | |||
449 | static struct omap_hwmod_ocp_if *omap3xxx_uart3_slaves[] = { | ||
450 | &omap3_l4_per__uart3, | ||
451 | }; | ||
452 | |||
453 | static struct omap_hwmod omap3xxx_uart3_hwmod = { | ||
454 | .name = "uart3", | ||
455 | .mpu_irqs = uart3_mpu_irqs, | ||
456 | .mpu_irqs_cnt = ARRAY_SIZE(uart3_mpu_irqs), | ||
457 | .sdma_reqs = uart3_sdma_reqs, | ||
458 | .sdma_reqs_cnt = ARRAY_SIZE(uart3_sdma_reqs), | ||
459 | .main_clk = "uart3_fck", | ||
460 | .prcm = { | ||
461 | .omap2 = { | ||
462 | .module_offs = OMAP3430_PER_MOD, | ||
463 | .prcm_reg_id = 1, | ||
464 | .module_bit = OMAP3430_EN_UART3_SHIFT, | ||
465 | .idlest_reg_id = 1, | ||
466 | .idlest_idle_bit = OMAP3430_EN_UART3_SHIFT, | ||
467 | }, | ||
468 | }, | ||
469 | .slaves = omap3xxx_uart3_slaves, | ||
470 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart3_slaves), | ||
471 | .class = &uart_class, | ||
472 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), | ||
473 | }; | ||
474 | |||
475 | /* UART4 */ | ||
476 | |||
477 | static struct omap_hwmod_irq_info uart4_mpu_irqs[] = { | ||
478 | { .irq = INT_36XX_UART4_IRQ, }, | ||
479 | }; | ||
480 | |||
481 | static struct omap_hwmod_dma_info uart4_sdma_reqs[] = { | ||
482 | { .name = "rx", .dma_req = OMAP36XX_DMA_UART4_RX, }, | ||
483 | { .name = "tx", .dma_req = OMAP36XX_DMA_UART4_TX, }, | ||
484 | }; | ||
485 | |||
486 | static struct omap_hwmod_ocp_if *omap3xxx_uart4_slaves[] = { | ||
487 | &omap3_l4_per__uart4, | ||
488 | }; | ||
489 | |||
490 | static struct omap_hwmod omap3xxx_uart4_hwmod = { | ||
491 | .name = "uart4", | ||
492 | .mpu_irqs = uart4_mpu_irqs, | ||
493 | .mpu_irqs_cnt = ARRAY_SIZE(uart4_mpu_irqs), | ||
494 | .sdma_reqs = uart4_sdma_reqs, | ||
495 | .sdma_reqs_cnt = ARRAY_SIZE(uart4_sdma_reqs), | ||
496 | .main_clk = "uart4_fck", | ||
497 | .prcm = { | ||
498 | .omap2 = { | ||
499 | .module_offs = OMAP3430_PER_MOD, | ||
500 | .prcm_reg_id = 1, | ||
501 | .module_bit = OMAP3630_EN_UART4_SHIFT, | ||
502 | .idlest_reg_id = 1, | ||
503 | .idlest_idle_bit = OMAP3630_EN_UART4_SHIFT, | ||
504 | }, | ||
505 | }, | ||
506 | .slaves = omap3xxx_uart4_slaves, | ||
507 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart4_slaves), | ||
508 | .class = &uart_class, | ||
509 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3630ES1), | ||
510 | }; | ||
511 | |||
265 | static __initdata struct omap_hwmod *omap3xxx_hwmods[] = { | 512 | static __initdata struct omap_hwmod *omap3xxx_hwmods[] = { |
266 | &omap3xxx_l3_main_hwmod, | 513 | &omap3xxx_l3_main_hwmod, |
267 | &omap3xxx_l4_core_hwmod, | 514 | &omap3xxx_l4_core_hwmod, |
@@ -270,6 +517,10 @@ static __initdata struct omap_hwmod *omap3xxx_hwmods[] = { | |||
270 | &omap3xxx_mpu_hwmod, | 517 | &omap3xxx_mpu_hwmod, |
271 | &omap3xxx_iva_hwmod, | 518 | &omap3xxx_iva_hwmod, |
272 | &omap3xxx_wd_timer2_hwmod, | 519 | &omap3xxx_wd_timer2_hwmod, |
520 | &omap3xxx_uart1_hwmod, | ||
521 | &omap3xxx_uart2_hwmod, | ||
522 | &omap3xxx_uart3_hwmod, | ||
523 | &omap3xxx_uart4_hwmod, | ||
273 | NULL, | 524 | NULL, |
274 | }; | 525 | }; |
275 | 526 | ||
@@ -277,5 +528,3 @@ int __init omap3xxx_hwmod_init(void) | |||
277 | { | 528 | { |
278 | return omap_hwmod_init(omap3xxx_hwmods); | 529 | return omap_hwmod_init(omap3xxx_hwmods); |
279 | } | 530 | } |
280 | |||
281 | |||
diff --git a/arch/arm/mach-omap2/omap_hwmod_44xx_data.c b/arch/arm/mach-omap2/omap_hwmod_44xx_data.c index 9523b4c9537f..7274db4de487 100644 --- a/arch/arm/mach-omap2/omap_hwmod_44xx_data.c +++ b/arch/arm/mach-omap2/omap_hwmod_44xx_data.c | |||
@@ -468,6 +468,21 @@ static struct omap_hwmod_class_sysconfig omap44xx_wd_timer_sysc = { | |||
468 | .sysc_fields = &omap_hwmod_sysc_type1, | 468 | .sysc_fields = &omap_hwmod_sysc_type1, |
469 | }; | 469 | }; |
470 | 470 | ||
471 | /* | ||
472 | * 'uart' class | ||
473 | * universal asynchronous receiver/transmitter (uart) | ||
474 | */ | ||
475 | |||
476 | static struct omap_hwmod_class_sysconfig omap44xx_uart_sysc = { | ||
477 | .rev_offs = 0x0050, | ||
478 | .sysc_offs = 0x0054, | ||
479 | .syss_offs = 0x0058, | ||
480 | .sysc_flags = (SYSC_HAS_ENAWAKEUP | SYSC_HAS_SIDLEMODE | | ||
481 | SYSC_HAS_SOFTRESET | SYSC_HAS_AUTOIDLE), | ||
482 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART), | ||
483 | .sysc_fields = &omap_hwmod_sysc_type1, | ||
484 | }; | ||
485 | |||
471 | static struct omap_hwmod_class omap44xx_wd_timer_hwmod_class = { | 486 | static struct omap_hwmod_class omap44xx_wd_timer_hwmod_class = { |
472 | .name = "wd_timer", | 487 | .name = "wd_timer", |
473 | .sysc = &omap44xx_wd_timer_sysc, | 488 | .sysc = &omap44xx_wd_timer_sysc, |
@@ -487,6 +502,82 @@ static struct omap_hwmod_addr_space omap44xx_wd_timer2_addrs[] = { | |||
487 | }, | 502 | }, |
488 | }; | 503 | }; |
489 | 504 | ||
505 | static struct omap_hwmod_class omap44xx_uart_hwmod_class = { | ||
506 | .name = "uart", | ||
507 | .sysc = &omap44xx_uart_sysc, | ||
508 | }; | ||
509 | |||
510 | /* uart1 */ | ||
511 | static struct omap_hwmod omap44xx_uart1_hwmod; | ||
512 | static struct omap_hwmod_irq_info omap44xx_uart1_irqs[] = { | ||
513 | { .irq = 72 + OMAP44XX_IRQ_GIC_START }, | ||
514 | }; | ||
515 | |||
516 | static struct omap_hwmod_dma_info omap44xx_uart1_sdma_reqs[] = { | ||
517 | { .name = "tx", .dma_req = 48 + OMAP44XX_DMA_REQ_START }, | ||
518 | { .name = "rx", .dma_req = 49 + OMAP44XX_DMA_REQ_START }, | ||
519 | }; | ||
520 | |||
521 | static struct omap_hwmod_addr_space omap44xx_uart1_addrs[] = { | ||
522 | { | ||
523 | .pa_start = 0x4806a000, | ||
524 | .pa_end = 0x4806a0ff, | ||
525 | .flags = ADDR_TYPE_RT | ||
526 | }, | ||
527 | }; | ||
528 | |||
529 | /* l4_per -> uart1 */ | ||
530 | static struct omap_hwmod_ocp_if omap44xx_l4_per__uart1 = { | ||
531 | .master = &omap44xx_l4_per_hwmod, | ||
532 | .slave = &omap44xx_uart1_hwmod, | ||
533 | .clk = "l4_div_ck", | ||
534 | .addr = omap44xx_uart1_addrs, | ||
535 | .addr_cnt = ARRAY_SIZE(omap44xx_uart1_addrs), | ||
536 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
537 | }; | ||
538 | |||
539 | /* uart1 slave ports */ | ||
540 | static struct omap_hwmod_ocp_if *omap44xx_uart1_slaves[] = { | ||
541 | &omap44xx_l4_per__uart1, | ||
542 | }; | ||
543 | |||
544 | static struct omap_hwmod omap44xx_uart1_hwmod = { | ||
545 | .name = "uart1", | ||
546 | .class = &omap44xx_uart_hwmod_class, | ||
547 | .mpu_irqs = omap44xx_uart1_irqs, | ||
548 | .mpu_irqs_cnt = ARRAY_SIZE(omap44xx_uart1_irqs), | ||
549 | .sdma_reqs = omap44xx_uart1_sdma_reqs, | ||
550 | .sdma_reqs_cnt = ARRAY_SIZE(omap44xx_uart1_sdma_reqs), | ||
551 | .main_clk = "uart1_fck", | ||
552 | .prcm = { | ||
553 | .omap4 = { | ||
554 | .clkctrl_reg = OMAP4430_CM_L4PER_UART1_CLKCTRL, | ||
555 | }, | ||
556 | }, | ||
557 | .slaves = omap44xx_uart1_slaves, | ||
558 | .slaves_cnt = ARRAY_SIZE(omap44xx_uart1_slaves), | ||
559 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP4430), | ||
560 | }; | ||
561 | |||
562 | /* uart2 */ | ||
563 | static struct omap_hwmod omap44xx_uart2_hwmod; | ||
564 | static struct omap_hwmod_irq_info omap44xx_uart2_irqs[] = { | ||
565 | { .irq = 73 + OMAP44XX_IRQ_GIC_START }, | ||
566 | }; | ||
567 | |||
568 | static struct omap_hwmod_dma_info omap44xx_uart2_sdma_reqs[] = { | ||
569 | { .name = "tx", .dma_req = 50 + OMAP44XX_DMA_REQ_START }, | ||
570 | { .name = "rx", .dma_req = 51 + OMAP44XX_DMA_REQ_START }, | ||
571 | }; | ||
572 | |||
573 | static struct omap_hwmod_addr_space omap44xx_uart2_addrs[] = { | ||
574 | { | ||
575 | .pa_start = 0x4806c000, | ||
576 | .pa_end = 0x4806c0ff, | ||
577 | .flags = ADDR_TYPE_RT | ||
578 | }, | ||
579 | }; | ||
580 | |||
490 | /* l4_wkup -> wd_timer2 */ | 581 | /* l4_wkup -> wd_timer2 */ |
491 | static struct omap_hwmod_ocp_if omap44xx_l4_wkup__wd_timer2 = { | 582 | static struct omap_hwmod_ocp_if omap44xx_l4_wkup__wd_timer2 = { |
492 | .master = &omap44xx_l4_wkup_hwmod, | 583 | .master = &omap44xx_l4_wkup_hwmod, |
@@ -532,6 +623,58 @@ static struct omap_hwmod_addr_space omap44xx_wd_timer3_addrs[] = { | |||
532 | }, | 623 | }, |
533 | }; | 624 | }; |
534 | 625 | ||
626 | /* l4_per -> uart2 */ | ||
627 | static struct omap_hwmod_ocp_if omap44xx_l4_per__uart2 = { | ||
628 | .master = &omap44xx_l4_per_hwmod, | ||
629 | .slave = &omap44xx_uart2_hwmod, | ||
630 | .clk = "l4_div_ck", | ||
631 | .addr = omap44xx_uart2_addrs, | ||
632 | .addr_cnt = ARRAY_SIZE(omap44xx_uart2_addrs), | ||
633 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
634 | }; | ||
635 | |||
636 | /* uart2 slave ports */ | ||
637 | static struct omap_hwmod_ocp_if *omap44xx_uart2_slaves[] = { | ||
638 | &omap44xx_l4_per__uart2, | ||
639 | }; | ||
640 | |||
641 | static struct omap_hwmod omap44xx_uart2_hwmod = { | ||
642 | .name = "uart2", | ||
643 | .class = &omap44xx_uart_hwmod_class, | ||
644 | .mpu_irqs = omap44xx_uart2_irqs, | ||
645 | .mpu_irqs_cnt = ARRAY_SIZE(omap44xx_uart2_irqs), | ||
646 | .sdma_reqs = omap44xx_uart2_sdma_reqs, | ||
647 | .sdma_reqs_cnt = ARRAY_SIZE(omap44xx_uart2_sdma_reqs), | ||
648 | .main_clk = "uart2_fck", | ||
649 | .prcm = { | ||
650 | .omap4 = { | ||
651 | .clkctrl_reg = OMAP4430_CM_L4PER_UART2_CLKCTRL, | ||
652 | }, | ||
653 | }, | ||
654 | .slaves = omap44xx_uart2_slaves, | ||
655 | .slaves_cnt = ARRAY_SIZE(omap44xx_uart2_slaves), | ||
656 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP4430), | ||
657 | }; | ||
658 | |||
659 | /* uart3 */ | ||
660 | static struct omap_hwmod omap44xx_uart3_hwmod; | ||
661 | static struct omap_hwmod_irq_info omap44xx_uart3_irqs[] = { | ||
662 | { .irq = 74 + OMAP44XX_IRQ_GIC_START }, | ||
663 | }; | ||
664 | |||
665 | static struct omap_hwmod_dma_info omap44xx_uart3_sdma_reqs[] = { | ||
666 | { .name = "tx", .dma_req = 52 + OMAP44XX_DMA_REQ_START }, | ||
667 | { .name = "rx", .dma_req = 53 + OMAP44XX_DMA_REQ_START }, | ||
668 | }; | ||
669 | |||
670 | static struct omap_hwmod_addr_space omap44xx_uart3_addrs[] = { | ||
671 | { | ||
672 | .pa_start = 0x48020000, | ||
673 | .pa_end = 0x480200ff, | ||
674 | .flags = ADDR_TYPE_RT | ||
675 | }, | ||
676 | }; | ||
677 | |||
535 | /* l4_abe -> wd_timer3 */ | 678 | /* l4_abe -> wd_timer3 */ |
536 | static struct omap_hwmod_ocp_if omap44xx_l4_abe__wd_timer3 = { | 679 | static struct omap_hwmod_ocp_if omap44xx_l4_abe__wd_timer3 = { |
537 | .master = &omap44xx_l4_abe_hwmod, | 680 | .master = &omap44xx_l4_abe_hwmod, |
@@ -551,6 +694,59 @@ static struct omap_hwmod_addr_space omap44xx_wd_timer3_dma_addrs[] = { | |||
551 | }, | 694 | }, |
552 | }; | 695 | }; |
553 | 696 | ||
697 | /* l4_per -> uart3 */ | ||
698 | static struct omap_hwmod_ocp_if omap44xx_l4_per__uart3 = { | ||
699 | .master = &omap44xx_l4_per_hwmod, | ||
700 | .slave = &omap44xx_uart3_hwmod, | ||
701 | .clk = "l4_div_ck", | ||
702 | .addr = omap44xx_uart3_addrs, | ||
703 | .addr_cnt = ARRAY_SIZE(omap44xx_uart3_addrs), | ||
704 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
705 | }; | ||
706 | |||
707 | /* uart3 slave ports */ | ||
708 | static struct omap_hwmod_ocp_if *omap44xx_uart3_slaves[] = { | ||
709 | &omap44xx_l4_per__uart3, | ||
710 | }; | ||
711 | |||
712 | static struct omap_hwmod omap44xx_uart3_hwmod = { | ||
713 | .name = "uart3", | ||
714 | .class = &omap44xx_uart_hwmod_class, | ||
715 | .flags = (HWMOD_INIT_NO_IDLE | HWMOD_INIT_NO_RESET), | ||
716 | .mpu_irqs = omap44xx_uart3_irqs, | ||
717 | .mpu_irqs_cnt = ARRAY_SIZE(omap44xx_uart3_irqs), | ||
718 | .sdma_reqs = omap44xx_uart3_sdma_reqs, | ||
719 | .sdma_reqs_cnt = ARRAY_SIZE(omap44xx_uart3_sdma_reqs), | ||
720 | .main_clk = "uart3_fck", | ||
721 | .prcm = { | ||
722 | .omap4 = { | ||
723 | .clkctrl_reg = OMAP4430_CM_L4PER_UART3_CLKCTRL, | ||
724 | }, | ||
725 | }, | ||
726 | .slaves = omap44xx_uart3_slaves, | ||
727 | .slaves_cnt = ARRAY_SIZE(omap44xx_uart3_slaves), | ||
728 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP4430), | ||
729 | }; | ||
730 | |||
731 | /* uart4 */ | ||
732 | static struct omap_hwmod omap44xx_uart4_hwmod; | ||
733 | static struct omap_hwmod_irq_info omap44xx_uart4_irqs[] = { | ||
734 | { .irq = 70 + OMAP44XX_IRQ_GIC_START }, | ||
735 | }; | ||
736 | |||
737 | static struct omap_hwmod_dma_info omap44xx_uart4_sdma_reqs[] = { | ||
738 | { .name = "tx", .dma_req = 54 + OMAP44XX_DMA_REQ_START }, | ||
739 | { .name = "rx", .dma_req = 55 + OMAP44XX_DMA_REQ_START }, | ||
740 | }; | ||
741 | |||
742 | static struct omap_hwmod_addr_space omap44xx_uart4_addrs[] = { | ||
743 | { | ||
744 | .pa_start = 0x4806e000, | ||
745 | .pa_end = 0x4806e0ff, | ||
746 | .flags = ADDR_TYPE_RT | ||
747 | }, | ||
748 | }; | ||
749 | |||
554 | static struct omap_hwmod_ocp_if omap44xx_l4_abe__wd_timer3_dma = { | 750 | static struct omap_hwmod_ocp_if omap44xx_l4_abe__wd_timer3_dma = { |
555 | .master = &omap44xx_l4_abe_hwmod, | 751 | .master = &omap44xx_l4_abe_hwmod, |
556 | .slave = &omap44xx_wd_timer3_hwmod, | 752 | .slave = &omap44xx_wd_timer3_hwmod, |
@@ -582,6 +778,39 @@ static struct omap_hwmod omap44xx_wd_timer3_hwmod = { | |||
582 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP4430), | 778 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP4430), |
583 | }; | 779 | }; |
584 | 780 | ||
781 | /* l4_per -> uart4 */ | ||
782 | static struct omap_hwmod_ocp_if omap44xx_l4_per__uart4 = { | ||
783 | .master = &omap44xx_l4_per_hwmod, | ||
784 | .slave = &omap44xx_uart4_hwmod, | ||
785 | .clk = "l4_div_ck", | ||
786 | .addr = omap44xx_uart4_addrs, | ||
787 | .addr_cnt = ARRAY_SIZE(omap44xx_uart4_addrs), | ||
788 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
789 | }; | ||
790 | |||
791 | /* uart4 slave ports */ | ||
792 | static struct omap_hwmod_ocp_if *omap44xx_uart4_slaves[] = { | ||
793 | &omap44xx_l4_per__uart4, | ||
794 | }; | ||
795 | |||
796 | static struct omap_hwmod omap44xx_uart4_hwmod = { | ||
797 | .name = "uart4", | ||
798 | .class = &omap44xx_uart_hwmod_class, | ||
799 | .mpu_irqs = omap44xx_uart4_irqs, | ||
800 | .mpu_irqs_cnt = ARRAY_SIZE(omap44xx_uart4_irqs), | ||
801 | .sdma_reqs = omap44xx_uart4_sdma_reqs, | ||
802 | .sdma_reqs_cnt = ARRAY_SIZE(omap44xx_uart4_sdma_reqs), | ||
803 | .main_clk = "uart4_fck", | ||
804 | .prcm = { | ||
805 | .omap4 = { | ||
806 | .clkctrl_reg = OMAP4430_CM_L4PER_UART4_CLKCTRL, | ||
807 | }, | ||
808 | }, | ||
809 | .slaves = omap44xx_uart4_slaves, | ||
810 | .slaves_cnt = ARRAY_SIZE(omap44xx_uart4_slaves), | ||
811 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP4430), | ||
812 | }; | ||
813 | |||
585 | static __initdata struct omap_hwmod *omap44xx_hwmods[] = { | 814 | static __initdata struct omap_hwmod *omap44xx_hwmods[] = { |
586 | /* dmm class */ | 815 | /* dmm class */ |
587 | &omap44xx_dmm_hwmod, | 816 | &omap44xx_dmm_hwmod, |
@@ -605,6 +834,12 @@ static __initdata struct omap_hwmod *omap44xx_hwmods[] = { | |||
605 | /* wd_timer class */ | 834 | /* wd_timer class */ |
606 | &omap44xx_wd_timer2_hwmod, | 835 | &omap44xx_wd_timer2_hwmod, |
607 | &omap44xx_wd_timer3_hwmod, | 836 | &omap44xx_wd_timer3_hwmod, |
837 | |||
838 | /* uart class */ | ||
839 | &omap44xx_uart1_hwmod, | ||
840 | &omap44xx_uart2_hwmod, | ||
841 | &omap44xx_uart3_hwmod, | ||
842 | &omap44xx_uart4_hwmod, | ||
608 | NULL, | 843 | NULL, |
609 | }; | 844 | }; |
610 | 845 | ||
diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c index d2b940c7215d..60baffa27cb3 100644 --- a/arch/arm/mach-omap2/pm34xx.c +++ b/arch/arm/mach-omap2/pm34xx.c | |||
@@ -388,6 +388,7 @@ void omap_sram_idle(void) | |||
388 | /* PER */ | 388 | /* PER */ |
389 | if (per_next_state < PWRDM_POWER_ON) { | 389 | if (per_next_state < PWRDM_POWER_ON) { |
390 | omap_uart_prepare_idle(2); | 390 | omap_uart_prepare_idle(2); |
391 | omap_uart_prepare_idle(3); | ||
391 | omap2_gpio_prepare_for_idle(per_next_state); | 392 | omap2_gpio_prepare_for_idle(per_next_state); |
392 | if (per_next_state == PWRDM_POWER_OFF) | 393 | if (per_next_state == PWRDM_POWER_OFF) |
393 | omap3_per_save_context(); | 394 | omap3_per_save_context(); |
@@ -459,6 +460,7 @@ void omap_sram_idle(void) | |||
459 | if (per_prev_state == PWRDM_POWER_OFF) | 460 | if (per_prev_state == PWRDM_POWER_OFF) |
460 | omap3_per_restore_context(); | 461 | omap3_per_restore_context(); |
461 | omap_uart_resume_idle(2); | 462 | omap_uart_resume_idle(2); |
463 | omap_uart_resume_idle(3); | ||
462 | } | 464 | } |
463 | 465 | ||
464 | /* Disable IO-PAD and IO-CHAIN wakeup */ | 466 | /* Disable IO-PAD and IO-CHAIN wakeup */ |
@@ -676,6 +678,14 @@ static void __init omap3_d2d_idle(void) | |||
676 | 678 | ||
677 | static void __init prcm_setup_regs(void) | 679 | static void __init prcm_setup_regs(void) |
678 | { | 680 | { |
681 | u32 omap3630_auto_uart4_mask = cpu_is_omap3630() ? | ||
682 | OMAP3630_AUTO_UART4_MASK : 0; | ||
683 | u32 omap3630_en_uart4_mask = cpu_is_omap3630() ? | ||
684 | OMAP3630_EN_UART4_MASK : 0; | ||
685 | u32 omap3630_grpsel_uart4_mask = cpu_is_omap3630() ? | ||
686 | OMAP3630_GRPSEL_UART4_MASK : 0; | ||
687 | |||
688 | |||
679 | /* XXX Reset all wkdeps. This should be done when initializing | 689 | /* XXX Reset all wkdeps. This should be done when initializing |
680 | * powerdomains */ | 690 | * powerdomains */ |
681 | prm_write_mod_reg(0, OMAP3430_IVA2_MOD, PM_WKDEP); | 691 | prm_write_mod_reg(0, OMAP3430_IVA2_MOD, PM_WKDEP); |
@@ -762,6 +772,7 @@ static void __init prcm_setup_regs(void) | |||
762 | CM_AUTOIDLE); | 772 | CM_AUTOIDLE); |
763 | 773 | ||
764 | cm_write_mod_reg( | 774 | cm_write_mod_reg( |
775 | omap3630_auto_uart4_mask | | ||
765 | OMAP3430_AUTO_GPIO6_MASK | | 776 | OMAP3430_AUTO_GPIO6_MASK | |
766 | OMAP3430_AUTO_GPIO5_MASK | | 777 | OMAP3430_AUTO_GPIO5_MASK | |
767 | OMAP3430_AUTO_GPIO4_MASK | | 778 | OMAP3430_AUTO_GPIO4_MASK | |
@@ -838,14 +849,16 @@ static void __init prcm_setup_regs(void) | |||
838 | OMAP3430_DSS_MOD, PM_WKEN); | 849 | OMAP3430_DSS_MOD, PM_WKEN); |
839 | 850 | ||
840 | /* Enable wakeups in PER */ | 851 | /* Enable wakeups in PER */ |
841 | prm_write_mod_reg(OMAP3430_EN_GPIO2_MASK | OMAP3430_EN_GPIO3_MASK | | 852 | prm_write_mod_reg(omap3630_en_uart4_mask | |
853 | OMAP3430_EN_GPIO2_MASK | OMAP3430_EN_GPIO3_MASK | | ||
842 | OMAP3430_EN_GPIO4_MASK | OMAP3430_EN_GPIO5_MASK | | 854 | OMAP3430_EN_GPIO4_MASK | OMAP3430_EN_GPIO5_MASK | |
843 | OMAP3430_EN_GPIO6_MASK | OMAP3430_EN_UART3_MASK | | 855 | OMAP3430_EN_GPIO6_MASK | OMAP3430_EN_UART3_MASK | |
844 | OMAP3430_EN_MCBSP2_MASK | OMAP3430_EN_MCBSP3_MASK | | 856 | OMAP3430_EN_MCBSP2_MASK | OMAP3430_EN_MCBSP3_MASK | |
845 | OMAP3430_EN_MCBSP4_MASK, | 857 | OMAP3430_EN_MCBSP4_MASK, |
846 | OMAP3430_PER_MOD, PM_WKEN); | 858 | OMAP3430_PER_MOD, PM_WKEN); |
847 | /* and allow them to wake up MPU */ | 859 | /* and allow them to wake up MPU */ |
848 | prm_write_mod_reg(OMAP3430_GRPSEL_GPIO2_MASK | | 860 | prm_write_mod_reg(omap3630_grpsel_uart4_mask | |
861 | OMAP3430_GRPSEL_GPIO2_MASK | | ||
849 | OMAP3430_GRPSEL_GPIO3_MASK | | 862 | OMAP3430_GRPSEL_GPIO3_MASK | |
850 | OMAP3430_GRPSEL_GPIO4_MASK | | 863 | OMAP3430_GRPSEL_GPIO4_MASK | |
851 | OMAP3430_GRPSEL_GPIO5_MASK | | 864 | OMAP3430_GRPSEL_GPIO5_MASK | |
diff --git a/arch/arm/mach-omap2/prcm-common.h b/arch/arm/mach-omap2/prcm-common.h index 995b7edbf18d..298a22a754e2 100644 --- a/arch/arm/mach-omap2/prcm-common.h +++ b/arch/arm/mach-omap2/prcm-common.h | |||
@@ -382,6 +382,9 @@ | |||
382 | #define OMAP3430_EN_MPU_SHIFT 1 | 382 | #define OMAP3430_EN_MPU_SHIFT 1 |
383 | 383 | ||
384 | /* CM_FCLKEN_PER, CM_ICLKEN_PER, PM_WKEN_PER shared bits */ | 384 | /* CM_FCLKEN_PER, CM_ICLKEN_PER, PM_WKEN_PER shared bits */ |
385 | |||
386 | #define OMAP3630_EN_UART4_MASK (1 << 18) | ||
387 | #define OMAP3630_EN_UART4_SHIFT 18 | ||
385 | #define OMAP3430_EN_GPIO6_MASK (1 << 17) | 388 | #define OMAP3430_EN_GPIO6_MASK (1 << 17) |
386 | #define OMAP3430_EN_GPIO6_SHIFT 17 | 389 | #define OMAP3430_EN_GPIO6_SHIFT 17 |
387 | #define OMAP3430_EN_GPIO5_MASK (1 << 16) | 390 | #define OMAP3430_EN_GPIO5_MASK (1 << 16) |
@@ -422,6 +425,8 @@ | |||
422 | #define OMAP3430_EN_MCBSP2_SHIFT 0 | 425 | #define OMAP3430_EN_MCBSP2_SHIFT 0 |
423 | 426 | ||
424 | /* CM_IDLEST_PER, PM_WKST_PER shared bits */ | 427 | /* CM_IDLEST_PER, PM_WKST_PER shared bits */ |
428 | #define OMAP3630_ST_UART4_SHIFT 18 | ||
429 | #define OMAP3630_ST_UART4_MASK (1 << 18) | ||
425 | #define OMAP3430_ST_GPIO6_SHIFT 17 | 430 | #define OMAP3430_ST_GPIO6_SHIFT 17 |
426 | #define OMAP3430_ST_GPIO6_MASK (1 << 17) | 431 | #define OMAP3430_ST_GPIO6_MASK (1 << 17) |
427 | #define OMAP3430_ST_GPIO5_SHIFT 16 | 432 | #define OMAP3430_ST_GPIO5_SHIFT 16 |
diff --git a/arch/arm/mach-omap2/prm-regbits-34xx.h b/arch/arm/mach-omap2/prm-regbits-34xx.h index 7fd6023edf96..9e63cb743a97 100644 --- a/arch/arm/mach-omap2/prm-regbits-34xx.h +++ b/arch/arm/mach-omap2/prm-regbits-34xx.h | |||
@@ -122,6 +122,7 @@ | |||
122 | #define OMAP3430_MEMRETSTATE_MASK (1 << 8) | 122 | #define OMAP3430_MEMRETSTATE_MASK (1 << 8) |
123 | 123 | ||
124 | /* PM_MPUGRPSEL_PER, PM_IVA2GRPSEL_PER shared bits */ | 124 | /* PM_MPUGRPSEL_PER, PM_IVA2GRPSEL_PER shared bits */ |
125 | #define OMAP3630_GRPSEL_UART4_MASK (1 << 18) | ||
125 | #define OMAP3430_GRPSEL_GPIO6_MASK (1 << 17) | 126 | #define OMAP3430_GRPSEL_GPIO6_MASK (1 << 17) |
126 | #define OMAP3430_GRPSEL_GPIO5_MASK (1 << 16) | 127 | #define OMAP3430_GRPSEL_GPIO5_MASK (1 << 16) |
127 | #define OMAP3430_GRPSEL_GPIO4_MASK (1 << 15) | 128 | #define OMAP3430_GRPSEL_GPIO4_MASK (1 << 15) |
diff --git a/arch/arm/mach-omap2/serial.c b/arch/arm/mach-omap2/serial.c index 566e991ede81..0bcc9df0c034 100644 --- a/arch/arm/mach-omap2/serial.c +++ b/arch/arm/mach-omap2/serial.c | |||
@@ -19,19 +19,30 @@ | |||
19 | */ | 19 | */ |
20 | #include <linux/kernel.h> | 20 | #include <linux/kernel.h> |
21 | #include <linux/init.h> | 21 | #include <linux/init.h> |
22 | #include <linux/serial_8250.h> | ||
23 | #include <linux/serial_reg.h> | 22 | #include <linux/serial_reg.h> |
24 | #include <linux/clk.h> | 23 | #include <linux/clk.h> |
25 | #include <linux/io.h> | 24 | #include <linux/io.h> |
26 | #include <linux/delay.h> | 25 | #include <linux/delay.h> |
26 | #include <linux/platform_device.h> | ||
27 | #include <linux/slab.h> | ||
28 | #include <linux/serial_8250.h> | ||
29 | #include <linux/pm_runtime.h> | ||
30 | |||
31 | #ifdef CONFIG_SERIAL_OMAP | ||
32 | #include <plat/omap-serial.h> | ||
33 | #endif | ||
27 | 34 | ||
28 | #include <plat/common.h> | 35 | #include <plat/common.h> |
29 | #include <plat/board.h> | 36 | #include <plat/board.h> |
30 | #include <plat/clock.h> | 37 | #include <plat/clock.h> |
31 | #include <plat/control.h> | 38 | #include <plat/control.h> |
39 | #include <plat/dma.h> | ||
40 | #include <plat/omap_hwmod.h> | ||
41 | #include <plat/omap_device.h> | ||
32 | 42 | ||
33 | #include "prm.h" | 43 | #include "prm.h" |
34 | #include "pm.h" | 44 | #include "pm.h" |
45 | #include "cm.h" | ||
35 | #include "prm-regbits-34xx.h" | 46 | #include "prm-regbits-34xx.h" |
36 | 47 | ||
37 | #define UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV 0x52 | 48 | #define UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV 0x52 |
@@ -48,6 +59,8 @@ | |||
48 | */ | 59 | */ |
49 | #define DEFAULT_TIMEOUT 0 | 60 | #define DEFAULT_TIMEOUT 0 |
50 | 61 | ||
62 | #define MAX_UART_HWMOD_NAME_LEN 16 | ||
63 | |||
51 | struct omap_uart_state { | 64 | struct omap_uart_state { |
52 | int num; | 65 | int num; |
53 | int can_sleep; | 66 | int can_sleep; |
@@ -58,14 +71,21 @@ struct omap_uart_state { | |||
58 | void __iomem *wk_en; | 71 | void __iomem *wk_en; |
59 | u32 wk_mask; | 72 | u32 wk_mask; |
60 | u32 padconf; | 73 | u32 padconf; |
74 | u32 dma_enabled; | ||
61 | 75 | ||
62 | struct clk *ick; | 76 | struct clk *ick; |
63 | struct clk *fck; | 77 | struct clk *fck; |
64 | int clocked; | 78 | int clocked; |
65 | 79 | ||
66 | struct plat_serial8250_port *p; | 80 | int irq; |
81 | int regshift; | ||
82 | int irqflags; | ||
83 | void __iomem *membase; | ||
84 | resource_size_t mapbase; | ||
85 | |||
67 | struct list_head node; | 86 | struct list_head node; |
68 | struct platform_device pdev; | 87 | struct omap_hwmod *oh; |
88 | struct platform_device *pdev; | ||
69 | 89 | ||
70 | u32 errata; | 90 | u32 errata; |
71 | #if defined(CONFIG_ARCH_OMAP3) && defined(CONFIG_PM) | 91 | #if defined(CONFIG_ARCH_OMAP3) && defined(CONFIG_PM) |
@@ -83,75 +103,47 @@ struct omap_uart_state { | |||
83 | }; | 103 | }; |
84 | 104 | ||
85 | static LIST_HEAD(uart_list); | 105 | static LIST_HEAD(uart_list); |
106 | static u8 num_uarts; | ||
86 | 107 | ||
87 | static struct plat_serial8250_port serial_platform_data0[] = { | 108 | /* |
88 | { | 109 | * Since these idle/enable hooks are used in the idle path itself |
89 | .irq = 72, | 110 | * which has interrupts disabled, use the non-locking versions of |
90 | .flags = UPF_BOOT_AUTOCONF, | 111 | * the hwmod enable/disable functions. |
91 | .iotype = UPIO_MEM, | 112 | */ |
92 | .regshift = 2, | 113 | static int uart_idle_hwmod(struct omap_device *od) |
93 | .uartclk = OMAP24XX_BASE_BAUD * 16, | 114 | { |
94 | }, { | 115 | _omap_hwmod_idle(od->hwmods[0]); |
95 | .flags = 0 | ||
96 | } | ||
97 | }; | ||
98 | 116 | ||
99 | static struct plat_serial8250_port serial_platform_data1[] = { | 117 | return 0; |
100 | { | 118 | } |
101 | .irq = 73, | ||
102 | .flags = UPF_BOOT_AUTOCONF, | ||
103 | .iotype = UPIO_MEM, | ||
104 | .regshift = 2, | ||
105 | .uartclk = OMAP24XX_BASE_BAUD * 16, | ||
106 | }, { | ||
107 | .flags = 0 | ||
108 | } | ||
109 | }; | ||
110 | 119 | ||
111 | static struct plat_serial8250_port serial_platform_data2[] = { | 120 | static int uart_enable_hwmod(struct omap_device *od) |
112 | { | 121 | { |
113 | .irq = 74, | 122 | _omap_hwmod_enable(od->hwmods[0]); |
114 | .flags = UPF_BOOT_AUTOCONF, | 123 | |
115 | .iotype = UPIO_MEM, | 124 | return 0; |
116 | .regshift = 2, | 125 | } |
117 | .uartclk = OMAP24XX_BASE_BAUD * 16, | ||
118 | }, { | ||
119 | .flags = 0 | ||
120 | } | ||
121 | }; | ||
122 | 126 | ||
123 | static struct plat_serial8250_port serial_platform_data3[] = { | 127 | static struct omap_device_pm_latency omap_uart_latency[] = { |
124 | { | 128 | { |
125 | .irq = 70, | 129 | .deactivate_func = uart_idle_hwmod, |
126 | .flags = UPF_BOOT_AUTOCONF, | 130 | .activate_func = uart_enable_hwmod, |
127 | .iotype = UPIO_MEM, | 131 | .flags = OMAP_DEVICE_LATENCY_AUTO_ADJUST, |
128 | .regshift = 2, | 132 | }, |
129 | .uartclk = OMAP24XX_BASE_BAUD * 16, | ||
130 | }, { | ||
131 | .flags = 0 | ||
132 | } | ||
133 | }; | 133 | }; |
134 | 134 | ||
135 | void __init omap2_set_globals_uart(struct omap_globals *omap2_globals) | ||
136 | { | ||
137 | serial_platform_data0[0].mapbase = omap2_globals->uart1_phys; | ||
138 | serial_platform_data1[0].mapbase = omap2_globals->uart2_phys; | ||
139 | serial_platform_data2[0].mapbase = omap2_globals->uart3_phys; | ||
140 | serial_platform_data3[0].mapbase = omap2_globals->uart4_phys; | ||
141 | } | ||
142 | |||
143 | static inline unsigned int __serial_read_reg(struct uart_port *up, | 135 | static inline unsigned int __serial_read_reg(struct uart_port *up, |
144 | int offset) | 136 | int offset) |
145 | { | 137 | { |
146 | offset <<= up->regshift; | 138 | offset <<= up->regshift; |
147 | return (unsigned int)__raw_readb(up->membase + offset); | 139 | return (unsigned int)__raw_readb(up->membase + offset); |
148 | } | 140 | } |
149 | 141 | ||
150 | static inline unsigned int serial_read_reg(struct plat_serial8250_port *up, | 142 | static inline unsigned int serial_read_reg(struct omap_uart_state *uart, |
151 | int offset) | 143 | int offset) |
152 | { | 144 | { |
153 | offset <<= up->regshift; | 145 | offset <<= uart->regshift; |
154 | return (unsigned int)__raw_readb(up->membase + offset); | 146 | return (unsigned int)__raw_readb(uart->membase + offset); |
155 | } | 147 | } |
156 | 148 | ||
157 | static inline void __serial_write_reg(struct uart_port *up, int offset, | 149 | static inline void __serial_write_reg(struct uart_port *up, int offset, |
@@ -161,11 +153,11 @@ static inline void __serial_write_reg(struct uart_port *up, int offset, | |||
161 | __raw_writeb(value, up->membase + offset); | 153 | __raw_writeb(value, up->membase + offset); |
162 | } | 154 | } |
163 | 155 | ||
164 | static inline void serial_write_reg(struct plat_serial8250_port *p, int offset, | 156 | static inline void serial_write_reg(struct omap_uart_state *uart, int offset, |
165 | int value) | 157 | int value) |
166 | { | 158 | { |
167 | offset <<= p->regshift; | 159 | offset <<= uart->regshift; |
168 | __raw_writeb(value, p->membase + offset); | 160 | __raw_writeb(value, uart->membase + offset); |
169 | } | 161 | } |
170 | 162 | ||
171 | /* | 163 | /* |
@@ -173,14 +165,12 @@ static inline void serial_write_reg(struct plat_serial8250_port *p, int offset, | |||
173 | * properly. Note that the TX watermark initialization may not be needed | 165 | * properly. Note that the TX watermark initialization may not be needed |
174 | * once the 8250.c watermark handling code is merged. | 166 | * once the 8250.c watermark handling code is merged. |
175 | */ | 167 | */ |
168 | |||
176 | static inline void __init omap_uart_reset(struct omap_uart_state *uart) | 169 | static inline void __init omap_uart_reset(struct omap_uart_state *uart) |
177 | { | 170 | { |
178 | struct plat_serial8250_port *p = uart->p; | 171 | serial_write_reg(uart, UART_OMAP_MDR1, 0x07); |
179 | 172 | serial_write_reg(uart, UART_OMAP_SCR, 0x08); | |
180 | serial_write_reg(p, UART_OMAP_MDR1, 0x07); | 173 | serial_write_reg(uart, UART_OMAP_MDR1, 0x00); |
181 | serial_write_reg(p, UART_OMAP_SCR, 0x08); | ||
182 | serial_write_reg(p, UART_OMAP_MDR1, 0x00); | ||
183 | serial_write_reg(p, UART_OMAP_SYSC, (0x02 << 3) | (1 << 2) | (1 << 0)); | ||
184 | } | 174 | } |
185 | 175 | ||
186 | #if defined(CONFIG_PM) && defined(CONFIG_ARCH_OMAP3) | 176 | #if defined(CONFIG_PM) && defined(CONFIG_ARCH_OMAP3) |
@@ -197,24 +187,23 @@ static inline void __init omap_uart_reset(struct omap_uart_state *uart) | |||
197 | static void omap_uart_mdr1_errataset(struct omap_uart_state *uart, u8 mdr1_val, | 187 | static void omap_uart_mdr1_errataset(struct omap_uart_state *uart, u8 mdr1_val, |
198 | u8 fcr_val) | 188 | u8 fcr_val) |
199 | { | 189 | { |
200 | struct plat_serial8250_port *p = uart->p; | ||
201 | u8 timeout = 255; | 190 | u8 timeout = 255; |
202 | 191 | ||
203 | serial_write_reg(p, UART_OMAP_MDR1, mdr1_val); | 192 | serial_write_reg(uart, UART_OMAP_MDR1, mdr1_val); |
204 | udelay(2); | 193 | udelay(2); |
205 | serial_write_reg(p, UART_FCR, fcr_val | UART_FCR_CLEAR_XMIT | | 194 | serial_write_reg(uart, UART_FCR, fcr_val | UART_FCR_CLEAR_XMIT | |
206 | UART_FCR_CLEAR_RCVR); | 195 | UART_FCR_CLEAR_RCVR); |
207 | /* | 196 | /* |
208 | * Wait for FIFO to empty: when empty, RX_FIFO_E bit is 0 and | 197 | * Wait for FIFO to empty: when empty, RX_FIFO_E bit is 0 and |
209 | * TX_FIFO_E bit is 1. | 198 | * TX_FIFO_E bit is 1. |
210 | */ | 199 | */ |
211 | while (UART_LSR_THRE != (serial_read_reg(p, UART_LSR) & | 200 | while (UART_LSR_THRE != (serial_read_reg(uart, UART_LSR) & |
212 | (UART_LSR_THRE | UART_LSR_DR))) { | 201 | (UART_LSR_THRE | UART_LSR_DR))) { |
213 | timeout--; | 202 | timeout--; |
214 | if (!timeout) { | 203 | if (!timeout) { |
215 | /* Should *never* happen. we warn and carry on */ | 204 | /* Should *never* happen. we warn and carry on */ |
216 | dev_crit(&uart->pdev.dev, "Errata i202: timedout %x\n", | 205 | dev_crit(&uart->pdev->dev, "Errata i202: timedout %x\n", |
217 | serial_read_reg(p, UART_LSR)); | 206 | serial_read_reg(uart, UART_LSR)); |
218 | break; | 207 | break; |
219 | } | 208 | } |
220 | udelay(1); | 209 | udelay(1); |
@@ -224,23 +213,22 @@ static void omap_uart_mdr1_errataset(struct omap_uart_state *uart, u8 mdr1_val, | |||
224 | static void omap_uart_save_context(struct omap_uart_state *uart) | 213 | static void omap_uart_save_context(struct omap_uart_state *uart) |
225 | { | 214 | { |
226 | u16 lcr = 0; | 215 | u16 lcr = 0; |
227 | struct plat_serial8250_port *p = uart->p; | ||
228 | 216 | ||
229 | if (!enable_off_mode) | 217 | if (!enable_off_mode) |
230 | return; | 218 | return; |
231 | 219 | ||
232 | lcr = serial_read_reg(p, UART_LCR); | 220 | lcr = serial_read_reg(uart, UART_LCR); |
233 | serial_write_reg(p, UART_LCR, 0xBF); | 221 | serial_write_reg(uart, UART_LCR, 0xBF); |
234 | uart->dll = serial_read_reg(p, UART_DLL); | 222 | uart->dll = serial_read_reg(uart, UART_DLL); |
235 | uart->dlh = serial_read_reg(p, UART_DLM); | 223 | uart->dlh = serial_read_reg(uart, UART_DLM); |
236 | serial_write_reg(p, UART_LCR, lcr); | 224 | serial_write_reg(uart, UART_LCR, lcr); |
237 | uart->ier = serial_read_reg(p, UART_IER); | 225 | uart->ier = serial_read_reg(uart, UART_IER); |
238 | uart->sysc = serial_read_reg(p, UART_OMAP_SYSC); | 226 | uart->sysc = serial_read_reg(uart, UART_OMAP_SYSC); |
239 | uart->scr = serial_read_reg(p, UART_OMAP_SCR); | 227 | uart->scr = serial_read_reg(uart, UART_OMAP_SCR); |
240 | uart->wer = serial_read_reg(p, UART_OMAP_WER); | 228 | uart->wer = serial_read_reg(uart, UART_OMAP_WER); |
241 | serial_write_reg(p, UART_LCR, 0x80); | 229 | serial_write_reg(uart, UART_LCR, 0x80); |
242 | uart->mcr = serial_read_reg(p, UART_MCR); | 230 | uart->mcr = serial_read_reg(uart, UART_MCR); |
243 | serial_write_reg(p, UART_LCR, lcr); | 231 | serial_write_reg(uart, UART_LCR, lcr); |
244 | 232 | ||
245 | uart->context_valid = 1; | 233 | uart->context_valid = 1; |
246 | } | 234 | } |
@@ -248,7 +236,6 @@ static void omap_uart_save_context(struct omap_uart_state *uart) | |||
248 | static void omap_uart_restore_context(struct omap_uart_state *uart) | 236 | static void omap_uart_restore_context(struct omap_uart_state *uart) |
249 | { | 237 | { |
250 | u16 efr = 0; | 238 | u16 efr = 0; |
251 | struct plat_serial8250_port *p = uart->p; | ||
252 | 239 | ||
253 | if (!enable_off_mode) | 240 | if (!enable_off_mode) |
254 | return; | 241 | return; |
@@ -261,29 +248,30 @@ static void omap_uart_restore_context(struct omap_uart_state *uart) | |||
261 | if (uart->errata & UART_ERRATA_i202_MDR1_ACCESS) | 248 | if (uart->errata & UART_ERRATA_i202_MDR1_ACCESS) |
262 | omap_uart_mdr1_errataset(uart, 0x07, 0xA0); | 249 | omap_uart_mdr1_errataset(uart, 0x07, 0xA0); |
263 | else | 250 | else |
264 | serial_write_reg(p, UART_OMAP_MDR1, 0x7); | 251 | serial_write_reg(uart, UART_OMAP_MDR1, 0x7); |
265 | serial_write_reg(p, UART_LCR, 0xBF); /* Config B mode */ | 252 | serial_write_reg(uart, UART_LCR, 0xBF); /* Config B mode */ |
266 | efr = serial_read_reg(p, UART_EFR); | 253 | efr = serial_read_reg(uart, UART_EFR); |
267 | serial_write_reg(p, UART_EFR, UART_EFR_ECB); | 254 | serial_write_reg(uart, UART_EFR, UART_EFR_ECB); |
268 | serial_write_reg(p, UART_LCR, 0x0); /* Operational mode */ | 255 | serial_write_reg(uart, UART_LCR, 0x0); /* Operational mode */ |
269 | serial_write_reg(p, UART_IER, 0x0); | 256 | serial_write_reg(uart, UART_IER, 0x0); |
270 | serial_write_reg(p, UART_LCR, 0xBF); /* Config B mode */ | 257 | serial_write_reg(uart, UART_LCR, 0xBF); /* Config B mode */ |
271 | serial_write_reg(p, UART_DLL, uart->dll); | 258 | serial_write_reg(uart, UART_DLL, uart->dll); |
272 | serial_write_reg(p, UART_DLM, uart->dlh); | 259 | serial_write_reg(uart, UART_DLM, uart->dlh); |
273 | serial_write_reg(p, UART_LCR, 0x0); /* Operational mode */ | 260 | serial_write_reg(uart, UART_LCR, 0x0); /* Operational mode */ |
274 | serial_write_reg(p, UART_IER, uart->ier); | 261 | serial_write_reg(uart, UART_IER, uart->ier); |
275 | serial_write_reg(p, UART_LCR, 0x80); | 262 | serial_write_reg(uart, UART_LCR, 0x80); |
276 | serial_write_reg(p, UART_MCR, uart->mcr); | 263 | serial_write_reg(uart, UART_MCR, uart->mcr); |
277 | serial_write_reg(p, UART_LCR, 0xBF); /* Config B mode */ | 264 | serial_write_reg(uart, UART_LCR, 0xBF); /* Config B mode */ |
278 | serial_write_reg(p, UART_EFR, efr); | 265 | serial_write_reg(uart, UART_EFR, efr); |
279 | serial_write_reg(p, UART_LCR, UART_LCR_WLEN8); | 266 | serial_write_reg(uart, UART_LCR, UART_LCR_WLEN8); |
280 | serial_write_reg(p, UART_OMAP_SCR, uart->scr); | 267 | serial_write_reg(uart, UART_OMAP_SCR, uart->scr); |
281 | serial_write_reg(p, UART_OMAP_WER, uart->wer); | 268 | serial_write_reg(uart, UART_OMAP_WER, uart->wer); |
282 | serial_write_reg(p, UART_OMAP_SYSC, uart->sysc); | 269 | serial_write_reg(uart, UART_OMAP_SYSC, uart->sysc); |
283 | if (uart->errata & UART_ERRATA_i202_MDR1_ACCESS) | 270 | if (uart->errata & UART_ERRATA_i202_MDR1_ACCESS) |
284 | omap_uart_mdr1_errataset(uart, 0x00, 0xA1); | 271 | omap_uart_mdr1_errataset(uart, 0x00, 0xA1); |
285 | else | 272 | else |
286 | serial_write_reg(p, UART_OMAP_MDR1, 0x00); /* UART 16x mode */ | 273 | /* UART 16x mode */ |
274 | serial_write_reg(uart, UART_OMAP_MDR1, 0x00); | ||
287 | } | 275 | } |
288 | #else | 276 | #else |
289 | static inline void omap_uart_save_context(struct omap_uart_state *uart) {} | 277 | static inline void omap_uart_save_context(struct omap_uart_state *uart) {} |
@@ -295,8 +283,7 @@ static inline void omap_uart_enable_clocks(struct omap_uart_state *uart) | |||
295 | if (uart->clocked) | 283 | if (uart->clocked) |
296 | return; | 284 | return; |
297 | 285 | ||
298 | clk_enable(uart->ick); | 286 | omap_device_enable(uart->pdev); |
299 | clk_enable(uart->fck); | ||
300 | uart->clocked = 1; | 287 | uart->clocked = 1; |
301 | omap_uart_restore_context(uart); | 288 | omap_uart_restore_context(uart); |
302 | } | 289 | } |
@@ -310,8 +297,7 @@ static inline void omap_uart_disable_clocks(struct omap_uart_state *uart) | |||
310 | 297 | ||
311 | omap_uart_save_context(uart); | 298 | omap_uart_save_context(uart); |
312 | uart->clocked = 0; | 299 | uart->clocked = 0; |
313 | clk_disable(uart->ick); | 300 | omap_device_idle(uart->pdev); |
314 | clk_disable(uart->fck); | ||
315 | } | 301 | } |
316 | 302 | ||
317 | static void omap_uart_enable_wakeup(struct omap_uart_state *uart) | 303 | static void omap_uart_enable_wakeup(struct omap_uart_state *uart) |
@@ -349,18 +335,24 @@ static void omap_uart_disable_wakeup(struct omap_uart_state *uart) | |||
349 | } | 335 | } |
350 | 336 | ||
351 | static void omap_uart_smart_idle_enable(struct omap_uart_state *uart, | 337 | static void omap_uart_smart_idle_enable(struct omap_uart_state *uart, |
352 | int enable) | 338 | int enable) |
353 | { | 339 | { |
354 | struct plat_serial8250_port *p = uart->p; | 340 | u8 idlemode; |
355 | u16 sysc; | ||
356 | 341 | ||
357 | sysc = serial_read_reg(p, UART_OMAP_SYSC) & 0x7; | 342 | if (enable) { |
358 | if (enable) | 343 | /** |
359 | sysc |= 0x2 << 3; | 344 | * Errata 2.15: [UART]:Cannot Acknowledge Idle Requests |
360 | else | 345 | * in Smartidle Mode When Configured for DMA Operations. |
361 | sysc |= 0x1 << 3; | 346 | */ |
347 | if (uart->dma_enabled) | ||
348 | idlemode = HWMOD_IDLEMODE_FORCE; | ||
349 | else | ||
350 | idlemode = HWMOD_IDLEMODE_SMART; | ||
351 | } else { | ||
352 | idlemode = HWMOD_IDLEMODE_NO; | ||
353 | } | ||
362 | 354 | ||
363 | serial_write_reg(p, UART_OMAP_SYSC, sysc); | 355 | omap_hwmod_set_slave_idlemode(uart->oh, idlemode); |
364 | } | 356 | } |
365 | 357 | ||
366 | static void omap_uart_block_sleep(struct omap_uart_state *uart) | 358 | static void omap_uart_block_sleep(struct omap_uart_state *uart) |
@@ -377,7 +369,7 @@ static void omap_uart_block_sleep(struct omap_uart_state *uart) | |||
377 | 369 | ||
378 | static void omap_uart_allow_sleep(struct omap_uart_state *uart) | 370 | static void omap_uart_allow_sleep(struct omap_uart_state *uart) |
379 | { | 371 | { |
380 | if (device_may_wakeup(&uart->pdev.dev)) | 372 | if (device_may_wakeup(&uart->pdev->dev)) |
381 | omap_uart_enable_wakeup(uart); | 373 | omap_uart_enable_wakeup(uart); |
382 | else | 374 | else |
383 | omap_uart_disable_wakeup(uart); | 375 | omap_uart_disable_wakeup(uart); |
@@ -472,6 +464,7 @@ int omap_uart_can_sleep(void) | |||
472 | * UART will not idle or sleep for its timeout period. | 464 | * UART will not idle or sleep for its timeout period. |
473 | * | 465 | * |
474 | **/ | 466 | **/ |
467 | /* static int first_interrupt; */ | ||
475 | static irqreturn_t omap_uart_interrupt(int irq, void *dev_id) | 468 | static irqreturn_t omap_uart_interrupt(int irq, void *dev_id) |
476 | { | 469 | { |
477 | struct omap_uart_state *uart = dev_id; | 470 | struct omap_uart_state *uart = dev_id; |
@@ -483,7 +476,6 @@ static irqreturn_t omap_uart_interrupt(int irq, void *dev_id) | |||
483 | 476 | ||
484 | static void omap_uart_idle_init(struct omap_uart_state *uart) | 477 | static void omap_uart_idle_init(struct omap_uart_state *uart) |
485 | { | 478 | { |
486 | struct plat_serial8250_port *p = uart->p; | ||
487 | int ret; | 479 | int ret; |
488 | 480 | ||
489 | uart->can_sleep = 0; | 481 | uart->can_sleep = 0; |
@@ -495,7 +487,7 @@ static void omap_uart_idle_init(struct omap_uart_state *uart) | |||
495 | omap_uart_smart_idle_enable(uart, 0); | 487 | omap_uart_smart_idle_enable(uart, 0); |
496 | 488 | ||
497 | if (cpu_is_omap34xx()) { | 489 | if (cpu_is_omap34xx()) { |
498 | u32 mod = (uart->num == 2) ? OMAP3430_PER_MOD : CORE_MOD; | 490 | u32 mod = (uart->num > 1) ? OMAP3430_PER_MOD : CORE_MOD; |
499 | u32 wk_mask = 0; | 491 | u32 wk_mask = 0; |
500 | u32 padconf = 0; | 492 | u32 padconf = 0; |
501 | 493 | ||
@@ -514,6 +506,10 @@ static void omap_uart_idle_init(struct omap_uart_state *uart) | |||
514 | wk_mask = OMAP3430_ST_UART3_MASK; | 506 | wk_mask = OMAP3430_ST_UART3_MASK; |
515 | padconf = 0x19e; | 507 | padconf = 0x19e; |
516 | break; | 508 | break; |
509 | case 3: | ||
510 | wk_mask = OMAP3630_ST_UART4_MASK; | ||
511 | padconf = 0x0d2; | ||
512 | break; | ||
517 | } | 513 | } |
518 | uart->wk_mask = wk_mask; | 514 | uart->wk_mask = wk_mask; |
519 | uart->padconf = padconf; | 515 | uart->padconf = padconf; |
@@ -546,9 +542,9 @@ static void omap_uart_idle_init(struct omap_uart_state *uart) | |||
546 | uart->padconf = 0; | 542 | uart->padconf = 0; |
547 | } | 543 | } |
548 | 544 | ||
549 | p->irqflags |= IRQF_SHARED; | 545 | uart->irqflags |= IRQF_SHARED; |
550 | ret = request_irq(p->irq, omap_uart_interrupt, IRQF_SHARED, | 546 | ret = request_threaded_irq(uart->irq, NULL, omap_uart_interrupt, |
551 | "serial idle", (void *)uart); | 547 | IRQF_SHARED, "serial idle", (void *)uart); |
552 | WARN_ON(ret); | 548 | WARN_ON(ret); |
553 | } | 549 | } |
554 | 550 | ||
@@ -558,11 +554,17 @@ void omap_uart_enable_irqs(int enable) | |||
558 | struct omap_uart_state *uart; | 554 | struct omap_uart_state *uart; |
559 | 555 | ||
560 | list_for_each_entry(uart, &uart_list, node) { | 556 | list_for_each_entry(uart, &uart_list, node) { |
561 | if (enable) | 557 | if (enable) { |
562 | ret = request_irq(uart->p->irq, omap_uart_interrupt, | 558 | pm_runtime_put_sync(&uart->pdev->dev); |
563 | IRQF_SHARED, "serial idle", (void *)uart); | 559 | ret = request_threaded_irq(uart->irq, NULL, |
564 | else | 560 | omap_uart_interrupt, |
565 | free_irq(uart->p->irq, (void *)uart); | 561 | IRQF_SHARED, |
562 | "serial idle", | ||
563 | (void *)uart); | ||
564 | } else { | ||
565 | pm_runtime_get_noresume(&uart->pdev->dev); | ||
566 | free_irq(uart->irq, (void *)uart); | ||
567 | } | ||
566 | } | 568 | } |
567 | } | 569 | } |
568 | 570 | ||
@@ -570,10 +572,9 @@ static ssize_t sleep_timeout_show(struct device *dev, | |||
570 | struct device_attribute *attr, | 572 | struct device_attribute *attr, |
571 | char *buf) | 573 | char *buf) |
572 | { | 574 | { |
573 | struct platform_device *pdev = container_of(dev, | 575 | struct platform_device *pdev = to_platform_device(dev); |
574 | struct platform_device, dev); | 576 | struct omap_device *odev = to_omap_device(pdev); |
575 | struct omap_uart_state *uart = container_of(pdev, | 577 | struct omap_uart_state *uart = odev->hwmods[0]->dev_attr; |
576 | struct omap_uart_state, pdev); | ||
577 | 578 | ||
578 | return sprintf(buf, "%u\n", uart->timeout / HZ); | 579 | return sprintf(buf, "%u\n", uart->timeout / HZ); |
579 | } | 580 | } |
@@ -582,10 +583,9 @@ static ssize_t sleep_timeout_store(struct device *dev, | |||
582 | struct device_attribute *attr, | 583 | struct device_attribute *attr, |
583 | const char *buf, size_t n) | 584 | const char *buf, size_t n) |
584 | { | 585 | { |
585 | struct platform_device *pdev = container_of(dev, | 586 | struct platform_device *pdev = to_platform_device(dev); |
586 | struct platform_device, dev); | 587 | struct omap_device *odev = to_omap_device(pdev); |
587 | struct omap_uart_state *uart = container_of(pdev, | 588 | struct omap_uart_state *uart = odev->hwmods[0]->dev_attr; |
588 | struct omap_uart_state, pdev); | ||
589 | unsigned int value; | 589 | unsigned int value; |
590 | 590 | ||
591 | if (sscanf(buf, "%u", &value) != 1) { | 591 | if (sscanf(buf, "%u", &value) != 1) { |
@@ -608,48 +608,11 @@ static DEVICE_ATTR(sleep_timeout, 0644, sleep_timeout_show, | |||
608 | #define DEV_CREATE_FILE(dev, attr) WARN_ON(device_create_file(dev, attr)) | 608 | #define DEV_CREATE_FILE(dev, attr) WARN_ON(device_create_file(dev, attr)) |
609 | #else | 609 | #else |
610 | static inline void omap_uart_idle_init(struct omap_uart_state *uart) {} | 610 | static inline void omap_uart_idle_init(struct omap_uart_state *uart) {} |
611 | static void omap_uart_block_sleep(struct omap_uart_state *uart) {} | ||
611 | #define DEV_CREATE_FILE(dev, attr) | 612 | #define DEV_CREATE_FILE(dev, attr) |
612 | #endif /* CONFIG_PM */ | 613 | #endif /* CONFIG_PM */ |
613 | 614 | ||
614 | static struct omap_uart_state omap_uart[] = { | 615 | #ifndef CONFIG_SERIAL_OMAP |
615 | { | ||
616 | .pdev = { | ||
617 | .name = "serial8250", | ||
618 | .id = PLAT8250_DEV_PLATFORM, | ||
619 | .dev = { | ||
620 | .platform_data = serial_platform_data0, | ||
621 | }, | ||
622 | }, | ||
623 | }, { | ||
624 | .pdev = { | ||
625 | .name = "serial8250", | ||
626 | .id = PLAT8250_DEV_PLATFORM1, | ||
627 | .dev = { | ||
628 | .platform_data = serial_platform_data1, | ||
629 | }, | ||
630 | }, | ||
631 | }, { | ||
632 | .pdev = { | ||
633 | .name = "serial8250", | ||
634 | .id = PLAT8250_DEV_PLATFORM2, | ||
635 | .dev = { | ||
636 | .platform_data = serial_platform_data2, | ||
637 | }, | ||
638 | }, | ||
639 | }, | ||
640 | #if defined(CONFIG_ARCH_OMAP3) || defined(CONFIG_ARCH_OMAP4) | ||
641 | { | ||
642 | .pdev = { | ||
643 | .name = "serial8250", | ||
644 | .id = 3, | ||
645 | .dev = { | ||
646 | .platform_data = serial_platform_data3, | ||
647 | }, | ||
648 | }, | ||
649 | }, | ||
650 | #endif | ||
651 | }; | ||
652 | |||
653 | /* | 616 | /* |
654 | * Override the default 8250 read handler: mem_serial_in() | 617 | * Override the default 8250 read handler: mem_serial_in() |
655 | * Empty RX fifo read causes an abort on omap3630 and omap4 | 618 | * Empty RX fifo read causes an abort on omap3630 and omap4 |
@@ -682,71 +645,44 @@ static void serial_out_override(struct uart_port *up, int offset, int value) | |||
682 | } | 645 | } |
683 | __serial_write_reg(up, offset, value); | 646 | __serial_write_reg(up, offset, value); |
684 | } | 647 | } |
648 | #endif | ||
649 | |||
685 | void __init omap_serial_early_init(void) | 650 | void __init omap_serial_early_init(void) |
686 | { | 651 | { |
687 | int i, nr_ports; | 652 | int i = 0; |
688 | char name[16]; | ||
689 | 653 | ||
690 | if (!(cpu_is_omap3630() || cpu_is_omap4430())) | 654 | do { |
691 | nr_ports = 3; | 655 | char oh_name[MAX_UART_HWMOD_NAME_LEN]; |
692 | else | 656 | struct omap_hwmod *oh; |
693 | nr_ports = ARRAY_SIZE(omap_uart); | 657 | struct omap_uart_state *uart; |
694 | 658 | ||
695 | /* | 659 | snprintf(oh_name, MAX_UART_HWMOD_NAME_LEN, |
696 | * Make sure the serial ports are muxed on at this point. | 660 | "uart%d", i + 1); |
697 | * You have to mux them off in device drivers later on | 661 | oh = omap_hwmod_lookup(oh_name); |
698 | * if not needed. | 662 | if (!oh) |
699 | */ | 663 | break; |
700 | 664 | ||
701 | for (i = 0; i < nr_ports; i++) { | 665 | uart = kzalloc(sizeof(struct omap_uart_state), GFP_KERNEL); |
702 | struct omap_uart_state *uart = &omap_uart[i]; | 666 | if (WARN_ON(!uart)) |
703 | struct platform_device *pdev = &uart->pdev; | 667 | return; |
704 | struct device *dev = &pdev->dev; | 668 | |
705 | struct plat_serial8250_port *p = dev->platform_data; | 669 | uart->oh = oh; |
670 | uart->num = i++; | ||
671 | list_add_tail(&uart->node, &uart_list); | ||
672 | num_uarts++; | ||
706 | 673 | ||
707 | /* Don't map zero-based physical address */ | ||
708 | if (p->mapbase == 0) { | ||
709 | dev_warn(dev, "no physical address for uart#%d," | ||
710 | " so skipping early_init...\n", i); | ||
711 | continue; | ||
712 | } | ||
713 | /* | 674 | /* |
714 | * Module 4KB + L4 interconnect 4KB | 675 | * NOTE: omap_hwmod_init() has not yet been called, |
715 | * Static mapping, never released | 676 | * so no hwmod functions will work yet. |
716 | */ | 677 | */ |
717 | p->membase = ioremap(p->mapbase, SZ_8K); | ||
718 | if (!p->membase) { | ||
719 | dev_err(dev, "ioremap failed for uart%i\n", i + 1); | ||
720 | continue; | ||
721 | } | ||
722 | |||
723 | sprintf(name, "uart%d_ick", i + 1); | ||
724 | uart->ick = clk_get(NULL, name); | ||
725 | if (IS_ERR(uart->ick)) { | ||
726 | dev_err(dev, "Could not get uart%d_ick\n", i + 1); | ||
727 | uart->ick = NULL; | ||
728 | } | ||
729 | |||
730 | sprintf(name, "uart%d_fck", i+1); | ||
731 | uart->fck = clk_get(NULL, name); | ||
732 | if (IS_ERR(uart->fck)) { | ||
733 | dev_err(dev, "Could not get uart%d_fck\n", i + 1); | ||
734 | uart->fck = NULL; | ||
735 | } | ||
736 | |||
737 | /* FIXME: Remove this once the clkdev is ready */ | ||
738 | if (!cpu_is_omap44xx()) { | ||
739 | if (!uart->ick || !uart->fck) | ||
740 | continue; | ||
741 | } | ||
742 | |||
743 | uart->num = i; | ||
744 | p->private_data = uart; | ||
745 | uart->p = p; | ||
746 | 678 | ||
747 | if (cpu_is_omap44xx()) | 679 | /* |
748 | p->irq += 32; | 680 | * During UART early init, device need to be probed |
749 | } | 681 | * to determine SoC specific init before omap_device |
682 | * is ready. Therefore, don't allow idle here | ||
683 | */ | ||
684 | uart->oh->flags |= HWMOD_INIT_NO_IDLE | HWMOD_INIT_NO_RESET; | ||
685 | } while (1); | ||
750 | } | 686 | } |
751 | 687 | ||
752 | /** | 688 | /** |
@@ -763,53 +699,135 @@ void __init omap_serial_early_init(void) | |||
763 | void __init omap_serial_init_port(int port) | 699 | void __init omap_serial_init_port(int port) |
764 | { | 700 | { |
765 | struct omap_uart_state *uart; | 701 | struct omap_uart_state *uart; |
766 | struct platform_device *pdev; | 702 | struct omap_hwmod *oh; |
767 | struct device *dev; | 703 | struct omap_device *od; |
768 | 704 | void *pdata = NULL; | |
769 | BUG_ON(port < 0); | 705 | u32 pdata_size = 0; |
770 | BUG_ON(port >= ARRAY_SIZE(omap_uart)); | 706 | char *name; |
771 | 707 | #ifndef CONFIG_SERIAL_OMAP | |
772 | uart = &omap_uart[port]; | 708 | struct plat_serial8250_port ports[2] = { |
773 | pdev = &uart->pdev; | 709 | {}, |
774 | dev = &pdev->dev; | 710 | {.flags = 0}, |
711 | }; | ||
712 | struct plat_serial8250_port *p = &ports[0]; | ||
713 | #else | ||
714 | struct omap_uart_port_info omap_up; | ||
715 | #endif | ||
775 | 716 | ||
776 | /* Don't proceed if there's no clocks available */ | 717 | if (WARN_ON(port < 0)) |
777 | if (unlikely(!uart->ick || !uart->fck)) { | 718 | return; |
778 | WARN(1, "%s: can't init uart%d, no clocks available\n", | 719 | if (WARN_ON(port >= num_uarts)) |
779 | kobject_name(&dev->kobj), port); | ||
780 | return; | 720 | return; |
781 | } | ||
782 | |||
783 | omap_uart_enable_clocks(uart); | ||
784 | |||
785 | omap_uart_reset(uart); | ||
786 | omap_uart_idle_init(uart); | ||
787 | 721 | ||
788 | list_add_tail(&uart->node, &uart_list); | 722 | list_for_each_entry(uart, &uart_list, node) |
723 | if (port == uart->num) | ||
724 | break; | ||
789 | 725 | ||
790 | if (WARN_ON(platform_device_register(pdev))) | 726 | oh = uart->oh; |
791 | return; | 727 | uart->dma_enabled = 0; |
728 | #ifndef CONFIG_SERIAL_OMAP | ||
729 | name = "serial8250"; | ||
792 | 730 | ||
793 | if ((cpu_is_omap34xx() && uart->padconf) || | 731 | /* |
794 | (uart->wk_en && uart->wk_mask)) { | 732 | * !! 8250 driver does not use standard IORESOURCE* It |
795 | device_init_wakeup(dev, true); | 733 | * has it's own custom pdata that can be taken from |
796 | DEV_CREATE_FILE(dev, &dev_attr_sleep_timeout); | 734 | * the hwmod resource data. But, this needs to be |
797 | } | 735 | * done after the build. |
736 | * | ||
737 | * ?? does it have to be done before the register ?? | ||
738 | * YES, because platform_device_data_add() copies | ||
739 | * pdata, it does not use a pointer. | ||
740 | */ | ||
741 | p->flags = UPF_BOOT_AUTOCONF; | ||
742 | p->iotype = UPIO_MEM; | ||
743 | p->regshift = 2; | ||
744 | p->uartclk = OMAP24XX_BASE_BAUD * 16; | ||
745 | p->irq = oh->mpu_irqs[0].irq; | ||
746 | p->mapbase = oh->slaves[0]->addr->pa_start; | ||
747 | p->membase = omap_hwmod_get_mpu_rt_va(oh); | ||
748 | p->irqflags = IRQF_SHARED; | ||
749 | p->private_data = uart; | ||
798 | 750 | ||
799 | /* | 751 | /* |
800 | * omap44xx: Never read empty UART fifo | 752 | * omap44xx: Never read empty UART fifo |
801 | * omap3xxx: Never read empty UART fifo on UARTs | 753 | * omap3xxx: Never read empty UART fifo on UARTs |
802 | * with IP rev >=0x52 | 754 | * with IP rev >=0x52 |
803 | */ | 755 | */ |
756 | uart->regshift = p->regshift; | ||
757 | uart->membase = p->membase; | ||
804 | if (cpu_is_omap44xx()) | 758 | if (cpu_is_omap44xx()) |
805 | uart->errata |= UART_ERRATA_FIFO_FULL_ABORT; | 759 | uart->errata |= UART_ERRATA_FIFO_FULL_ABORT; |
806 | else if ((serial_read_reg(uart->p, UART_OMAP_MVER) & 0xFF) | 760 | else if ((serial_read_reg(uart, UART_OMAP_MVER) & 0xFF) |
807 | >= UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV) | 761 | >= UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV) |
808 | uart->errata |= UART_ERRATA_FIFO_FULL_ABORT; | 762 | uart->errata |= UART_ERRATA_FIFO_FULL_ABORT; |
809 | 763 | ||
810 | if (uart->errata & UART_ERRATA_FIFO_FULL_ABORT) { | 764 | if (uart->errata & UART_ERRATA_FIFO_FULL_ABORT) { |
811 | uart->p->serial_in = serial_in_override; | 765 | p->serial_in = serial_in_override; |
812 | uart->p->serial_out = serial_out_override; | 766 | p->serial_out = serial_out_override; |
767 | } | ||
768 | |||
769 | pdata = &ports[0]; | ||
770 | pdata_size = 2 * sizeof(struct plat_serial8250_port); | ||
771 | #else | ||
772 | |||
773 | name = DRIVER_NAME; | ||
774 | |||
775 | omap_up.dma_enabled = uart->dma_enabled; | ||
776 | omap_up.uartclk = OMAP24XX_BASE_BAUD * 16; | ||
777 | omap_up.mapbase = oh->slaves[0]->addr->pa_start; | ||
778 | omap_up.membase = omap_hwmod_get_mpu_rt_va(oh); | ||
779 | omap_up.irqflags = IRQF_SHARED; | ||
780 | omap_up.flags = UPF_BOOT_AUTOCONF | UPF_SHARE_IRQ; | ||
781 | |||
782 | pdata = &omap_up; | ||
783 | pdata_size = sizeof(struct omap_uart_port_info); | ||
784 | #endif | ||
785 | |||
786 | if (WARN_ON(!oh)) | ||
787 | return; | ||
788 | |||
789 | od = omap_device_build(name, uart->num, oh, pdata, pdata_size, | ||
790 | omap_uart_latency, | ||
791 | ARRAY_SIZE(omap_uart_latency), false); | ||
792 | WARN(IS_ERR(od), "Could not build omap_device for %s: %s.\n", | ||
793 | name, oh->name); | ||
794 | |||
795 | uart->irq = oh->mpu_irqs[0].irq; | ||
796 | uart->regshift = 2; | ||
797 | uart->mapbase = oh->slaves[0]->addr->pa_start; | ||
798 | uart->membase = omap_hwmod_get_mpu_rt_va(oh); | ||
799 | uart->pdev = &od->pdev; | ||
800 | |||
801 | oh->dev_attr = uart; | ||
802 | |||
803 | /* | ||
804 | * Because of early UART probing, UART did not get idled | ||
805 | * on init. Now that omap_device is ready, ensure full idle | ||
806 | * before doing omap_device_enable(). | ||
807 | */ | ||
808 | omap_hwmod_idle(uart->oh); | ||
809 | |||
810 | omap_device_enable(uart->pdev); | ||
811 | omap_uart_idle_init(uart); | ||
812 | omap_uart_reset(uart); | ||
813 | omap_hwmod_enable_wakeup(uart->oh); | ||
814 | omap_device_idle(uart->pdev); | ||
815 | |||
816 | /* | ||
817 | * Need to block sleep long enough for interrupt driven | ||
818 | * driver to start. Console driver is in polling mode | ||
819 | * so device needs to be kept enabled while polling driver | ||
820 | * is in use. | ||
821 | */ | ||
822 | if (uart->timeout) | ||
823 | uart->timeout = (30 * HZ); | ||
824 | omap_uart_block_sleep(uart); | ||
825 | uart->timeout = DEFAULT_TIMEOUT; | ||
826 | |||
827 | if ((cpu_is_omap34xx() && uart->padconf) || | ||
828 | (uart->wk_en && uart->wk_mask)) { | ||
829 | device_init_wakeup(&od->pdev.dev, true); | ||
830 | DEV_CREATE_FILE(&od->pdev.dev, &dev_attr_sleep_timeout); | ||
813 | } | 831 | } |
814 | 832 | ||
815 | /* Enable the MDR1 errata for OMAP3 */ | 833 | /* Enable the MDR1 errata for OMAP3 */ |
@@ -826,13 +844,8 @@ void __init omap_serial_init_port(int port) | |||
826 | */ | 844 | */ |
827 | void __init omap_serial_init(void) | 845 | void __init omap_serial_init(void) |
828 | { | 846 | { |
829 | int i, nr_ports; | 847 | struct omap_uart_state *uart; |
830 | |||
831 | if (!(cpu_is_omap3630() || cpu_is_omap4430())) | ||
832 | nr_ports = 3; | ||
833 | else | ||
834 | nr_ports = ARRAY_SIZE(omap_uart); | ||
835 | 848 | ||
836 | for (i = 0; i < nr_ports; i++) | 849 | list_for_each_entry(uart, &uart_list, node) |
837 | omap_serial_init_port(i); | 850 | omap_serial_init_port(uart->num); |
838 | } | 851 | } |