blob: acf0d54024ab25a954022676edd51ad4699c4f2a [file] [log] [blame]
Paul Walmsley73591542010-02-22 22:09:32 -07001/*
2 * omap_hwmod_3xxx_data.c - hardware modules present on the OMAP3xxx chips
3 *
4 * Copyright (C) 2009-2010 Nokia Corporation
5 * Paul Walmsley
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 *
11 * The data in this file should be completely autogeneratable from
12 * the TI hardware database or other technical documentation.
13 *
14 * XXX these should be marked initdata for multi-OMAP kernels
15 */
16#include <plat/omap_hwmod.h>
17#include <mach/irqs.h>
18#include <plat/cpu.h>
19#include <plat/dma.h>
Kevin Hilman046465b2010-09-27 20:19:30 +053020#include <plat/serial.h>
Rajendra Nayak4fe20e92010-09-21 19:37:13 +053021#include <plat/l4_3xxx.h>
22#include <plat/i2c.h>
Varadarajan, Charulatha70034d32010-12-07 16:26:57 -080023#include <plat/gpio.h>
Thara Gopinathd3442722010-05-29 22:02:24 +053024#include <plat/smartreflex.h>
Paul Walmsley73591542010-02-22 22:09:32 -070025
Paul Walmsley43b40992010-02-22 22:09:34 -070026#include "omap_hwmod_common_data.h"
27
Paul Walmsley73591542010-02-22 22:09:32 -070028#include "prm-regbits-34xx.h"
Varadarajan, Charulatha6b667f82010-09-23 20:02:38 +053029#include "cm-regbits-34xx.h"
Paul Walmsleyff2516f2010-12-21 15:39:15 -070030#include "wd_timer.h"
Paul Walmsley73591542010-02-22 22:09:32 -070031
32/*
33 * OMAP3xxx hardware module integration data
34 *
35 * ALl of the data in this section should be autogeneratable from the
36 * TI hardware database or other technical documentation. Data that
37 * is driver-specific or driver-kernel integration-specific belongs
38 * elsewhere.
39 */
40
41static struct omap_hwmod omap3xxx_mpu_hwmod;
Kevin Hilman540064b2010-07-26 16:34:32 -060042static struct omap_hwmod omap3xxx_iva_hwmod;
Kevin Hilman4a7cf902010-07-26 16:34:32 -060043static struct omap_hwmod omap3xxx_l3_main_hwmod;
Paul Walmsley73591542010-02-22 22:09:32 -070044static struct omap_hwmod omap3xxx_l4_core_hwmod;
45static struct omap_hwmod omap3xxx_l4_per_hwmod;
Varadarajan, Charulatha6b667f82010-09-23 20:02:38 +053046static struct omap_hwmod omap3xxx_wd_timer2_hwmod;
Rajendra Nayak4fe20e92010-09-21 19:37:13 +053047static struct omap_hwmod omap3xxx_i2c1_hwmod;
48static struct omap_hwmod omap3xxx_i2c2_hwmod;
49static struct omap_hwmod omap3xxx_i2c3_hwmod;
Varadarajan, Charulatha70034d32010-12-07 16:26:57 -080050static struct omap_hwmod omap3xxx_gpio1_hwmod;
51static struct omap_hwmod omap3xxx_gpio2_hwmod;
52static struct omap_hwmod omap3xxx_gpio3_hwmod;
53static struct omap_hwmod omap3xxx_gpio4_hwmod;
54static struct omap_hwmod omap3xxx_gpio5_hwmod;
55static struct omap_hwmod omap3xxx_gpio6_hwmod;
Thara Gopinathd3442722010-05-29 22:02:24 +053056static struct omap_hwmod omap34xx_sr1_hwmod;
57static struct omap_hwmod omap34xx_sr2_hwmod;
Paul Walmsley73591542010-02-22 22:09:32 -070058
G, Manjunath Kondaiah01438ab2010-12-20 18:27:19 -080059static struct omap_hwmod omap3xxx_dma_system_hwmod;
60
Paul Walmsley73591542010-02-22 22:09:32 -070061/* L3 -> L4_CORE interface */
Kevin Hilman4a7cf902010-07-26 16:34:32 -060062static struct omap_hwmod_ocp_if omap3xxx_l3_main__l4_core = {
63 .master = &omap3xxx_l3_main_hwmod,
Paul Walmsley73591542010-02-22 22:09:32 -070064 .slave = &omap3xxx_l4_core_hwmod,
65 .user = OCP_USER_MPU | OCP_USER_SDMA,
66};
67
68/* L3 -> L4_PER interface */
Kevin Hilman4a7cf902010-07-26 16:34:32 -060069static struct omap_hwmod_ocp_if omap3xxx_l3_main__l4_per = {
70 .master = &omap3xxx_l3_main_hwmod,
Paul Walmsley73591542010-02-22 22:09:32 -070071 .slave = &omap3xxx_l4_per_hwmod,
72 .user = OCP_USER_MPU | OCP_USER_SDMA,
73};
74
75/* MPU -> L3 interface */
Kevin Hilman4a7cf902010-07-26 16:34:32 -060076static struct omap_hwmod_ocp_if omap3xxx_mpu__l3_main = {
Paul Walmsley73591542010-02-22 22:09:32 -070077 .master = &omap3xxx_mpu_hwmod,
Kevin Hilman4a7cf902010-07-26 16:34:32 -060078 .slave = &omap3xxx_l3_main_hwmod,
Paul Walmsley73591542010-02-22 22:09:32 -070079 .user = OCP_USER_MPU,
80};
81
82/* Slave interfaces on the L3 interconnect */
Kevin Hilman4a7cf902010-07-26 16:34:32 -060083static struct omap_hwmod_ocp_if *omap3xxx_l3_main_slaves[] = {
84 &omap3xxx_mpu__l3_main,
Paul Walmsley73591542010-02-22 22:09:32 -070085};
86
87/* Master interfaces on the L3 interconnect */
Kevin Hilman4a7cf902010-07-26 16:34:32 -060088static struct omap_hwmod_ocp_if *omap3xxx_l3_main_masters[] = {
89 &omap3xxx_l3_main__l4_core,
90 &omap3xxx_l3_main__l4_per,
Paul Walmsley73591542010-02-22 22:09:32 -070091};
92
93/* L3 */
Kevin Hilman4a7cf902010-07-26 16:34:32 -060094static struct omap_hwmod omap3xxx_l3_main_hwmod = {
Benoit Coussonfa983472010-07-26 16:34:29 -060095 .name = "l3_main",
Paul Walmsley43b40992010-02-22 22:09:34 -070096 .class = &l3_hwmod_class,
Kevin Hilman4a7cf902010-07-26 16:34:32 -060097 .masters = omap3xxx_l3_main_masters,
98 .masters_cnt = ARRAY_SIZE(omap3xxx_l3_main_masters),
99 .slaves = omap3xxx_l3_main_slaves,
100 .slaves_cnt = ARRAY_SIZE(omap3xxx_l3_main_slaves),
Kevin Hilman2eb18752010-07-26 16:34:28 -0600101 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
102 .flags = HWMOD_NO_IDLEST,
Paul Walmsley73591542010-02-22 22:09:32 -0700103};
104
105static struct omap_hwmod omap3xxx_l4_wkup_hwmod;
Kevin Hilman046465b2010-09-27 20:19:30 +0530106static struct omap_hwmod omap3xxx_uart1_hwmod;
107static struct omap_hwmod omap3xxx_uart2_hwmod;
108static struct omap_hwmod omap3xxx_uart3_hwmod;
109static struct omap_hwmod omap3xxx_uart4_hwmod;
Paul Walmsley73591542010-02-22 22:09:32 -0700110
111/* L4_CORE -> L4_WKUP interface */
112static struct omap_hwmod_ocp_if omap3xxx_l4_core__l4_wkup = {
113 .master = &omap3xxx_l4_core_hwmod,
114 .slave = &omap3xxx_l4_wkup_hwmod,
115 .user = OCP_USER_MPU | OCP_USER_SDMA,
116};
117
Kevin Hilman046465b2010-09-27 20:19:30 +0530118/* L4 CORE -> UART1 interface */
119static struct omap_hwmod_addr_space omap3xxx_uart1_addr_space[] = {
120 {
121 .pa_start = OMAP3_UART1_BASE,
122 .pa_end = OMAP3_UART1_BASE + SZ_8K - 1,
123 .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT,
124 },
125};
126
127static struct omap_hwmod_ocp_if omap3_l4_core__uart1 = {
128 .master = &omap3xxx_l4_core_hwmod,
129 .slave = &omap3xxx_uart1_hwmod,
130 .clk = "uart1_ick",
131 .addr = omap3xxx_uart1_addr_space,
132 .addr_cnt = ARRAY_SIZE(omap3xxx_uart1_addr_space),
133 .user = OCP_USER_MPU | OCP_USER_SDMA,
134};
135
136/* L4 CORE -> UART2 interface */
137static struct omap_hwmod_addr_space omap3xxx_uart2_addr_space[] = {
138 {
139 .pa_start = OMAP3_UART2_BASE,
140 .pa_end = OMAP3_UART2_BASE + SZ_1K - 1,
141 .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT,
142 },
143};
144
145static struct omap_hwmod_ocp_if omap3_l4_core__uart2 = {
146 .master = &omap3xxx_l4_core_hwmod,
147 .slave = &omap3xxx_uart2_hwmod,
148 .clk = "uart2_ick",
149 .addr = omap3xxx_uart2_addr_space,
150 .addr_cnt = ARRAY_SIZE(omap3xxx_uart2_addr_space),
151 .user = OCP_USER_MPU | OCP_USER_SDMA,
152};
153
154/* L4 PER -> UART3 interface */
155static struct omap_hwmod_addr_space omap3xxx_uart3_addr_space[] = {
156 {
157 .pa_start = OMAP3_UART3_BASE,
158 .pa_end = OMAP3_UART3_BASE + SZ_1K - 1,
159 .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT,
160 },
161};
162
163static struct omap_hwmod_ocp_if omap3_l4_per__uart3 = {
164 .master = &omap3xxx_l4_per_hwmod,
165 .slave = &omap3xxx_uart3_hwmod,
166 .clk = "uart3_ick",
167 .addr = omap3xxx_uart3_addr_space,
168 .addr_cnt = ARRAY_SIZE(omap3xxx_uart3_addr_space),
169 .user = OCP_USER_MPU | OCP_USER_SDMA,
170};
171
172/* L4 PER -> UART4 interface */
173static struct omap_hwmod_addr_space omap3xxx_uart4_addr_space[] = {
174 {
175 .pa_start = OMAP3_UART4_BASE,
176 .pa_end = OMAP3_UART4_BASE + SZ_1K - 1,
177 .flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT,
178 },
179};
180
181static struct omap_hwmod_ocp_if omap3_l4_per__uart4 = {
182 .master = &omap3xxx_l4_per_hwmod,
183 .slave = &omap3xxx_uart4_hwmod,
184 .clk = "uart4_ick",
185 .addr = omap3xxx_uart4_addr_space,
186 .addr_cnt = ARRAY_SIZE(omap3xxx_uart4_addr_space),
187 .user = OCP_USER_MPU | OCP_USER_SDMA,
188};
189
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530190/* I2C IP block address space length (in bytes) */
191#define OMAP2_I2C_AS_LEN 128
192
193/* L4 CORE -> I2C1 interface */
194static struct omap_hwmod_addr_space omap3xxx_i2c1_addr_space[] = {
195 {
196 .pa_start = 0x48070000,
197 .pa_end = 0x48070000 + OMAP2_I2C_AS_LEN - 1,
198 .flags = ADDR_TYPE_RT,
199 },
200};
201
202static struct omap_hwmod_ocp_if omap3_l4_core__i2c1 = {
203 .master = &omap3xxx_l4_core_hwmod,
204 .slave = &omap3xxx_i2c1_hwmod,
205 .clk = "i2c1_ick",
206 .addr = omap3xxx_i2c1_addr_space,
207 .addr_cnt = ARRAY_SIZE(omap3xxx_i2c1_addr_space),
208 .fw = {
209 .omap2 = {
210 .l4_fw_region = OMAP3_L4_CORE_FW_I2C1_REGION,
211 .l4_prot_group = 7,
212 .flags = OMAP_FIREWALL_L4,
213 }
214 },
215 .user = OCP_USER_MPU | OCP_USER_SDMA,
216};
217
218/* L4 CORE -> I2C2 interface */
219static struct omap_hwmod_addr_space omap3xxx_i2c2_addr_space[] = {
220 {
221 .pa_start = 0x48072000,
222 .pa_end = 0x48072000 + OMAP2_I2C_AS_LEN - 1,
223 .flags = ADDR_TYPE_RT,
224 },
225};
226
227static struct omap_hwmod_ocp_if omap3_l4_core__i2c2 = {
228 .master = &omap3xxx_l4_core_hwmod,
229 .slave = &omap3xxx_i2c2_hwmod,
230 .clk = "i2c2_ick",
231 .addr = omap3xxx_i2c2_addr_space,
232 .addr_cnt = ARRAY_SIZE(omap3xxx_i2c2_addr_space),
233 .fw = {
234 .omap2 = {
235 .l4_fw_region = OMAP3_L4_CORE_FW_I2C2_REGION,
236 .l4_prot_group = 7,
237 .flags = OMAP_FIREWALL_L4,
238 }
239 },
240 .user = OCP_USER_MPU | OCP_USER_SDMA,
241};
242
243/* L4 CORE -> I2C3 interface */
244static struct omap_hwmod_addr_space omap3xxx_i2c3_addr_space[] = {
245 {
246 .pa_start = 0x48060000,
247 .pa_end = 0x48060000 + OMAP2_I2C_AS_LEN - 1,
248 .flags = ADDR_TYPE_RT,
249 },
250};
251
252static struct omap_hwmod_ocp_if omap3_l4_core__i2c3 = {
253 .master = &omap3xxx_l4_core_hwmod,
254 .slave = &omap3xxx_i2c3_hwmod,
255 .clk = "i2c3_ick",
256 .addr = omap3xxx_i2c3_addr_space,
257 .addr_cnt = ARRAY_SIZE(omap3xxx_i2c3_addr_space),
258 .fw = {
259 .omap2 = {
260 .l4_fw_region = OMAP3_L4_CORE_FW_I2C3_REGION,
261 .l4_prot_group = 7,
262 .flags = OMAP_FIREWALL_L4,
263 }
264 },
265 .user = OCP_USER_MPU | OCP_USER_SDMA,
266};
267
Thara Gopinathd3442722010-05-29 22:02:24 +0530268/* L4 CORE -> SR1 interface */
269static struct omap_hwmod_addr_space omap3_sr1_addr_space[] = {
270 {
271 .pa_start = OMAP34XX_SR1_BASE,
272 .pa_end = OMAP34XX_SR1_BASE + SZ_1K - 1,
273 .flags = ADDR_TYPE_RT,
274 },
275};
276
277static struct omap_hwmod_ocp_if omap3_l4_core__sr1 = {
278 .master = &omap3xxx_l4_core_hwmod,
279 .slave = &omap34xx_sr1_hwmod,
280 .clk = "sr_l4_ick",
281 .addr = omap3_sr1_addr_space,
282 .addr_cnt = ARRAY_SIZE(omap3_sr1_addr_space),
283 .user = OCP_USER_MPU,
284};
285
286/* L4 CORE -> SR1 interface */
287static struct omap_hwmod_addr_space omap3_sr2_addr_space[] = {
288 {
289 .pa_start = OMAP34XX_SR2_BASE,
290 .pa_end = OMAP34XX_SR2_BASE + SZ_1K - 1,
291 .flags = ADDR_TYPE_RT,
292 },
293};
294
295static struct omap_hwmod_ocp_if omap3_l4_core__sr2 = {
296 .master = &omap3xxx_l4_core_hwmod,
297 .slave = &omap34xx_sr2_hwmod,
298 .clk = "sr_l4_ick",
299 .addr = omap3_sr2_addr_space,
300 .addr_cnt = ARRAY_SIZE(omap3_sr2_addr_space),
301 .user = OCP_USER_MPU,
302};
303
Paul Walmsley73591542010-02-22 22:09:32 -0700304/* Slave interfaces on the L4_CORE interconnect */
305static struct omap_hwmod_ocp_if *omap3xxx_l4_core_slaves[] = {
Kevin Hilman4a7cf902010-07-26 16:34:32 -0600306 &omap3xxx_l3_main__l4_core,
Thara Gopinathd3442722010-05-29 22:02:24 +0530307 &omap3_l4_core__sr1,
308 &omap3_l4_core__sr2,
Paul Walmsley73591542010-02-22 22:09:32 -0700309};
310
311/* Master interfaces on the L4_CORE interconnect */
312static struct omap_hwmod_ocp_if *omap3xxx_l4_core_masters[] = {
313 &omap3xxx_l4_core__l4_wkup,
Kevin Hilman046465b2010-09-27 20:19:30 +0530314 &omap3_l4_core__uart1,
315 &omap3_l4_core__uart2,
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530316 &omap3_l4_core__i2c1,
317 &omap3_l4_core__i2c2,
318 &omap3_l4_core__i2c3,
Paul Walmsley73591542010-02-22 22:09:32 -0700319};
320
321/* L4 CORE */
322static struct omap_hwmod omap3xxx_l4_core_hwmod = {
Benoit Coussonfa983472010-07-26 16:34:29 -0600323 .name = "l4_core",
Paul Walmsley43b40992010-02-22 22:09:34 -0700324 .class = &l4_hwmod_class,
Paul Walmsley73591542010-02-22 22:09:32 -0700325 .masters = omap3xxx_l4_core_masters,
326 .masters_cnt = ARRAY_SIZE(omap3xxx_l4_core_masters),
327 .slaves = omap3xxx_l4_core_slaves,
328 .slaves_cnt = ARRAY_SIZE(omap3xxx_l4_core_slaves),
Kevin Hilman2eb18752010-07-26 16:34:28 -0600329 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
330 .flags = HWMOD_NO_IDLEST,
Paul Walmsley73591542010-02-22 22:09:32 -0700331};
332
333/* Slave interfaces on the L4_PER interconnect */
334static struct omap_hwmod_ocp_if *omap3xxx_l4_per_slaves[] = {
Kevin Hilman4a7cf902010-07-26 16:34:32 -0600335 &omap3xxx_l3_main__l4_per,
Paul Walmsley73591542010-02-22 22:09:32 -0700336};
337
338/* Master interfaces on the L4_PER interconnect */
339static struct omap_hwmod_ocp_if *omap3xxx_l4_per_masters[] = {
Kevin Hilman046465b2010-09-27 20:19:30 +0530340 &omap3_l4_per__uart3,
341 &omap3_l4_per__uart4,
Paul Walmsley73591542010-02-22 22:09:32 -0700342};
343
344/* L4 PER */
345static struct omap_hwmod omap3xxx_l4_per_hwmod = {
Benoit Coussonfa983472010-07-26 16:34:29 -0600346 .name = "l4_per",
Paul Walmsley43b40992010-02-22 22:09:34 -0700347 .class = &l4_hwmod_class,
Paul Walmsley73591542010-02-22 22:09:32 -0700348 .masters = omap3xxx_l4_per_masters,
349 .masters_cnt = ARRAY_SIZE(omap3xxx_l4_per_masters),
350 .slaves = omap3xxx_l4_per_slaves,
351 .slaves_cnt = ARRAY_SIZE(omap3xxx_l4_per_slaves),
Kevin Hilman2eb18752010-07-26 16:34:28 -0600352 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
353 .flags = HWMOD_NO_IDLEST,
Paul Walmsley73591542010-02-22 22:09:32 -0700354};
355
356/* Slave interfaces on the L4_WKUP interconnect */
357static struct omap_hwmod_ocp_if *omap3xxx_l4_wkup_slaves[] = {
358 &omap3xxx_l4_core__l4_wkup,
359};
360
361/* Master interfaces on the L4_WKUP interconnect */
362static struct omap_hwmod_ocp_if *omap3xxx_l4_wkup_masters[] = {
363};
364
365/* L4 WKUP */
366static struct omap_hwmod omap3xxx_l4_wkup_hwmod = {
Benoit Coussonfa983472010-07-26 16:34:29 -0600367 .name = "l4_wkup",
Paul Walmsley43b40992010-02-22 22:09:34 -0700368 .class = &l4_hwmod_class,
Paul Walmsley73591542010-02-22 22:09:32 -0700369 .masters = omap3xxx_l4_wkup_masters,
370 .masters_cnt = ARRAY_SIZE(omap3xxx_l4_wkup_masters),
371 .slaves = omap3xxx_l4_wkup_slaves,
372 .slaves_cnt = ARRAY_SIZE(omap3xxx_l4_wkup_slaves),
Kevin Hilman2eb18752010-07-26 16:34:28 -0600373 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
374 .flags = HWMOD_NO_IDLEST,
Paul Walmsley73591542010-02-22 22:09:32 -0700375};
376
377/* Master interfaces on the MPU device */
378static struct omap_hwmod_ocp_if *omap3xxx_mpu_masters[] = {
Kevin Hilman4a7cf902010-07-26 16:34:32 -0600379 &omap3xxx_mpu__l3_main,
Paul Walmsley73591542010-02-22 22:09:32 -0700380};
381
382/* MPU */
383static struct omap_hwmod omap3xxx_mpu_hwmod = {
Benoit Cousson5c2c0292010-05-20 12:31:10 -0600384 .name = "mpu",
Paul Walmsley43b40992010-02-22 22:09:34 -0700385 .class = &mpu_hwmod_class,
Paul Walmsley73591542010-02-22 22:09:32 -0700386 .main_clk = "arm_fck",
387 .masters = omap3xxx_mpu_masters,
388 .masters_cnt = ARRAY_SIZE(omap3xxx_mpu_masters),
389 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
390};
391
Kevin Hilman540064b2010-07-26 16:34:32 -0600392/*
393 * IVA2_2 interface data
394 */
395
396/* IVA2 <- L3 interface */
397static struct omap_hwmod_ocp_if omap3xxx_l3__iva = {
398 .master = &omap3xxx_l3_main_hwmod,
399 .slave = &omap3xxx_iva_hwmod,
400 .clk = "iva2_ck",
401 .user = OCP_USER_MPU | OCP_USER_SDMA,
402};
403
404static struct omap_hwmod_ocp_if *omap3xxx_iva_masters[] = {
405 &omap3xxx_l3__iva,
406};
407
408/*
409 * IVA2 (IVA2)
410 */
411
412static struct omap_hwmod omap3xxx_iva_hwmod = {
413 .name = "iva",
414 .class = &iva_hwmod_class,
415 .masters = omap3xxx_iva_masters,
416 .masters_cnt = ARRAY_SIZE(omap3xxx_iva_masters),
417 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430)
418};
419
Varadarajan, Charulatha6b667f82010-09-23 20:02:38 +0530420/* l4_wkup -> wd_timer2 */
421static struct omap_hwmod_addr_space omap3xxx_wd_timer2_addrs[] = {
422 {
423 .pa_start = 0x48314000,
424 .pa_end = 0x4831407f,
425 .flags = ADDR_TYPE_RT
426 },
427};
428
429static struct omap_hwmod_ocp_if omap3xxx_l4_wkup__wd_timer2 = {
430 .master = &omap3xxx_l4_wkup_hwmod,
431 .slave = &omap3xxx_wd_timer2_hwmod,
432 .clk = "wdt2_ick",
433 .addr = omap3xxx_wd_timer2_addrs,
434 .addr_cnt = ARRAY_SIZE(omap3xxx_wd_timer2_addrs),
435 .user = OCP_USER_MPU | OCP_USER_SDMA,
436};
437
438/*
439 * 'wd_timer' class
440 * 32-bit watchdog upward counter that generates a pulse on the reset pin on
441 * overflow condition
442 */
443
444static struct omap_hwmod_class_sysconfig omap3xxx_wd_timer_sysc = {
445 .rev_offs = 0x0000,
446 .sysc_offs = 0x0010,
447 .syss_offs = 0x0014,
448 .sysc_flags = (SYSC_HAS_SIDLEMODE | SYSC_HAS_EMUFREE |
449 SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET |
Avinash.H.Md73d65f2011-03-03 14:22:46 -0700450 SYSC_HAS_AUTOIDLE | SYSC_HAS_CLOCKACTIVITY |
451 SYSS_HAS_RESET_STATUS),
Varadarajan, Charulatha6b667f82010-09-23 20:02:38 +0530452 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
453 .sysc_fields = &omap_hwmod_sysc_type1,
454};
455
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530456/* I2C common */
457static struct omap_hwmod_class_sysconfig i2c_sysc = {
458 .rev_offs = 0x00,
459 .sysc_offs = 0x20,
460 .syss_offs = 0x10,
461 .sysc_flags = (SYSC_HAS_CLOCKACTIVITY | SYSC_HAS_SIDLEMODE |
462 SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET |
Avinash.H.Md73d65f2011-03-03 14:22:46 -0700463 SYSC_HAS_AUTOIDLE | SYSS_HAS_RESET_STATUS),
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530464 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
465 .sysc_fields = &omap_hwmod_sysc_type1,
466};
467
Varadarajan, Charulatha6b667f82010-09-23 20:02:38 +0530468static struct omap_hwmod_class omap3xxx_wd_timer_hwmod_class = {
Paul Walmsleyff2516f2010-12-21 15:39:15 -0700469 .name = "wd_timer",
470 .sysc = &omap3xxx_wd_timer_sysc,
471 .pre_shutdown = &omap2_wd_timer_disable
Varadarajan, Charulatha6b667f82010-09-23 20:02:38 +0530472};
473
474/* wd_timer2 */
475static struct omap_hwmod_ocp_if *omap3xxx_wd_timer2_slaves[] = {
476 &omap3xxx_l4_wkup__wd_timer2,
477};
478
479static struct omap_hwmod omap3xxx_wd_timer2_hwmod = {
480 .name = "wd_timer2",
481 .class = &omap3xxx_wd_timer_hwmod_class,
482 .main_clk = "wdt2_fck",
483 .prcm = {
484 .omap2 = {
485 .prcm_reg_id = 1,
486 .module_bit = OMAP3430_EN_WDT2_SHIFT,
487 .module_offs = WKUP_MOD,
488 .idlest_reg_id = 1,
489 .idlest_idle_bit = OMAP3430_ST_WDT2_SHIFT,
490 },
491 },
492 .slaves = omap3xxx_wd_timer2_slaves,
493 .slaves_cnt = ARRAY_SIZE(omap3xxx_wd_timer2_slaves),
494 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
495};
496
Kevin Hilman046465b2010-09-27 20:19:30 +0530497/* UART common */
498
499static struct omap_hwmod_class_sysconfig uart_sysc = {
500 .rev_offs = 0x50,
501 .sysc_offs = 0x54,
502 .syss_offs = 0x58,
503 .sysc_flags = (SYSC_HAS_SIDLEMODE |
504 SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET |
Avinash.H.Md73d65f2011-03-03 14:22:46 -0700505 SYSC_HAS_AUTOIDLE | SYSS_HAS_RESET_STATUS),
Kevin Hilman046465b2010-09-27 20:19:30 +0530506 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
507 .sysc_fields = &omap_hwmod_sysc_type1,
508};
509
510static struct omap_hwmod_class uart_class = {
511 .name = "uart",
512 .sysc = &uart_sysc,
513};
514
515/* UART1 */
516
517static struct omap_hwmod_irq_info uart1_mpu_irqs[] = {
518 { .irq = INT_24XX_UART1_IRQ, },
519};
520
521static struct omap_hwmod_dma_info uart1_sdma_reqs[] = {
522 { .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, },
523 { .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, },
524};
525
526static struct omap_hwmod_ocp_if *omap3xxx_uart1_slaves[] = {
527 &omap3_l4_core__uart1,
528};
529
530static struct omap_hwmod omap3xxx_uart1_hwmod = {
531 .name = "uart1",
532 .mpu_irqs = uart1_mpu_irqs,
533 .mpu_irqs_cnt = ARRAY_SIZE(uart1_mpu_irqs),
534 .sdma_reqs = uart1_sdma_reqs,
535 .sdma_reqs_cnt = ARRAY_SIZE(uart1_sdma_reqs),
536 .main_clk = "uart1_fck",
537 .prcm = {
538 .omap2 = {
539 .module_offs = CORE_MOD,
540 .prcm_reg_id = 1,
541 .module_bit = OMAP3430_EN_UART1_SHIFT,
542 .idlest_reg_id = 1,
543 .idlest_idle_bit = OMAP3430_EN_UART1_SHIFT,
544 },
545 },
546 .slaves = omap3xxx_uart1_slaves,
547 .slaves_cnt = ARRAY_SIZE(omap3xxx_uart1_slaves),
548 .class = &uart_class,
549 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
550};
551
552/* UART2 */
553
554static struct omap_hwmod_irq_info uart2_mpu_irqs[] = {
555 { .irq = INT_24XX_UART2_IRQ, },
556};
557
558static struct omap_hwmod_dma_info uart2_sdma_reqs[] = {
559 { .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, },
560 { .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, },
561};
562
563static struct omap_hwmod_ocp_if *omap3xxx_uart2_slaves[] = {
564 &omap3_l4_core__uart2,
565};
566
567static struct omap_hwmod omap3xxx_uart2_hwmod = {
568 .name = "uart2",
569 .mpu_irqs = uart2_mpu_irqs,
570 .mpu_irqs_cnt = ARRAY_SIZE(uart2_mpu_irqs),
571 .sdma_reqs = uart2_sdma_reqs,
572 .sdma_reqs_cnt = ARRAY_SIZE(uart2_sdma_reqs),
573 .main_clk = "uart2_fck",
574 .prcm = {
575 .omap2 = {
576 .module_offs = CORE_MOD,
577 .prcm_reg_id = 1,
578 .module_bit = OMAP3430_EN_UART2_SHIFT,
579 .idlest_reg_id = 1,
580 .idlest_idle_bit = OMAP3430_EN_UART2_SHIFT,
581 },
582 },
583 .slaves = omap3xxx_uart2_slaves,
584 .slaves_cnt = ARRAY_SIZE(omap3xxx_uart2_slaves),
585 .class = &uart_class,
586 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
587};
588
589/* UART3 */
590
591static struct omap_hwmod_irq_info uart3_mpu_irqs[] = {
592 { .irq = INT_24XX_UART3_IRQ, },
593};
594
595static struct omap_hwmod_dma_info uart3_sdma_reqs[] = {
596 { .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, },
597 { .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, },
598};
599
600static struct omap_hwmod_ocp_if *omap3xxx_uart3_slaves[] = {
601 &omap3_l4_per__uart3,
602};
603
604static struct omap_hwmod omap3xxx_uart3_hwmod = {
605 .name = "uart3",
606 .mpu_irqs = uart3_mpu_irqs,
607 .mpu_irqs_cnt = ARRAY_SIZE(uart3_mpu_irqs),
608 .sdma_reqs = uart3_sdma_reqs,
609 .sdma_reqs_cnt = ARRAY_SIZE(uart3_sdma_reqs),
610 .main_clk = "uart3_fck",
611 .prcm = {
612 .omap2 = {
613 .module_offs = OMAP3430_PER_MOD,
614 .prcm_reg_id = 1,
615 .module_bit = OMAP3430_EN_UART3_SHIFT,
616 .idlest_reg_id = 1,
617 .idlest_idle_bit = OMAP3430_EN_UART3_SHIFT,
618 },
619 },
620 .slaves = omap3xxx_uart3_slaves,
621 .slaves_cnt = ARRAY_SIZE(omap3xxx_uart3_slaves),
622 .class = &uart_class,
623 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
624};
625
626/* UART4 */
627
628static struct omap_hwmod_irq_info uart4_mpu_irqs[] = {
629 { .irq = INT_36XX_UART4_IRQ, },
630};
631
632static struct omap_hwmod_dma_info uart4_sdma_reqs[] = {
633 { .name = "rx", .dma_req = OMAP36XX_DMA_UART4_RX, },
634 { .name = "tx", .dma_req = OMAP36XX_DMA_UART4_TX, },
635};
636
637static struct omap_hwmod_ocp_if *omap3xxx_uart4_slaves[] = {
638 &omap3_l4_per__uart4,
639};
640
641static struct omap_hwmod omap3xxx_uart4_hwmod = {
642 .name = "uart4",
643 .mpu_irqs = uart4_mpu_irqs,
644 .mpu_irqs_cnt = ARRAY_SIZE(uart4_mpu_irqs),
645 .sdma_reqs = uart4_sdma_reqs,
646 .sdma_reqs_cnt = ARRAY_SIZE(uart4_sdma_reqs),
647 .main_clk = "uart4_fck",
648 .prcm = {
649 .omap2 = {
650 .module_offs = OMAP3430_PER_MOD,
651 .prcm_reg_id = 1,
652 .module_bit = OMAP3630_EN_UART4_SHIFT,
653 .idlest_reg_id = 1,
654 .idlest_idle_bit = OMAP3630_EN_UART4_SHIFT,
655 },
656 },
657 .slaves = omap3xxx_uart4_slaves,
658 .slaves_cnt = ARRAY_SIZE(omap3xxx_uart4_slaves),
659 .class = &uart_class,
660 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3630ES1),
661};
662
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530663static struct omap_hwmod_class i2c_class = {
664 .name = "i2c",
665 .sysc = &i2c_sysc,
666};
667
668/* I2C1 */
669
670static struct omap_i2c_dev_attr i2c1_dev_attr = {
671 .fifo_depth = 8, /* bytes */
672};
673
674static struct omap_hwmod_irq_info i2c1_mpu_irqs[] = {
675 { .irq = INT_24XX_I2C1_IRQ, },
676};
677
678static struct omap_hwmod_dma_info i2c1_sdma_reqs[] = {
679 { .name = "tx", .dma_req = OMAP24XX_DMA_I2C1_TX },
680 { .name = "rx", .dma_req = OMAP24XX_DMA_I2C1_RX },
681};
682
683static struct omap_hwmod_ocp_if *omap3xxx_i2c1_slaves[] = {
684 &omap3_l4_core__i2c1,
685};
686
687static struct omap_hwmod omap3xxx_i2c1_hwmod = {
688 .name = "i2c1",
689 .mpu_irqs = i2c1_mpu_irqs,
690 .mpu_irqs_cnt = ARRAY_SIZE(i2c1_mpu_irqs),
691 .sdma_reqs = i2c1_sdma_reqs,
692 .sdma_reqs_cnt = ARRAY_SIZE(i2c1_sdma_reqs),
693 .main_clk = "i2c1_fck",
694 .prcm = {
695 .omap2 = {
696 .module_offs = CORE_MOD,
697 .prcm_reg_id = 1,
698 .module_bit = OMAP3430_EN_I2C1_SHIFT,
699 .idlest_reg_id = 1,
700 .idlest_idle_bit = OMAP3430_ST_I2C1_SHIFT,
701 },
702 },
703 .slaves = omap3xxx_i2c1_slaves,
704 .slaves_cnt = ARRAY_SIZE(omap3xxx_i2c1_slaves),
705 .class = &i2c_class,
706 .dev_attr = &i2c1_dev_attr,
707 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
708};
709
710/* I2C2 */
711
712static struct omap_i2c_dev_attr i2c2_dev_attr = {
713 .fifo_depth = 8, /* bytes */
714};
715
716static struct omap_hwmod_irq_info i2c2_mpu_irqs[] = {
717 { .irq = INT_24XX_I2C2_IRQ, },
718};
719
720static struct omap_hwmod_dma_info i2c2_sdma_reqs[] = {
721 { .name = "tx", .dma_req = OMAP24XX_DMA_I2C2_TX },
722 { .name = "rx", .dma_req = OMAP24XX_DMA_I2C2_RX },
723};
724
725static struct omap_hwmod_ocp_if *omap3xxx_i2c2_slaves[] = {
726 &omap3_l4_core__i2c2,
727};
728
729static struct omap_hwmod omap3xxx_i2c2_hwmod = {
730 .name = "i2c2",
731 .mpu_irqs = i2c2_mpu_irqs,
732 .mpu_irqs_cnt = ARRAY_SIZE(i2c2_mpu_irqs),
733 .sdma_reqs = i2c2_sdma_reqs,
734 .sdma_reqs_cnt = ARRAY_SIZE(i2c2_sdma_reqs),
735 .main_clk = "i2c2_fck",
736 .prcm = {
737 .omap2 = {
738 .module_offs = CORE_MOD,
739 .prcm_reg_id = 1,
740 .module_bit = OMAP3430_EN_I2C2_SHIFT,
741 .idlest_reg_id = 1,
742 .idlest_idle_bit = OMAP3430_ST_I2C2_SHIFT,
743 },
744 },
745 .slaves = omap3xxx_i2c2_slaves,
746 .slaves_cnt = ARRAY_SIZE(omap3xxx_i2c2_slaves),
747 .class = &i2c_class,
748 .dev_attr = &i2c2_dev_attr,
749 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
750};
751
752/* I2C3 */
753
754static struct omap_i2c_dev_attr i2c3_dev_attr = {
755 .fifo_depth = 64, /* bytes */
756};
757
758static struct omap_hwmod_irq_info i2c3_mpu_irqs[] = {
759 { .irq = INT_34XX_I2C3_IRQ, },
760};
761
762static struct omap_hwmod_dma_info i2c3_sdma_reqs[] = {
763 { .name = "tx", .dma_req = OMAP34XX_DMA_I2C3_TX },
764 { .name = "rx", .dma_req = OMAP34XX_DMA_I2C3_RX },
765};
766
767static struct omap_hwmod_ocp_if *omap3xxx_i2c3_slaves[] = {
768 &omap3_l4_core__i2c3,
769};
770
771static struct omap_hwmod omap3xxx_i2c3_hwmod = {
772 .name = "i2c3",
773 .mpu_irqs = i2c3_mpu_irqs,
774 .mpu_irqs_cnt = ARRAY_SIZE(i2c3_mpu_irqs),
775 .sdma_reqs = i2c3_sdma_reqs,
776 .sdma_reqs_cnt = ARRAY_SIZE(i2c3_sdma_reqs),
777 .main_clk = "i2c3_fck",
778 .prcm = {
779 .omap2 = {
780 .module_offs = CORE_MOD,
781 .prcm_reg_id = 1,
782 .module_bit = OMAP3430_EN_I2C3_SHIFT,
783 .idlest_reg_id = 1,
784 .idlest_idle_bit = OMAP3430_ST_I2C3_SHIFT,
785 },
786 },
787 .slaves = omap3xxx_i2c3_slaves,
788 .slaves_cnt = ARRAY_SIZE(omap3xxx_i2c3_slaves),
789 .class = &i2c_class,
790 .dev_attr = &i2c3_dev_attr,
791 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
792};
793
Varadarajan, Charulatha70034d32010-12-07 16:26:57 -0800794/* l4_wkup -> gpio1 */
795static struct omap_hwmod_addr_space omap3xxx_gpio1_addrs[] = {
796 {
797 .pa_start = 0x48310000,
798 .pa_end = 0x483101ff,
799 .flags = ADDR_TYPE_RT
800 },
801};
802
803static struct omap_hwmod_ocp_if omap3xxx_l4_wkup__gpio1 = {
804 .master = &omap3xxx_l4_wkup_hwmod,
805 .slave = &omap3xxx_gpio1_hwmod,
806 .addr = omap3xxx_gpio1_addrs,
807 .addr_cnt = ARRAY_SIZE(omap3xxx_gpio1_addrs),
808 .user = OCP_USER_MPU | OCP_USER_SDMA,
809};
810
811/* l4_per -> gpio2 */
812static struct omap_hwmod_addr_space omap3xxx_gpio2_addrs[] = {
813 {
814 .pa_start = 0x49050000,
815 .pa_end = 0x490501ff,
816 .flags = ADDR_TYPE_RT
817 },
818};
819
820static struct omap_hwmod_ocp_if omap3xxx_l4_per__gpio2 = {
821 .master = &omap3xxx_l4_per_hwmod,
822 .slave = &omap3xxx_gpio2_hwmod,
823 .addr = omap3xxx_gpio2_addrs,
824 .addr_cnt = ARRAY_SIZE(omap3xxx_gpio2_addrs),
825 .user = OCP_USER_MPU | OCP_USER_SDMA,
826};
827
828/* l4_per -> gpio3 */
829static struct omap_hwmod_addr_space omap3xxx_gpio3_addrs[] = {
830 {
831 .pa_start = 0x49052000,
832 .pa_end = 0x490521ff,
833 .flags = ADDR_TYPE_RT
834 },
835};
836
837static struct omap_hwmod_ocp_if omap3xxx_l4_per__gpio3 = {
838 .master = &omap3xxx_l4_per_hwmod,
839 .slave = &omap3xxx_gpio3_hwmod,
840 .addr = omap3xxx_gpio3_addrs,
841 .addr_cnt = ARRAY_SIZE(omap3xxx_gpio3_addrs),
842 .user = OCP_USER_MPU | OCP_USER_SDMA,
843};
844
845/* l4_per -> gpio4 */
846static struct omap_hwmod_addr_space omap3xxx_gpio4_addrs[] = {
847 {
848 .pa_start = 0x49054000,
849 .pa_end = 0x490541ff,
850 .flags = ADDR_TYPE_RT
851 },
852};
853
854static struct omap_hwmod_ocp_if omap3xxx_l4_per__gpio4 = {
855 .master = &omap3xxx_l4_per_hwmod,
856 .slave = &omap3xxx_gpio4_hwmod,
857 .addr = omap3xxx_gpio4_addrs,
858 .addr_cnt = ARRAY_SIZE(omap3xxx_gpio4_addrs),
859 .user = OCP_USER_MPU | OCP_USER_SDMA,
860};
861
862/* l4_per -> gpio5 */
863static struct omap_hwmod_addr_space omap3xxx_gpio5_addrs[] = {
864 {
865 .pa_start = 0x49056000,
866 .pa_end = 0x490561ff,
867 .flags = ADDR_TYPE_RT
868 },
869};
870
871static struct omap_hwmod_ocp_if omap3xxx_l4_per__gpio5 = {
872 .master = &omap3xxx_l4_per_hwmod,
873 .slave = &omap3xxx_gpio5_hwmod,
874 .addr = omap3xxx_gpio5_addrs,
875 .addr_cnt = ARRAY_SIZE(omap3xxx_gpio5_addrs),
876 .user = OCP_USER_MPU | OCP_USER_SDMA,
877};
878
879/* l4_per -> gpio6 */
880static struct omap_hwmod_addr_space omap3xxx_gpio6_addrs[] = {
881 {
882 .pa_start = 0x49058000,
883 .pa_end = 0x490581ff,
884 .flags = ADDR_TYPE_RT
885 },
886};
887
888static struct omap_hwmod_ocp_if omap3xxx_l4_per__gpio6 = {
889 .master = &omap3xxx_l4_per_hwmod,
890 .slave = &omap3xxx_gpio6_hwmod,
891 .addr = omap3xxx_gpio6_addrs,
892 .addr_cnt = ARRAY_SIZE(omap3xxx_gpio6_addrs),
893 .user = OCP_USER_MPU | OCP_USER_SDMA,
894};
895
896/*
897 * 'gpio' class
898 * general purpose io module
899 */
900
901static struct omap_hwmod_class_sysconfig omap3xxx_gpio_sysc = {
902 .rev_offs = 0x0000,
903 .sysc_offs = 0x0010,
904 .syss_offs = 0x0014,
905 .sysc_flags = (SYSC_HAS_ENAWAKEUP | SYSC_HAS_SIDLEMODE |
Avinash.H.Md73d65f2011-03-03 14:22:46 -0700906 SYSC_HAS_SOFTRESET | SYSC_HAS_AUTOIDLE |
907 SYSS_HAS_RESET_STATUS),
Varadarajan, Charulatha70034d32010-12-07 16:26:57 -0800908 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
909 .sysc_fields = &omap_hwmod_sysc_type1,
910};
911
912static struct omap_hwmod_class omap3xxx_gpio_hwmod_class = {
913 .name = "gpio",
914 .sysc = &omap3xxx_gpio_sysc,
915 .rev = 1,
916};
917
918/* gpio_dev_attr*/
919static struct omap_gpio_dev_attr gpio_dev_attr = {
920 .bank_width = 32,
921 .dbck_flag = true,
922};
923
924/* gpio1 */
925static struct omap_hwmod_irq_info omap3xxx_gpio1_irqs[] = {
926 { .irq = 29 }, /* INT_34XX_GPIO_BANK1 */
927};
928
929static struct omap_hwmod_opt_clk gpio1_opt_clks[] = {
930 { .role = "dbclk", .clk = "gpio1_dbck", },
931};
932
933static struct omap_hwmod_ocp_if *omap3xxx_gpio1_slaves[] = {
934 &omap3xxx_l4_wkup__gpio1,
935};
936
937static struct omap_hwmod omap3xxx_gpio1_hwmod = {
938 .name = "gpio1",
939 .mpu_irqs = omap3xxx_gpio1_irqs,
940 .mpu_irqs_cnt = ARRAY_SIZE(omap3xxx_gpio1_irqs),
941 .main_clk = "gpio1_ick",
942 .opt_clks = gpio1_opt_clks,
943 .opt_clks_cnt = ARRAY_SIZE(gpio1_opt_clks),
944 .prcm = {
945 .omap2 = {
946 .prcm_reg_id = 1,
947 .module_bit = OMAP3430_EN_GPIO1_SHIFT,
948 .module_offs = WKUP_MOD,
949 .idlest_reg_id = 1,
950 .idlest_idle_bit = OMAP3430_ST_GPIO1_SHIFT,
951 },
952 },
953 .slaves = omap3xxx_gpio1_slaves,
954 .slaves_cnt = ARRAY_SIZE(omap3xxx_gpio1_slaves),
955 .class = &omap3xxx_gpio_hwmod_class,
956 .dev_attr = &gpio_dev_attr,
957 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
958};
959
960/* gpio2 */
961static struct omap_hwmod_irq_info omap3xxx_gpio2_irqs[] = {
962 { .irq = 30 }, /* INT_34XX_GPIO_BANK2 */
963};
964
965static struct omap_hwmod_opt_clk gpio2_opt_clks[] = {
966 { .role = "dbclk", .clk = "gpio2_dbck", },
967};
968
969static struct omap_hwmod_ocp_if *omap3xxx_gpio2_slaves[] = {
970 &omap3xxx_l4_per__gpio2,
971};
972
973static struct omap_hwmod omap3xxx_gpio2_hwmod = {
974 .name = "gpio2",
975 .mpu_irqs = omap3xxx_gpio2_irqs,
976 .mpu_irqs_cnt = ARRAY_SIZE(omap3xxx_gpio2_irqs),
977 .main_clk = "gpio2_ick",
978 .opt_clks = gpio2_opt_clks,
979 .opt_clks_cnt = ARRAY_SIZE(gpio2_opt_clks),
980 .prcm = {
981 .omap2 = {
982 .prcm_reg_id = 1,
983 .module_bit = OMAP3430_EN_GPIO2_SHIFT,
984 .module_offs = OMAP3430_PER_MOD,
985 .idlest_reg_id = 1,
986 .idlest_idle_bit = OMAP3430_ST_GPIO2_SHIFT,
987 },
988 },
989 .slaves = omap3xxx_gpio2_slaves,
990 .slaves_cnt = ARRAY_SIZE(omap3xxx_gpio2_slaves),
991 .class = &omap3xxx_gpio_hwmod_class,
992 .dev_attr = &gpio_dev_attr,
993 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
994};
995
996/* gpio3 */
997static struct omap_hwmod_irq_info omap3xxx_gpio3_irqs[] = {
998 { .irq = 31 }, /* INT_34XX_GPIO_BANK3 */
999};
1000
1001static struct omap_hwmod_opt_clk gpio3_opt_clks[] = {
1002 { .role = "dbclk", .clk = "gpio3_dbck", },
1003};
1004
1005static struct omap_hwmod_ocp_if *omap3xxx_gpio3_slaves[] = {
1006 &omap3xxx_l4_per__gpio3,
1007};
1008
1009static struct omap_hwmod omap3xxx_gpio3_hwmod = {
1010 .name = "gpio3",
1011 .mpu_irqs = omap3xxx_gpio3_irqs,
1012 .mpu_irqs_cnt = ARRAY_SIZE(omap3xxx_gpio3_irqs),
1013 .main_clk = "gpio3_ick",
1014 .opt_clks = gpio3_opt_clks,
1015 .opt_clks_cnt = ARRAY_SIZE(gpio3_opt_clks),
1016 .prcm = {
1017 .omap2 = {
1018 .prcm_reg_id = 1,
1019 .module_bit = OMAP3430_EN_GPIO3_SHIFT,
1020 .module_offs = OMAP3430_PER_MOD,
1021 .idlest_reg_id = 1,
1022 .idlest_idle_bit = OMAP3430_ST_GPIO3_SHIFT,
1023 },
1024 },
1025 .slaves = omap3xxx_gpio3_slaves,
1026 .slaves_cnt = ARRAY_SIZE(omap3xxx_gpio3_slaves),
1027 .class = &omap3xxx_gpio_hwmod_class,
1028 .dev_attr = &gpio_dev_attr,
1029 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
1030};
1031
1032/* gpio4 */
1033static struct omap_hwmod_irq_info omap3xxx_gpio4_irqs[] = {
1034 { .irq = 32 }, /* INT_34XX_GPIO_BANK4 */
1035};
1036
1037static struct omap_hwmod_opt_clk gpio4_opt_clks[] = {
1038 { .role = "dbclk", .clk = "gpio4_dbck", },
1039};
1040
1041static struct omap_hwmod_ocp_if *omap3xxx_gpio4_slaves[] = {
1042 &omap3xxx_l4_per__gpio4,
1043};
1044
1045static struct omap_hwmod omap3xxx_gpio4_hwmod = {
1046 .name = "gpio4",
1047 .mpu_irqs = omap3xxx_gpio4_irqs,
1048 .mpu_irqs_cnt = ARRAY_SIZE(omap3xxx_gpio4_irqs),
1049 .main_clk = "gpio4_ick",
1050 .opt_clks = gpio4_opt_clks,
1051 .opt_clks_cnt = ARRAY_SIZE(gpio4_opt_clks),
1052 .prcm = {
1053 .omap2 = {
1054 .prcm_reg_id = 1,
1055 .module_bit = OMAP3430_EN_GPIO4_SHIFT,
1056 .module_offs = OMAP3430_PER_MOD,
1057 .idlest_reg_id = 1,
1058 .idlest_idle_bit = OMAP3430_ST_GPIO4_SHIFT,
1059 },
1060 },
1061 .slaves = omap3xxx_gpio4_slaves,
1062 .slaves_cnt = ARRAY_SIZE(omap3xxx_gpio4_slaves),
1063 .class = &omap3xxx_gpio_hwmod_class,
1064 .dev_attr = &gpio_dev_attr,
1065 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
1066};
1067
1068/* gpio5 */
1069static struct omap_hwmod_irq_info omap3xxx_gpio5_irqs[] = {
1070 { .irq = 33 }, /* INT_34XX_GPIO_BANK5 */
1071};
1072
1073static struct omap_hwmod_opt_clk gpio5_opt_clks[] = {
1074 { .role = "dbclk", .clk = "gpio5_dbck", },
1075};
1076
1077static struct omap_hwmod_ocp_if *omap3xxx_gpio5_slaves[] = {
1078 &omap3xxx_l4_per__gpio5,
1079};
1080
1081static struct omap_hwmod omap3xxx_gpio5_hwmod = {
1082 .name = "gpio5",
1083 .mpu_irqs = omap3xxx_gpio5_irqs,
1084 .mpu_irqs_cnt = ARRAY_SIZE(omap3xxx_gpio5_irqs),
1085 .main_clk = "gpio5_ick",
1086 .opt_clks = gpio5_opt_clks,
1087 .opt_clks_cnt = ARRAY_SIZE(gpio5_opt_clks),
1088 .prcm = {
1089 .omap2 = {
1090 .prcm_reg_id = 1,
1091 .module_bit = OMAP3430_EN_GPIO5_SHIFT,
1092 .module_offs = OMAP3430_PER_MOD,
1093 .idlest_reg_id = 1,
1094 .idlest_idle_bit = OMAP3430_ST_GPIO5_SHIFT,
1095 },
1096 },
1097 .slaves = omap3xxx_gpio5_slaves,
1098 .slaves_cnt = ARRAY_SIZE(omap3xxx_gpio5_slaves),
1099 .class = &omap3xxx_gpio_hwmod_class,
1100 .dev_attr = &gpio_dev_attr,
1101 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
1102};
1103
1104/* gpio6 */
1105static struct omap_hwmod_irq_info omap3xxx_gpio6_irqs[] = {
1106 { .irq = 34 }, /* INT_34XX_GPIO_BANK6 */
1107};
1108
1109static struct omap_hwmod_opt_clk gpio6_opt_clks[] = {
1110 { .role = "dbclk", .clk = "gpio6_dbck", },
1111};
1112
1113static struct omap_hwmod_ocp_if *omap3xxx_gpio6_slaves[] = {
1114 &omap3xxx_l4_per__gpio6,
1115};
1116
1117static struct omap_hwmod omap3xxx_gpio6_hwmod = {
1118 .name = "gpio6",
1119 .mpu_irqs = omap3xxx_gpio6_irqs,
1120 .mpu_irqs_cnt = ARRAY_SIZE(omap3xxx_gpio6_irqs),
1121 .main_clk = "gpio6_ick",
1122 .opt_clks = gpio6_opt_clks,
1123 .opt_clks_cnt = ARRAY_SIZE(gpio6_opt_clks),
1124 .prcm = {
1125 .omap2 = {
1126 .prcm_reg_id = 1,
1127 .module_bit = OMAP3430_EN_GPIO6_SHIFT,
1128 .module_offs = OMAP3430_PER_MOD,
1129 .idlest_reg_id = 1,
1130 .idlest_idle_bit = OMAP3430_ST_GPIO6_SHIFT,
1131 },
1132 },
1133 .slaves = omap3xxx_gpio6_slaves,
1134 .slaves_cnt = ARRAY_SIZE(omap3xxx_gpio6_slaves),
1135 .class = &omap3xxx_gpio_hwmod_class,
1136 .dev_attr = &gpio_dev_attr,
1137 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
1138};
1139
G, Manjunath Kondaiah01438ab2010-12-20 18:27:19 -08001140/* dma_system -> L3 */
1141static struct omap_hwmod_ocp_if omap3xxx_dma_system__l3 = {
1142 .master = &omap3xxx_dma_system_hwmod,
1143 .slave = &omap3xxx_l3_main_hwmod,
1144 .clk = "core_l3_ick",
1145 .user = OCP_USER_MPU | OCP_USER_SDMA,
1146};
1147
1148/* dma attributes */
1149static struct omap_dma_dev_attr dma_dev_attr = {
1150 .dev_caps = RESERVE_CHANNEL | DMA_LINKED_LCH | GLOBAL_PRIORITY |
1151 IS_CSSA_32 | IS_CDSA_32 | IS_RW_PRIORITY,
1152 .lch_count = 32,
1153};
1154
1155static struct omap_hwmod_class_sysconfig omap3xxx_dma_sysc = {
1156 .rev_offs = 0x0000,
1157 .sysc_offs = 0x002c,
1158 .syss_offs = 0x0028,
1159 .sysc_flags = (SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
1160 SYSC_HAS_MIDLEMODE | SYSC_HAS_CLOCKACTIVITY |
Avinash.H.Md73d65f2011-03-03 14:22:46 -07001161 SYSC_HAS_EMUFREE | SYSC_HAS_AUTOIDLE |
1162 SYSS_HAS_RESET_STATUS),
G, Manjunath Kondaiah01438ab2010-12-20 18:27:19 -08001163 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1164 MSTANDBY_FORCE | MSTANDBY_NO | MSTANDBY_SMART),
1165 .sysc_fields = &omap_hwmod_sysc_type1,
1166};
1167
1168static struct omap_hwmod_class omap3xxx_dma_hwmod_class = {
1169 .name = "dma",
1170 .sysc = &omap3xxx_dma_sysc,
1171};
1172
1173/* dma_system */
1174static struct omap_hwmod_irq_info omap3xxx_dma_system_irqs[] = {
1175 { .name = "0", .irq = 12 }, /* INT_24XX_SDMA_IRQ0 */
1176 { .name = "1", .irq = 13 }, /* INT_24XX_SDMA_IRQ1 */
1177 { .name = "2", .irq = 14 }, /* INT_24XX_SDMA_IRQ2 */
1178 { .name = "3", .irq = 15 }, /* INT_24XX_SDMA_IRQ3 */
1179};
1180
1181static struct omap_hwmod_addr_space omap3xxx_dma_system_addrs[] = {
1182 {
1183 .pa_start = 0x48056000,
1184 .pa_end = 0x4a0560ff,
1185 .flags = ADDR_TYPE_RT
1186 },
1187};
1188
1189/* dma_system master ports */
1190static struct omap_hwmod_ocp_if *omap3xxx_dma_system_masters[] = {
1191 &omap3xxx_dma_system__l3,
1192};
1193
1194/* l4_cfg -> dma_system */
1195static struct omap_hwmod_ocp_if omap3xxx_l4_core__dma_system = {
1196 .master = &omap3xxx_l4_core_hwmod,
1197 .slave = &omap3xxx_dma_system_hwmod,
1198 .clk = "core_l4_ick",
1199 .addr = omap3xxx_dma_system_addrs,
1200 .addr_cnt = ARRAY_SIZE(omap3xxx_dma_system_addrs),
1201 .user = OCP_USER_MPU | OCP_USER_SDMA,
1202};
1203
1204/* dma_system slave ports */
1205static struct omap_hwmod_ocp_if *omap3xxx_dma_system_slaves[] = {
1206 &omap3xxx_l4_core__dma_system,
1207};
1208
1209static struct omap_hwmod omap3xxx_dma_system_hwmod = {
1210 .name = "dma",
1211 .class = &omap3xxx_dma_hwmod_class,
1212 .mpu_irqs = omap3xxx_dma_system_irqs,
1213 .mpu_irqs_cnt = ARRAY_SIZE(omap3xxx_dma_system_irqs),
1214 .main_clk = "core_l3_ick",
1215 .prcm = {
1216 .omap2 = {
1217 .module_offs = CORE_MOD,
1218 .prcm_reg_id = 1,
1219 .module_bit = OMAP3430_ST_SDMA_SHIFT,
1220 .idlest_reg_id = 1,
1221 .idlest_idle_bit = OMAP3430_ST_SDMA_SHIFT,
1222 },
1223 },
1224 .slaves = omap3xxx_dma_system_slaves,
1225 .slaves_cnt = ARRAY_SIZE(omap3xxx_dma_system_slaves),
1226 .masters = omap3xxx_dma_system_masters,
1227 .masters_cnt = ARRAY_SIZE(omap3xxx_dma_system_masters),
1228 .dev_attr = &dma_dev_attr,
1229 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430),
1230 .flags = HWMOD_NO_IDLEST,
1231};
1232
Thara Gopinathd3442722010-05-29 22:02:24 +05301233/* SR common */
1234static struct omap_hwmod_sysc_fields omap34xx_sr_sysc_fields = {
1235 .clkact_shift = 20,
1236};
1237
1238static struct omap_hwmod_class_sysconfig omap34xx_sr_sysc = {
1239 .sysc_offs = 0x24,
1240 .sysc_flags = (SYSC_HAS_CLOCKACTIVITY | SYSC_NO_CACHE),
1241 .clockact = CLOCKACT_TEST_ICLK,
1242 .sysc_fields = &omap34xx_sr_sysc_fields,
1243};
1244
1245static struct omap_hwmod_class omap34xx_smartreflex_hwmod_class = {
1246 .name = "smartreflex",
1247 .sysc = &omap34xx_sr_sysc,
1248 .rev = 1,
1249};
1250
1251static struct omap_hwmod_sysc_fields omap36xx_sr_sysc_fields = {
1252 .sidle_shift = 24,
1253 .enwkup_shift = 26
1254};
1255
1256static struct omap_hwmod_class_sysconfig omap36xx_sr_sysc = {
1257 .sysc_offs = 0x38,
1258 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
1259 .sysc_flags = (SYSC_HAS_SIDLEMODE | SYSC_HAS_ENAWAKEUP |
1260 SYSC_NO_CACHE),
1261 .sysc_fields = &omap36xx_sr_sysc_fields,
1262};
1263
1264static struct omap_hwmod_class omap36xx_smartreflex_hwmod_class = {
1265 .name = "smartreflex",
1266 .sysc = &omap36xx_sr_sysc,
1267 .rev = 2,
1268};
1269
1270/* SR1 */
1271static struct omap_hwmod_ocp_if *omap3_sr1_slaves[] = {
1272 &omap3_l4_core__sr1,
1273};
1274
1275static struct omap_hwmod omap34xx_sr1_hwmod = {
1276 .name = "sr1_hwmod",
1277 .class = &omap34xx_smartreflex_hwmod_class,
1278 .main_clk = "sr1_fck",
1279 .vdd_name = "mpu",
1280 .prcm = {
1281 .omap2 = {
1282 .prcm_reg_id = 1,
1283 .module_bit = OMAP3430_EN_SR1_SHIFT,
1284 .module_offs = WKUP_MOD,
1285 .idlest_reg_id = 1,
1286 .idlest_idle_bit = OMAP3430_EN_SR1_SHIFT,
1287 },
1288 },
1289 .slaves = omap3_sr1_slaves,
1290 .slaves_cnt = ARRAY_SIZE(omap3_sr1_slaves),
1291 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430ES2 |
1292 CHIP_IS_OMAP3430ES3_0 |
1293 CHIP_IS_OMAP3430ES3_1),
1294 .flags = HWMOD_SET_DEFAULT_CLOCKACT,
1295};
1296
1297static struct omap_hwmod omap36xx_sr1_hwmod = {
1298 .name = "sr1_hwmod",
1299 .class = &omap36xx_smartreflex_hwmod_class,
1300 .main_clk = "sr1_fck",
1301 .vdd_name = "mpu",
1302 .prcm = {
1303 .omap2 = {
1304 .prcm_reg_id = 1,
1305 .module_bit = OMAP3430_EN_SR1_SHIFT,
1306 .module_offs = WKUP_MOD,
1307 .idlest_reg_id = 1,
1308 .idlest_idle_bit = OMAP3430_EN_SR1_SHIFT,
1309 },
1310 },
1311 .slaves = omap3_sr1_slaves,
1312 .slaves_cnt = ARRAY_SIZE(omap3_sr1_slaves),
1313 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3630ES1),
1314};
1315
1316/* SR2 */
1317static struct omap_hwmod_ocp_if *omap3_sr2_slaves[] = {
1318 &omap3_l4_core__sr2,
1319};
1320
1321static struct omap_hwmod omap34xx_sr2_hwmod = {
1322 .name = "sr2_hwmod",
1323 .class = &omap34xx_smartreflex_hwmod_class,
1324 .main_clk = "sr2_fck",
1325 .vdd_name = "core",
1326 .prcm = {
1327 .omap2 = {
1328 .prcm_reg_id = 1,
1329 .module_bit = OMAP3430_EN_SR2_SHIFT,
1330 .module_offs = WKUP_MOD,
1331 .idlest_reg_id = 1,
1332 .idlest_idle_bit = OMAP3430_EN_SR2_SHIFT,
1333 },
1334 },
1335 .slaves = omap3_sr2_slaves,
1336 .slaves_cnt = ARRAY_SIZE(omap3_sr2_slaves),
1337 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3430ES2 |
1338 CHIP_IS_OMAP3430ES3_0 |
1339 CHIP_IS_OMAP3430ES3_1),
1340 .flags = HWMOD_SET_DEFAULT_CLOCKACT,
1341};
1342
1343static struct omap_hwmod omap36xx_sr2_hwmod = {
1344 .name = "sr2_hwmod",
1345 .class = &omap36xx_smartreflex_hwmod_class,
1346 .main_clk = "sr2_fck",
1347 .vdd_name = "core",
1348 .prcm = {
1349 .omap2 = {
1350 .prcm_reg_id = 1,
1351 .module_bit = OMAP3430_EN_SR2_SHIFT,
1352 .module_offs = WKUP_MOD,
1353 .idlest_reg_id = 1,
1354 .idlest_idle_bit = OMAP3430_EN_SR2_SHIFT,
1355 },
1356 },
1357 .slaves = omap3_sr2_slaves,
1358 .slaves_cnt = ARRAY_SIZE(omap3_sr2_slaves),
1359 .omap_chip = OMAP_CHIP_INIT(CHIP_IS_OMAP3630ES1),
1360};
1361
Paul Walmsley73591542010-02-22 22:09:32 -07001362static __initdata struct omap_hwmod *omap3xxx_hwmods[] = {
Kevin Hilman4a7cf902010-07-26 16:34:32 -06001363 &omap3xxx_l3_main_hwmod,
Paul Walmsley73591542010-02-22 22:09:32 -07001364 &omap3xxx_l4_core_hwmod,
1365 &omap3xxx_l4_per_hwmod,
1366 &omap3xxx_l4_wkup_hwmod,
1367 &omap3xxx_mpu_hwmod,
Kevin Hilman540064b2010-07-26 16:34:32 -06001368 &omap3xxx_iva_hwmod,
Varadarajan, Charulatha6b667f82010-09-23 20:02:38 +05301369 &omap3xxx_wd_timer2_hwmod,
Kevin Hilman046465b2010-09-27 20:19:30 +05301370 &omap3xxx_uart1_hwmod,
1371 &omap3xxx_uart2_hwmod,
1372 &omap3xxx_uart3_hwmod,
1373 &omap3xxx_uart4_hwmod,
Rajendra Nayak4fe20e92010-09-21 19:37:13 +05301374 &omap3xxx_i2c1_hwmod,
1375 &omap3xxx_i2c2_hwmod,
1376 &omap3xxx_i2c3_hwmod,
Thara Gopinathd3442722010-05-29 22:02:24 +05301377 &omap34xx_sr1_hwmod,
1378 &omap34xx_sr2_hwmod,
1379 &omap36xx_sr1_hwmod,
1380 &omap36xx_sr2_hwmod,
1381
Varadarajan, Charulatha70034d32010-12-07 16:26:57 -08001382
1383 /* gpio class */
1384 &omap3xxx_gpio1_hwmod,
1385 &omap3xxx_gpio2_hwmod,
1386 &omap3xxx_gpio3_hwmod,
1387 &omap3xxx_gpio4_hwmod,
1388 &omap3xxx_gpio5_hwmod,
1389 &omap3xxx_gpio6_hwmod,
G, Manjunath Kondaiah01438ab2010-12-20 18:27:19 -08001390
1391 /* dma_system class*/
1392 &omap3xxx_dma_system_hwmod,
Paul Walmsley73591542010-02-22 22:09:32 -07001393 NULL,
1394};
1395
1396int __init omap3xxx_hwmod_init(void)
1397{
1398 return omap_hwmod_init(omap3xxx_hwmods);
1399}