diff options
author | Kevin Hilman <khilman@deeprootsystems.com> | 2010-09-27 10:49:30 -0400 |
---|---|---|
committer | Kevin Hilman <khilman@deeprootsystems.com> | 2010-09-29 15:42:42 -0400 |
commit | 046465b76a41a32a8d56e691b167fb9ba7729970 (patch) | |
tree | 51f2e7c0ad0747235cc63e05d42c7b7a82c1748f /arch/arm | |
parent | db12ba53fe8b2d79c06bfe00589b3e98fd50cb4c (diff) |
OMAP2/3: UART: add omap_hwmod data for UARTs 1-4
This patch adds omap_hwmod data for UARTs on OMAP2 and OMAP3
platforms.
UART4 support for 3630 and OMAP2 hwmod data added by Govindraj R.
Signed-off-by: Govindraj.R <govindraj.raja@ti.com>
Signed-off-by: Kevin Hilman <khilman@deeprootsystems.com>
Diffstat (limited to 'arch/arm')
-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/prcm-common.h | 3 | ||||
-rw-r--r-- | arch/arm/plat-omap/include/plat/dma.h | 2 | ||||
-rw-r--r-- | arch/arm/plat-omap/include/plat/irqs.h | 2 |
6 files changed, 644 insertions, 2 deletions
diff --git a/arch/arm/mach-omap2/omap_hwmod_2420_data.c b/arch/arm/mach-omap2/omap_hwmod_2420_data.c index 3cc768e8bc04..ba145f7d5896 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 | ||
@@ -71,6 +72,9 @@ static struct omap_hwmod omap2420_l3_main_hwmod = { | |||
71 | }; | 72 | }; |
72 | 73 | ||
73 | static struct omap_hwmod omap2420_l4_wkup_hwmod; | 74 | static struct omap_hwmod omap2420_l4_wkup_hwmod; |
75 | static struct omap_hwmod omap2420_uart1_hwmod; | ||
76 | static struct omap_hwmod omap2420_uart2_hwmod; | ||
77 | static struct omap_hwmod omap2420_uart3_hwmod; | ||
74 | 78 | ||
75 | /* L4_CORE -> L4_WKUP interface */ | 79 | /* L4_CORE -> L4_WKUP interface */ |
76 | static struct omap_hwmod_ocp_if omap2420_l4_core__l4_wkup = { | 80 | static struct omap_hwmod_ocp_if omap2420_l4_core__l4_wkup = { |
@@ -79,6 +83,60 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__l4_wkup = { | |||
79 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 83 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
80 | }; | 84 | }; |
81 | 85 | ||
86 | /* L4 CORE -> UART1 interface */ | ||
87 | static struct omap_hwmod_addr_space omap2420_uart1_addr_space[] = { | ||
88 | { | ||
89 | .pa_start = OMAP2_UART1_BASE, | ||
90 | .pa_end = OMAP2_UART1_BASE + SZ_8K - 1, | ||
91 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
92 | }, | ||
93 | }; | ||
94 | |||
95 | static struct omap_hwmod_ocp_if omap2_l4_core__uart1 = { | ||
96 | .master = &omap2420_l4_core_hwmod, | ||
97 | .slave = &omap2420_uart1_hwmod, | ||
98 | .clk = "uart1_ick", | ||
99 | .addr = omap2420_uart1_addr_space, | ||
100 | .addr_cnt = ARRAY_SIZE(omap2420_uart1_addr_space), | ||
101 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
102 | }; | ||
103 | |||
104 | /* L4 CORE -> UART2 interface */ | ||
105 | static struct omap_hwmod_addr_space omap2420_uart2_addr_space[] = { | ||
106 | { | ||
107 | .pa_start = OMAP2_UART2_BASE, | ||
108 | .pa_end = OMAP2_UART2_BASE + SZ_1K - 1, | ||
109 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
110 | }, | ||
111 | }; | ||
112 | |||
113 | static struct omap_hwmod_ocp_if omap2_l4_core__uart2 = { | ||
114 | .master = &omap2420_l4_core_hwmod, | ||
115 | .slave = &omap2420_uart2_hwmod, | ||
116 | .clk = "uart2_ick", | ||
117 | .addr = omap2420_uart2_addr_space, | ||
118 | .addr_cnt = ARRAY_SIZE(omap2420_uart2_addr_space), | ||
119 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
120 | }; | ||
121 | |||
122 | /* L4 PER -> UART3 interface */ | ||
123 | static struct omap_hwmod_addr_space omap2420_uart3_addr_space[] = { | ||
124 | { | ||
125 | .pa_start = OMAP2_UART3_BASE, | ||
126 | .pa_end = OMAP2_UART3_BASE + SZ_1K - 1, | ||
127 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
128 | }, | ||
129 | }; | ||
130 | |||
131 | static struct omap_hwmod_ocp_if omap2_l4_core__uart3 = { | ||
132 | .master = &omap2420_l4_core_hwmod, | ||
133 | .slave = &omap2420_uart3_hwmod, | ||
134 | .clk = "uart3_ick", | ||
135 | .addr = omap2420_uart3_addr_space, | ||
136 | .addr_cnt = ARRAY_SIZE(omap2420_uart3_addr_space), | ||
137 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
138 | }; | ||
139 | |||
82 | /* Slave interfaces on the L4_CORE interconnect */ | 140 | /* Slave interfaces on the L4_CORE interconnect */ |
83 | static struct omap_hwmod_ocp_if *omap2420_l4_core_slaves[] = { | 141 | static struct omap_hwmod_ocp_if *omap2420_l4_core_slaves[] = { |
84 | &omap2420_l3_main__l4_core, | 142 | &omap2420_l3_main__l4_core, |
@@ -87,6 +145,9 @@ static struct omap_hwmod_ocp_if *omap2420_l4_core_slaves[] = { | |||
87 | /* Master interfaces on the L4_CORE interconnect */ | 145 | /* Master interfaces on the L4_CORE interconnect */ |
88 | static struct omap_hwmod_ocp_if *omap2420_l4_core_masters[] = { | 146 | static struct omap_hwmod_ocp_if *omap2420_l4_core_masters[] = { |
89 | &omap2420_l4_core__l4_wkup, | 147 | &omap2420_l4_core__l4_wkup, |
148 | &omap2_l4_core__uart1, | ||
149 | &omap2_l4_core__uart2, | ||
150 | &omap2_l4_core__uart3, | ||
90 | }; | 151 | }; |
91 | 152 | ||
92 | /* L4 CORE */ | 153 | /* L4 CORE */ |
@@ -165,12 +226,144 @@ static struct omap_hwmod omap2420_iva_hwmod = { | |||
165 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420) | 226 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420) |
166 | }; | 227 | }; |
167 | 228 | ||
229 | /* UART */ | ||
230 | |||
231 | static struct omap_hwmod_class_sysconfig uart_sysc = { | ||
232 | .rev_offs = 0x50, | ||
233 | .sysc_offs = 0x54, | ||
234 | .syss_offs = 0x58, | ||
235 | .sysc_flags = (SYSC_HAS_SIDLEMODE | | ||
236 | SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET | | ||
237 | SYSC_HAS_AUTOIDLE), | ||
238 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART), | ||
239 | .sysc_fields = &omap_hwmod_sysc_type1, | ||
240 | }; | ||
241 | |||
242 | static struct omap_hwmod_class uart_class = { | ||
243 | .name = "uart", | ||
244 | .sysc = &uart_sysc, | ||
245 | }; | ||
246 | |||
247 | /* UART1 */ | ||
248 | |||
249 | static struct omap_hwmod_irq_info uart1_mpu_irqs[] = { | ||
250 | { .irq = INT_24XX_UART1_IRQ, }, | ||
251 | }; | ||
252 | |||
253 | static struct omap_hwmod_dma_info uart1_sdma_reqs[] = { | ||
254 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, }, | ||
255 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, }, | ||
256 | }; | ||
257 | |||
258 | static struct omap_hwmod_ocp_if *omap2420_uart1_slaves[] = { | ||
259 | &omap2_l4_core__uart1, | ||
260 | }; | ||
261 | |||
262 | static struct omap_hwmod omap2420_uart1_hwmod = { | ||
263 | .name = "uart1", | ||
264 | .mpu_irqs = uart1_mpu_irqs, | ||
265 | .mpu_irqs_cnt = ARRAY_SIZE(uart1_mpu_irqs), | ||
266 | .sdma_reqs = uart1_sdma_reqs, | ||
267 | .sdma_reqs_cnt = ARRAY_SIZE(uart1_sdma_reqs), | ||
268 | .main_clk = "uart1_fck", | ||
269 | .prcm = { | ||
270 | .omap2 = { | ||
271 | .module_offs = CORE_MOD, | ||
272 | .prcm_reg_id = 1, | ||
273 | .module_bit = OMAP24XX_EN_UART1_SHIFT, | ||
274 | .idlest_reg_id = 1, | ||
275 | .idlest_idle_bit = OMAP24XX_EN_UART1_SHIFT, | ||
276 | }, | ||
277 | }, | ||
278 | .slaves = omap2420_uart1_slaves, | ||
279 | .slaves_cnt = ARRAY_SIZE(omap2420_uart1_slaves), | ||
280 | .class = &uart_class, | ||
281 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), | ||
282 | }; | ||
283 | |||
284 | /* UART2 */ | ||
285 | |||
286 | static struct omap_hwmod_irq_info uart2_mpu_irqs[] = { | ||
287 | { .irq = INT_24XX_UART2_IRQ, }, | ||
288 | }; | ||
289 | |||
290 | static struct omap_hwmod_dma_info uart2_sdma_reqs[] = { | ||
291 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, }, | ||
292 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, }, | ||
293 | }; | ||
294 | |||
295 | static struct omap_hwmod_ocp_if *omap2420_uart2_slaves[] = { | ||
296 | &omap2_l4_core__uart2, | ||
297 | }; | ||
298 | |||
299 | static struct omap_hwmod omap2420_uart2_hwmod = { | ||
300 | .name = "uart2", | ||
301 | .mpu_irqs = uart2_mpu_irqs, | ||
302 | .mpu_irqs_cnt = ARRAY_SIZE(uart2_mpu_irqs), | ||
303 | .sdma_reqs = uart2_sdma_reqs, | ||
304 | .sdma_reqs_cnt = ARRAY_SIZE(uart2_sdma_reqs), | ||
305 | .main_clk = "uart2_fck", | ||
306 | .prcm = { | ||
307 | .omap2 = { | ||
308 | .module_offs = CORE_MOD, | ||
309 | .prcm_reg_id = 1, | ||
310 | .module_bit = OMAP24XX_EN_UART2_SHIFT, | ||
311 | .idlest_reg_id = 1, | ||
312 | .idlest_idle_bit = OMAP24XX_EN_UART2_SHIFT, | ||
313 | }, | ||
314 | }, | ||
315 | .slaves = omap2420_uart2_slaves, | ||
316 | .slaves_cnt = ARRAY_SIZE(omap2420_uart2_slaves), | ||
317 | .class = &uart_class, | ||
318 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), | ||
319 | }; | ||
320 | |||
321 | /* UART3 */ | ||
322 | |||
323 | static struct omap_hwmod_irq_info uart3_mpu_irqs[] = { | ||
324 | { .irq = INT_24XX_UART3_IRQ, }, | ||
325 | }; | ||
326 | |||
327 | static struct omap_hwmod_dma_info uart3_sdma_reqs[] = { | ||
328 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, }, | ||
329 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, }, | ||
330 | }; | ||
331 | |||
332 | static struct omap_hwmod_ocp_if *omap2420_uart3_slaves[] = { | ||
333 | &omap2_l4_core__uart3, | ||
334 | }; | ||
335 | |||
336 | static struct omap_hwmod omap2420_uart3_hwmod = { | ||
337 | .name = "uart3", | ||
338 | .mpu_irqs = uart3_mpu_irqs, | ||
339 | .mpu_irqs_cnt = ARRAY_SIZE(uart3_mpu_irqs), | ||
340 | .sdma_reqs = uart3_sdma_reqs, | ||
341 | .sdma_reqs_cnt = ARRAY_SIZE(uart3_sdma_reqs), | ||
342 | .main_clk = "uart3_fck", | ||
343 | .prcm = { | ||
344 | .omap2 = { | ||
345 | .module_offs = CORE_MOD, | ||
346 | .prcm_reg_id = 2, | ||
347 | .module_bit = OMAP24XX_EN_UART3_SHIFT, | ||
348 | .idlest_reg_id = 2, | ||
349 | .idlest_idle_bit = OMAP24XX_EN_UART3_SHIFT, | ||
350 | }, | ||
351 | }, | ||
352 | .slaves = omap2420_uart3_slaves, | ||
353 | .slaves_cnt = ARRAY_SIZE(omap2420_uart3_slaves), | ||
354 | .class = &uart_class, | ||
355 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2420), | ||
356 | }; | ||
357 | |||
168 | static __initdata struct omap_hwmod *omap2420_hwmods[] = { | 358 | static __initdata struct omap_hwmod *omap2420_hwmods[] = { |
169 | &omap2420_l3_main_hwmod, | 359 | &omap2420_l3_main_hwmod, |
170 | &omap2420_l4_core_hwmod, | 360 | &omap2420_l4_core_hwmod, |
171 | &omap2420_l4_wkup_hwmod, | 361 | &omap2420_l4_wkup_hwmod, |
172 | &omap2420_mpu_hwmod, | 362 | &omap2420_mpu_hwmod, |
173 | &omap2420_iva_hwmod, | 363 | &omap2420_iva_hwmod, |
364 | &omap2420_uart1_hwmod, | ||
365 | &omap2420_uart2_hwmod, | ||
366 | &omap2420_uart3_hwmod, | ||
174 | NULL, | 367 | NULL, |
175 | }; | 368 | }; |
176 | 369 | ||
diff --git a/arch/arm/mach-omap2/omap_hwmod_2430_data.c b/arch/arm/mach-omap2/omap_hwmod_2430_data.c index 4526628ed287..d21073d7eb74 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 | ||
@@ -71,6 +72,9 @@ static struct omap_hwmod omap2430_l3_main_hwmod = { | |||
71 | }; | 72 | }; |
72 | 73 | ||
73 | static struct omap_hwmod omap2430_l4_wkup_hwmod; | 74 | static struct omap_hwmod omap2430_l4_wkup_hwmod; |
75 | static struct omap_hwmod omap2430_uart1_hwmod; | ||
76 | static struct omap_hwmod omap2430_uart2_hwmod; | ||
77 | static struct omap_hwmod omap2430_uart3_hwmod; | ||
74 | 78 | ||
75 | /* L4_CORE -> L4_WKUP interface */ | 79 | /* L4_CORE -> L4_WKUP interface */ |
76 | static struct omap_hwmod_ocp_if omap2430_l4_core__l4_wkup = { | 80 | static struct omap_hwmod_ocp_if omap2430_l4_core__l4_wkup = { |
@@ -79,6 +83,60 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__l4_wkup = { | |||
79 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 83 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
80 | }; | 84 | }; |
81 | 85 | ||
86 | /* L4 CORE -> UART1 interface */ | ||
87 | static struct omap_hwmod_addr_space omap2430_uart1_addr_space[] = { | ||
88 | { | ||
89 | .pa_start = OMAP2_UART1_BASE, | ||
90 | .pa_end = OMAP2_UART1_BASE + SZ_8K - 1, | ||
91 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
92 | }, | ||
93 | }; | ||
94 | |||
95 | static struct omap_hwmod_ocp_if omap2_l4_core__uart1 = { | ||
96 | .master = &omap2430_l4_core_hwmod, | ||
97 | .slave = &omap2430_uart1_hwmod, | ||
98 | .clk = "uart1_ick", | ||
99 | .addr = omap2430_uart1_addr_space, | ||
100 | .addr_cnt = ARRAY_SIZE(omap2430_uart1_addr_space), | ||
101 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
102 | }; | ||
103 | |||
104 | /* L4 CORE -> UART2 interface */ | ||
105 | static struct omap_hwmod_addr_space omap2430_uart2_addr_space[] = { | ||
106 | { | ||
107 | .pa_start = OMAP2_UART2_BASE, | ||
108 | .pa_end = OMAP2_UART2_BASE + SZ_1K - 1, | ||
109 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
110 | }, | ||
111 | }; | ||
112 | |||
113 | static struct omap_hwmod_ocp_if omap2_l4_core__uart2 = { | ||
114 | .master = &omap2430_l4_core_hwmod, | ||
115 | .slave = &omap2430_uart2_hwmod, | ||
116 | .clk = "uart2_ick", | ||
117 | .addr = omap2430_uart2_addr_space, | ||
118 | .addr_cnt = ARRAY_SIZE(omap2430_uart2_addr_space), | ||
119 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
120 | }; | ||
121 | |||
122 | /* L4 PER -> UART3 interface */ | ||
123 | static struct omap_hwmod_addr_space omap2430_uart3_addr_space[] = { | ||
124 | { | ||
125 | .pa_start = OMAP2_UART3_BASE, | ||
126 | .pa_end = OMAP2_UART3_BASE + SZ_1K - 1, | ||
127 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
128 | }, | ||
129 | }; | ||
130 | |||
131 | static struct omap_hwmod_ocp_if omap2_l4_core__uart3 = { | ||
132 | .master = &omap2430_l4_core_hwmod, | ||
133 | .slave = &omap2430_uart3_hwmod, | ||
134 | .clk = "uart3_ick", | ||
135 | .addr = omap2430_uart3_addr_space, | ||
136 | .addr_cnt = ARRAY_SIZE(omap2430_uart3_addr_space), | ||
137 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
138 | }; | ||
139 | |||
82 | /* Slave interfaces on the L4_CORE interconnect */ | 140 | /* Slave interfaces on the L4_CORE interconnect */ |
83 | static struct omap_hwmod_ocp_if *omap2430_l4_core_slaves[] = { | 141 | static struct omap_hwmod_ocp_if *omap2430_l4_core_slaves[] = { |
84 | &omap2430_l3_main__l4_core, | 142 | &omap2430_l3_main__l4_core, |
@@ -104,6 +162,9 @@ static struct omap_hwmod omap2430_l4_core_hwmod = { | |||
104 | /* Slave interfaces on the L4_WKUP interconnect */ | 162 | /* Slave interfaces on the L4_WKUP interconnect */ |
105 | static struct omap_hwmod_ocp_if *omap2430_l4_wkup_slaves[] = { | 163 | static struct omap_hwmod_ocp_if *omap2430_l4_wkup_slaves[] = { |
106 | &omap2430_l4_core__l4_wkup, | 164 | &omap2430_l4_core__l4_wkup, |
165 | &omap2_l4_core__uart1, | ||
166 | &omap2_l4_core__uart2, | ||
167 | &omap2_l4_core__uart3, | ||
107 | }; | 168 | }; |
108 | 169 | ||
109 | /* Master interfaces on the L4_WKUP interconnect */ | 170 | /* Master interfaces on the L4_WKUP interconnect */ |
@@ -165,12 +226,144 @@ static struct omap_hwmod omap2430_iva_hwmod = { | |||
165 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430) | 226 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430) |
166 | }; | 227 | }; |
167 | 228 | ||
229 | /* UART */ | ||
230 | |||
231 | static struct omap_hwmod_class_sysconfig uart_sysc = { | ||
232 | .rev_offs = 0x50, | ||
233 | .sysc_offs = 0x54, | ||
234 | .syss_offs = 0x58, | ||
235 | .sysc_flags = (SYSC_HAS_SIDLEMODE | | ||
236 | SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET | | ||
237 | SYSC_HAS_AUTOIDLE), | ||
238 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART), | ||
239 | .sysc_fields = &omap_hwmod_sysc_type1, | ||
240 | }; | ||
241 | |||
242 | static struct omap_hwmod_class uart_class = { | ||
243 | .name = "uart", | ||
244 | .sysc = &uart_sysc, | ||
245 | }; | ||
246 | |||
247 | /* UART1 */ | ||
248 | |||
249 | static struct omap_hwmod_irq_info uart1_mpu_irqs[] = { | ||
250 | { .irq = INT_24XX_UART1_IRQ, }, | ||
251 | }; | ||
252 | |||
253 | static struct omap_hwmod_dma_info uart1_sdma_reqs[] = { | ||
254 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, }, | ||
255 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, }, | ||
256 | }; | ||
257 | |||
258 | static struct omap_hwmod_ocp_if *omap2430_uart1_slaves[] = { | ||
259 | &omap2_l4_core__uart1, | ||
260 | }; | ||
261 | |||
262 | static struct omap_hwmod omap2430_uart1_hwmod = { | ||
263 | .name = "uart1", | ||
264 | .mpu_irqs = uart1_mpu_irqs, | ||
265 | .mpu_irqs_cnt = ARRAY_SIZE(uart1_mpu_irqs), | ||
266 | .sdma_reqs = uart1_sdma_reqs, | ||
267 | .sdma_reqs_cnt = ARRAY_SIZE(uart1_sdma_reqs), | ||
268 | .main_clk = "uart1_fck", | ||
269 | .prcm = { | ||
270 | .omap2 = { | ||
271 | .module_offs = CORE_MOD, | ||
272 | .prcm_reg_id = 1, | ||
273 | .module_bit = OMAP24XX_EN_UART1_SHIFT, | ||
274 | .idlest_reg_id = 1, | ||
275 | .idlest_idle_bit = OMAP24XX_EN_UART1_SHIFT, | ||
276 | }, | ||
277 | }, | ||
278 | .slaves = omap2430_uart1_slaves, | ||
279 | .slaves_cnt = ARRAY_SIZE(omap2430_uart1_slaves), | ||
280 | .class = &uart_class, | ||
281 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), | ||
282 | }; | ||
283 | |||
284 | /* UART2 */ | ||
285 | |||
286 | static struct omap_hwmod_irq_info uart2_mpu_irqs[] = { | ||
287 | { .irq = INT_24XX_UART2_IRQ, }, | ||
288 | }; | ||
289 | |||
290 | static struct omap_hwmod_dma_info uart2_sdma_reqs[] = { | ||
291 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, }, | ||
292 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, }, | ||
293 | }; | ||
294 | |||
295 | static struct omap_hwmod_ocp_if *omap2430_uart2_slaves[] = { | ||
296 | &omap2_l4_core__uart2, | ||
297 | }; | ||
298 | |||
299 | static struct omap_hwmod omap2430_uart2_hwmod = { | ||
300 | .name = "uart2", | ||
301 | .mpu_irqs = uart2_mpu_irqs, | ||
302 | .mpu_irqs_cnt = ARRAY_SIZE(uart2_mpu_irqs), | ||
303 | .sdma_reqs = uart2_sdma_reqs, | ||
304 | .sdma_reqs_cnt = ARRAY_SIZE(uart2_sdma_reqs), | ||
305 | .main_clk = "uart2_fck", | ||
306 | .prcm = { | ||
307 | .omap2 = { | ||
308 | .module_offs = CORE_MOD, | ||
309 | .prcm_reg_id = 1, | ||
310 | .module_bit = OMAP24XX_EN_UART2_SHIFT, | ||
311 | .idlest_reg_id = 1, | ||
312 | .idlest_idle_bit = OMAP24XX_EN_UART2_SHIFT, | ||
313 | }, | ||
314 | }, | ||
315 | .slaves = omap2430_uart2_slaves, | ||
316 | .slaves_cnt = ARRAY_SIZE(omap2430_uart2_slaves), | ||
317 | .class = &uart_class, | ||
318 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), | ||
319 | }; | ||
320 | |||
321 | /* UART3 */ | ||
322 | |||
323 | static struct omap_hwmod_irq_info uart3_mpu_irqs[] = { | ||
324 | { .irq = INT_24XX_UART3_IRQ, }, | ||
325 | }; | ||
326 | |||
327 | static struct omap_hwmod_dma_info uart3_sdma_reqs[] = { | ||
328 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, }, | ||
329 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, }, | ||
330 | }; | ||
331 | |||
332 | static struct omap_hwmod_ocp_if *omap2430_uart3_slaves[] = { | ||
333 | &omap2_l4_core__uart3, | ||
334 | }; | ||
335 | |||
336 | static struct omap_hwmod omap2430_uart3_hwmod = { | ||
337 | .name = "uart3", | ||
338 | .mpu_irqs = uart3_mpu_irqs, | ||
339 | .mpu_irqs_cnt = ARRAY_SIZE(uart3_mpu_irqs), | ||
340 | .sdma_reqs = uart3_sdma_reqs, | ||
341 | .sdma_reqs_cnt = ARRAY_SIZE(uart3_sdma_reqs), | ||
342 | .main_clk = "uart3_fck", | ||
343 | .prcm = { | ||
344 | .omap2 = { | ||
345 | .module_offs = CORE_MOD, | ||
346 | .prcm_reg_id = 2, | ||
347 | .module_bit = OMAP24XX_EN_UART3_SHIFT, | ||
348 | .idlest_reg_id = 2, | ||
349 | .idlest_idle_bit = OMAP24XX_EN_UART3_SHIFT, | ||
350 | }, | ||
351 | }, | ||
352 | .slaves = omap2430_uart3_slaves, | ||
353 | .slaves_cnt = ARRAY_SIZE(omap2430_uart3_slaves), | ||
354 | .class = &uart_class, | ||
355 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP2430), | ||
356 | }; | ||
357 | |||
168 | static __initdata struct omap_hwmod *omap2430_hwmods[] = { | 358 | static __initdata struct omap_hwmod *omap2430_hwmods[] = { |
169 | &omap2430_l3_main_hwmod, | 359 | &omap2430_l3_main_hwmod, |
170 | &omap2430_l4_core_hwmod, | 360 | &omap2430_l4_core_hwmod, |
171 | &omap2430_l4_wkup_hwmod, | 361 | &omap2430_l4_wkup_hwmod, |
172 | &omap2430_mpu_hwmod, | 362 | &omap2430_mpu_hwmod, |
173 | &omap2430_iva_hwmod, | 363 | &omap2430_iva_hwmod, |
364 | &omap2430_uart1_hwmod, | ||
365 | &omap2430_uart2_hwmod, | ||
366 | &omap2430_uart3_hwmod, | ||
174 | NULL, | 367 | NULL, |
175 | }; | 368 | }; |
176 | 369 | ||
diff --git a/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c b/arch/arm/mach-omap2/omap_hwmod_3xxx_data.c index 5d8eb58ba5e3..5c9cb255a052 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 | ||
@@ -82,6 +83,10 @@ static struct omap_hwmod omap3xxx_l3_main_hwmod = { | |||
82 | }; | 83 | }; |
83 | 84 | ||
84 | static struct omap_hwmod omap3xxx_l4_wkup_hwmod; | 85 | static struct omap_hwmod omap3xxx_l4_wkup_hwmod; |
86 | static struct omap_hwmod omap3xxx_uart1_hwmod; | ||
87 | static struct omap_hwmod omap3xxx_uart2_hwmod; | ||
88 | static struct omap_hwmod omap3xxx_uart3_hwmod; | ||
89 | static struct omap_hwmod omap3xxx_uart4_hwmod; | ||
85 | 90 | ||
86 | /* L4_CORE -> L4_WKUP interface */ | 91 | /* L4_CORE -> L4_WKUP interface */ |
87 | static struct omap_hwmod_ocp_if omap3xxx_l4_core__l4_wkup = { | 92 | static struct omap_hwmod_ocp_if omap3xxx_l4_core__l4_wkup = { |
@@ -90,6 +95,78 @@ static struct omap_hwmod_ocp_if omap3xxx_l4_core__l4_wkup = { | |||
90 | .user = OCP_USER_MPU | OCP_USER_SDMA, | 95 | .user = OCP_USER_MPU | OCP_USER_SDMA, |
91 | }; | 96 | }; |
92 | 97 | ||
98 | /* L4 CORE -> UART1 interface */ | ||
99 | static struct omap_hwmod_addr_space omap3xxx_uart1_addr_space[] = { | ||
100 | { | ||
101 | .pa_start = OMAP3_UART1_BASE, | ||
102 | .pa_end = OMAP3_UART1_BASE + SZ_8K - 1, | ||
103 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
104 | }, | ||
105 | }; | ||
106 | |||
107 | static struct omap_hwmod_ocp_if omap3_l4_core__uart1 = { | ||
108 | .master = &omap3xxx_l4_core_hwmod, | ||
109 | .slave = &omap3xxx_uart1_hwmod, | ||
110 | .clk = "uart1_ick", | ||
111 | .addr = omap3xxx_uart1_addr_space, | ||
112 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart1_addr_space), | ||
113 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
114 | }; | ||
115 | |||
116 | /* L4 CORE -> UART2 interface */ | ||
117 | static struct omap_hwmod_addr_space omap3xxx_uart2_addr_space[] = { | ||
118 | { | ||
119 | .pa_start = OMAP3_UART2_BASE, | ||
120 | .pa_end = OMAP3_UART2_BASE + SZ_1K - 1, | ||
121 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
122 | }, | ||
123 | }; | ||
124 | |||
125 | static struct omap_hwmod_ocp_if omap3_l4_core__uart2 = { | ||
126 | .master = &omap3xxx_l4_core_hwmod, | ||
127 | .slave = &omap3xxx_uart2_hwmod, | ||
128 | .clk = "uart2_ick", | ||
129 | .addr = omap3xxx_uart2_addr_space, | ||
130 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart2_addr_space), | ||
131 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
132 | }; | ||
133 | |||
134 | /* L4 PER -> UART3 interface */ | ||
135 | static struct omap_hwmod_addr_space omap3xxx_uart3_addr_space[] = { | ||
136 | { | ||
137 | .pa_start = OMAP3_UART3_BASE, | ||
138 | .pa_end = OMAP3_UART3_BASE + SZ_1K - 1, | ||
139 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
140 | }, | ||
141 | }; | ||
142 | |||
143 | static struct omap_hwmod_ocp_if omap3_l4_per__uart3 = { | ||
144 | .master = &omap3xxx_l4_per_hwmod, | ||
145 | .slave = &omap3xxx_uart3_hwmod, | ||
146 | .clk = "uart3_ick", | ||
147 | .addr = omap3xxx_uart3_addr_space, | ||
148 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart3_addr_space), | ||
149 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
150 | }; | ||
151 | |||
152 | /* L4 PER -> UART4 interface */ | ||
153 | static struct omap_hwmod_addr_space omap3xxx_uart4_addr_space[] = { | ||
154 | { | ||
155 | .pa_start = OMAP3_UART4_BASE, | ||
156 | .pa_end = OMAP3_UART4_BASE + SZ_1K - 1, | ||
157 | .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT, | ||
158 | }, | ||
159 | }; | ||
160 | |||
161 | static struct omap_hwmod_ocp_if omap3_l4_per__uart4 = { | ||
162 | .master = &omap3xxx_l4_per_hwmod, | ||
163 | .slave = &omap3xxx_uart4_hwmod, | ||
164 | .clk = "uart4_ick", | ||
165 | .addr = omap3xxx_uart4_addr_space, | ||
166 | .addr_cnt = ARRAY_SIZE(omap3xxx_uart4_addr_space), | ||
167 | .user = OCP_USER_MPU | OCP_USER_SDMA, | ||
168 | }; | ||
169 | |||
93 | /* Slave interfaces on the L4_CORE interconnect */ | 170 | /* Slave interfaces on the L4_CORE interconnect */ |
94 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_slaves[] = { | 171 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_slaves[] = { |
95 | &omap3xxx_l3_main__l4_core, | 172 | &omap3xxx_l3_main__l4_core, |
@@ -98,6 +175,8 @@ static struct omap_hwmod_ocp_if *omap3xxx_l4_core_slaves[] = { | |||
98 | /* Master interfaces on the L4_CORE interconnect */ | 175 | /* Master interfaces on the L4_CORE interconnect */ |
99 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_masters[] = { | 176 | static struct omap_hwmod_ocp_if *omap3xxx_l4_core_masters[] = { |
100 | &omap3xxx_l4_core__l4_wkup, | 177 | &omap3xxx_l4_core__l4_wkup, |
178 | &omap3_l4_core__uart1, | ||
179 | &omap3_l4_core__uart2, | ||
101 | }; | 180 | }; |
102 | 181 | ||
103 | /* L4 CORE */ | 182 | /* L4 CORE */ |
@@ -119,6 +198,8 @@ static struct omap_hwmod_ocp_if *omap3xxx_l4_per_slaves[] = { | |||
119 | 198 | ||
120 | /* Master interfaces on the L4_PER interconnect */ | 199 | /* Master interfaces on the L4_PER interconnect */ |
121 | static struct omap_hwmod_ocp_if *omap3xxx_l4_per_masters[] = { | 200 | static struct omap_hwmod_ocp_if *omap3xxx_l4_per_masters[] = { |
201 | &omap3_l4_per__uart3, | ||
202 | &omap3_l4_per__uart4, | ||
122 | }; | 203 | }; |
123 | 204 | ||
124 | /* L4 PER */ | 205 | /* L4 PER */ |
@@ -197,6 +278,172 @@ static struct omap_hwmod omap3xxx_iva_hwmod = { | |||
197 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430) | 278 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430) |
198 | }; | 279 | }; |
199 | 280 | ||
281 | /* UART common */ | ||
282 | |||
283 | static struct omap_hwmod_class_sysconfig uart_sysc = { | ||
284 | .rev_offs = 0x50, | ||
285 | .sysc_offs = 0x54, | ||
286 | .syss_offs = 0x58, | ||
287 | .sysc_flags = (SYSC_HAS_SIDLEMODE | | ||
288 | SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET | | ||
289 | SYSC_HAS_AUTOIDLE), | ||
290 | .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART), | ||
291 | .sysc_fields = &omap_hwmod_sysc_type1, | ||
292 | }; | ||
293 | |||
294 | static struct omap_hwmod_class uart_class = { | ||
295 | .name = "uart", | ||
296 | .sysc = &uart_sysc, | ||
297 | }; | ||
298 | |||
299 | /* UART1 */ | ||
300 | |||
301 | static struct omap_hwmod_irq_info uart1_mpu_irqs[] = { | ||
302 | { .irq = INT_24XX_UART1_IRQ, }, | ||
303 | }; | ||
304 | |||
305 | static struct omap_hwmod_dma_info uart1_sdma_reqs[] = { | ||
306 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, }, | ||
307 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, }, | ||
308 | }; | ||
309 | |||
310 | static struct omap_hwmod_ocp_if *omap3xxx_uart1_slaves[] = { | ||
311 | &omap3_l4_core__uart1, | ||
312 | }; | ||
313 | |||
314 | static struct omap_hwmod omap3xxx_uart1_hwmod = { | ||
315 | .name = "uart1", | ||
316 | .mpu_irqs = uart1_mpu_irqs, | ||
317 | .mpu_irqs_cnt = ARRAY_SIZE(uart1_mpu_irqs), | ||
318 | .sdma_reqs = uart1_sdma_reqs, | ||
319 | .sdma_reqs_cnt = ARRAY_SIZE(uart1_sdma_reqs), | ||
320 | .main_clk = "uart1_fck", | ||
321 | .prcm = { | ||
322 | .omap2 = { | ||
323 | .module_offs = CORE_MOD, | ||
324 | .prcm_reg_id = 1, | ||
325 | .module_bit = OMAP3430_EN_UART1_SHIFT, | ||
326 | .idlest_reg_id = 1, | ||
327 | .idlest_idle_bit = OMAP3430_EN_UART1_SHIFT, | ||
328 | }, | ||
329 | }, | ||
330 | .slaves = omap3xxx_uart1_slaves, | ||
331 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart1_slaves), | ||
332 | .class = &uart_class, | ||
333 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), | ||
334 | }; | ||
335 | |||
336 | /* UART2 */ | ||
337 | |||
338 | static struct omap_hwmod_irq_info uart2_mpu_irqs[] = { | ||
339 | { .irq = INT_24XX_UART2_IRQ, }, | ||
340 | }; | ||
341 | |||
342 | static struct omap_hwmod_dma_info uart2_sdma_reqs[] = { | ||
343 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, }, | ||
344 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, }, | ||
345 | }; | ||
346 | |||
347 | static struct omap_hwmod_ocp_if *omap3xxx_uart2_slaves[] = { | ||
348 | &omap3_l4_core__uart2, | ||
349 | }; | ||
350 | |||
351 | static struct omap_hwmod omap3xxx_uart2_hwmod = { | ||
352 | .name = "uart2", | ||
353 | .mpu_irqs = uart2_mpu_irqs, | ||
354 | .mpu_irqs_cnt = ARRAY_SIZE(uart2_mpu_irqs), | ||
355 | .sdma_reqs = uart2_sdma_reqs, | ||
356 | .sdma_reqs_cnt = ARRAY_SIZE(uart2_sdma_reqs), | ||
357 | .main_clk = "uart2_fck", | ||
358 | .prcm = { | ||
359 | .omap2 = { | ||
360 | .module_offs = CORE_MOD, | ||
361 | .prcm_reg_id = 1, | ||
362 | .module_bit = OMAP3430_EN_UART2_SHIFT, | ||
363 | .idlest_reg_id = 1, | ||
364 | .idlest_idle_bit = OMAP3430_EN_UART2_SHIFT, | ||
365 | }, | ||
366 | }, | ||
367 | .slaves = omap3xxx_uart2_slaves, | ||
368 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart2_slaves), | ||
369 | .class = &uart_class, | ||
370 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), | ||
371 | }; | ||
372 | |||
373 | /* UART3 */ | ||
374 | |||
375 | static struct omap_hwmod_irq_info uart3_mpu_irqs[] = { | ||
376 | { .irq = INT_24XX_UART3_IRQ, }, | ||
377 | }; | ||
378 | |||
379 | static struct omap_hwmod_dma_info uart3_sdma_reqs[] = { | ||
380 | { .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, }, | ||
381 | { .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, }, | ||
382 | }; | ||
383 | |||
384 | static struct omap_hwmod_ocp_if *omap3xxx_uart3_slaves[] = { | ||
385 | &omap3_l4_per__uart3, | ||
386 | }; | ||
387 | |||
388 | static struct omap_hwmod omap3xxx_uart3_hwmod = { | ||
389 | .name = "uart3", | ||
390 | .mpu_irqs = uart3_mpu_irqs, | ||
391 | .mpu_irqs_cnt = ARRAY_SIZE(uart3_mpu_irqs), | ||
392 | .sdma_reqs = uart3_sdma_reqs, | ||
393 | .sdma_reqs_cnt = ARRAY_SIZE(uart3_sdma_reqs), | ||
394 | .main_clk = "uart3_fck", | ||
395 | .prcm = { | ||
396 | .omap2 = { | ||
397 | .module_offs = OMAP3430_PER_MOD, | ||
398 | .prcm_reg_id = 1, | ||
399 | .module_bit = OMAP3430_EN_UART3_SHIFT, | ||
400 | .idlest_reg_id = 1, | ||
401 | .idlest_idle_bit = OMAP3430_EN_UART3_SHIFT, | ||
402 | }, | ||
403 | }, | ||
404 | .slaves = omap3xxx_uart3_slaves, | ||
405 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart3_slaves), | ||
406 | .class = &uart_class, | ||
407 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430), | ||
408 | }; | ||
409 | |||
410 | /* UART4 */ | ||
411 | |||
412 | static struct omap_hwmod_irq_info uart4_mpu_irqs[] = { | ||
413 | { .irq = INT_36XX_UART4_IRQ, }, | ||
414 | }; | ||
415 | |||
416 | static struct omap_hwmod_dma_info uart4_sdma_reqs[] = { | ||
417 | { .name = "rx", .dma_req = OMAP36XX_DMA_UART4_RX, }, | ||
418 | { .name = "tx", .dma_req = OMAP36XX_DMA_UART4_TX, }, | ||
419 | }; | ||
420 | |||
421 | static struct omap_hwmod_ocp_if *omap3xxx_uart4_slaves[] = { | ||
422 | &omap3_l4_per__uart4, | ||
423 | }; | ||
424 | |||
425 | static struct omap_hwmod omap3xxx_uart4_hwmod = { | ||
426 | .name = "uart4", | ||
427 | .mpu_irqs = uart4_mpu_irqs, | ||
428 | .mpu_irqs_cnt = ARRAY_SIZE(uart4_mpu_irqs), | ||
429 | .sdma_reqs = uart4_sdma_reqs, | ||
430 | .sdma_reqs_cnt = ARRAY_SIZE(uart4_sdma_reqs), | ||
431 | .main_clk = "uart4_fck", | ||
432 | .prcm = { | ||
433 | .omap2 = { | ||
434 | .module_offs = OMAP3430_PER_MOD, | ||
435 | .prcm_reg_id = 1, | ||
436 | .module_bit = OMAP3630_EN_UART4_SHIFT, | ||
437 | .idlest_reg_id = 1, | ||
438 | .idlest_idle_bit = OMAP3630_EN_UART4_SHIFT, | ||
439 | }, | ||
440 | }, | ||
441 | .slaves = omap3xxx_uart4_slaves, | ||
442 | .slaves_cnt = ARRAY_SIZE(omap3xxx_uart4_slaves), | ||
443 | .class = &uart_class, | ||
444 | .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3630ES1), | ||
445 | }; | ||
446 | |||
200 | static __initdata struct omap_hwmod *omap3xxx_hwmods[] = { | 447 | static __initdata struct omap_hwmod *omap3xxx_hwmods[] = { |
201 | &omap3xxx_l3_main_hwmod, | 448 | &omap3xxx_l3_main_hwmod, |
202 | &omap3xxx_l4_core_hwmod, | 449 | &omap3xxx_l4_core_hwmod, |
@@ -204,6 +451,10 @@ static __initdata struct omap_hwmod *omap3xxx_hwmods[] = { | |||
204 | &omap3xxx_l4_wkup_hwmod, | 451 | &omap3xxx_l4_wkup_hwmod, |
205 | &omap3xxx_mpu_hwmod, | 452 | &omap3xxx_mpu_hwmod, |
206 | &omap3xxx_iva_hwmod, | 453 | &omap3xxx_iva_hwmod, |
454 | &omap3xxx_uart1_hwmod, | ||
455 | &omap3xxx_uart2_hwmod, | ||
456 | &omap3xxx_uart3_hwmod, | ||
457 | &omap3xxx_uart4_hwmod, | ||
207 | NULL, | 458 | NULL, |
208 | }; | 459 | }; |
209 | 460 | ||
@@ -211,5 +462,3 @@ int __init omap3xxx_hwmod_init(void) | |||
211 | { | 462 | { |
212 | return omap_hwmod_init(omap3xxx_hwmods); | 463 | return omap_hwmod_init(omap3xxx_hwmods); |
213 | } | 464 | } |
214 | |||
215 | |||
diff --git a/arch/arm/mach-omap2/prcm-common.h b/arch/arm/mach-omap2/prcm-common.h index 995b7edbf18d..86edcf9ada7c 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) |
diff --git a/arch/arm/plat-omap/include/plat/dma.h b/arch/arm/plat-omap/include/plat/dma.h index af3a03941add..098f154f5d41 100644 --- a/arch/arm/plat-omap/include/plat/dma.h +++ b/arch/arm/plat-omap/include/plat/dma.h | |||
@@ -319,6 +319,8 @@ | |||
319 | #define OMAP34XX_DMA_USIM_TX 79 /* S_DMA_78 */ | 319 | #define OMAP34XX_DMA_USIM_TX 79 /* S_DMA_78 */ |
320 | #define OMAP34XX_DMA_USIM_RX 80 /* S_DMA_79 */ | 320 | #define OMAP34XX_DMA_USIM_RX 80 /* S_DMA_79 */ |
321 | 321 | ||
322 | #define OMAP36XX_DMA_UART4_TX 81 /* S_DMA_80 */ | ||
323 | #define OMAP36XX_DMA_UART4_RX 82 /* S_DMA_81 */ | ||
322 | /*----------------------------------------------------------------------------*/ | 324 | /*----------------------------------------------------------------------------*/ |
323 | 325 | ||
324 | #define OMAP1_DMA_TOUT_IRQ (1 << 0) | 326 | #define OMAP1_DMA_TOUT_IRQ (1 << 0) |
diff --git a/arch/arm/plat-omap/include/plat/irqs.h b/arch/arm/plat-omap/include/plat/irqs.h index c01d9f08a198..65e20a686713 100644 --- a/arch/arm/plat-omap/include/plat/irqs.h +++ b/arch/arm/plat-omap/include/plat/irqs.h | |||
@@ -345,6 +345,8 @@ | |||
345 | #define INT_34XX_MMC3_IRQ 94 | 345 | #define INT_34XX_MMC3_IRQ 94 |
346 | #define INT_34XX_GPT12_IRQ 95 | 346 | #define INT_34XX_GPT12_IRQ 95 |
347 | 347 | ||
348 | #define INT_36XX_UART4_IRQ 80 | ||
349 | |||
348 | #define INT_35XX_HECC0_IRQ 24 | 350 | #define INT_35XX_HECC0_IRQ 24 |
349 | #define INT_35XX_HECC1_IRQ 28 | 351 | #define INT_35XX_HECC1_IRQ 28 |
350 | #define INT_35XX_EMAC_C0_RXTHRESH_IRQ 67 | 352 | #define INT_35XX_EMAC_C0_RXTHRESH_IRQ 67 |