blob: 6cf7b6ff154f927ad79f482fc9f94d0351406ec0 [file] [log] [blame]
Ambresh K90020c72013-07-09 13:02:16 +05301/*
2 * Hardware modules present on the DRA7xx chips
3 *
4 * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com
5 *
6 * Paul Walmsley
7 * Benoit Cousson
8 *
9 * This file is automatically generated from the OMAP hardware databases.
10 * We respectfully ask that any modifications to this file be coordinated
11 * with the public linux-omap@vger.kernel.org mailing list and the
12 * authors above to ensure that the autogeneration scripts are kept
13 * up-to-date with the file contents.
14 *
15 * This program is free software; you can redistribute it and/or modify
16 * it under the terms of the GNU General Public License version 2 as
17 * published by the Free Software Foundation.
18 */
19
20#include <linux/io.h>
21#include <linux/platform_data/gpio-omap.h>
22#include <linux/power/smartreflex.h>
23#include <linux/i2c-omap.h>
24
25#include <linux/omap-dma.h>
26#include <linux/platform_data/spi-omap2-mcspi.h>
27#include <linux/platform_data/asoc-ti-mcbsp.h>
28#include <plat/dmtimer.h>
29
30#include "omap_hwmod.h"
31#include "omap_hwmod_common_data.h"
32#include "cm1_7xx.h"
33#include "cm2_7xx.h"
34#include "prm7xx.h"
35#include "i2c.h"
36#include "mmc.h"
37#include "wd_timer.h"
38
39/* Base offset for all DRA7XX interrupts external to MPUSS */
40#define DRA7XX_IRQ_GIC_START 32
41
42/* Base offset for all DRA7XX dma requests */
43#define DRA7XX_DMA_REQ_START 1
44
45
46/*
47 * IP blocks
48 */
49
50/*
51 * 'l3' class
52 * instance(s): l3_instr, l3_main_1, l3_main_2
53 */
54static struct omap_hwmod_class dra7xx_l3_hwmod_class = {
55 .name = "l3",
56};
57
58/* l3_instr */
59static struct omap_hwmod dra7xx_l3_instr_hwmod = {
60 .name = "l3_instr",
61 .class = &dra7xx_l3_hwmod_class,
62 .clkdm_name = "l3instr_clkdm",
63 .prcm = {
64 .omap4 = {
65 .clkctrl_offs = DRA7XX_CM_L3INSTR_L3_INSTR_CLKCTRL_OFFSET,
66 .context_offs = DRA7XX_RM_L3INSTR_L3_INSTR_CONTEXT_OFFSET,
67 .modulemode = MODULEMODE_HWCTRL,
68 },
69 },
70};
71
72/* l3_main_1 */
73static struct omap_hwmod dra7xx_l3_main_1_hwmod = {
74 .name = "l3_main_1",
75 .class = &dra7xx_l3_hwmod_class,
76 .clkdm_name = "l3main1_clkdm",
77 .prcm = {
78 .omap4 = {
79 .clkctrl_offs = DRA7XX_CM_L3MAIN1_L3_MAIN_1_CLKCTRL_OFFSET,
80 .context_offs = DRA7XX_RM_L3MAIN1_L3_MAIN_1_CONTEXT_OFFSET,
81 },
82 },
83};
84
85/* l3_main_2 */
86static struct omap_hwmod dra7xx_l3_main_2_hwmod = {
87 .name = "l3_main_2",
88 .class = &dra7xx_l3_hwmod_class,
89 .clkdm_name = "l3instr_clkdm",
90 .prcm = {
91 .omap4 = {
92 .clkctrl_offs = DRA7XX_CM_L3INSTR_L3_MAIN_2_CLKCTRL_OFFSET,
93 .context_offs = DRA7XX_RM_L3INSTR_L3_MAIN_2_CONTEXT_OFFSET,
94 .modulemode = MODULEMODE_HWCTRL,
95 },
96 },
97};
98
99/*
100 * 'l4' class
101 * instance(s): l4_cfg, l4_per1, l4_per2, l4_per3, l4_wkup
102 */
103static struct omap_hwmod_class dra7xx_l4_hwmod_class = {
104 .name = "l4",
105};
106
107/* l4_cfg */
108static struct omap_hwmod dra7xx_l4_cfg_hwmod = {
109 .name = "l4_cfg",
110 .class = &dra7xx_l4_hwmod_class,
111 .clkdm_name = "l4cfg_clkdm",
112 .prcm = {
113 .omap4 = {
114 .clkctrl_offs = DRA7XX_CM_L4CFG_L4_CFG_CLKCTRL_OFFSET,
115 .context_offs = DRA7XX_RM_L4CFG_L4_CFG_CONTEXT_OFFSET,
116 },
117 },
118};
119
120/* l4_per1 */
121static struct omap_hwmod dra7xx_l4_per1_hwmod = {
122 .name = "l4_per1",
123 .class = &dra7xx_l4_hwmod_class,
124 .clkdm_name = "l4per_clkdm",
125 .prcm = {
126 .omap4 = {
127 .clkctrl_offs = DRA7XX_CM_L4PER_L4_PER1_CLKCTRL_OFFSET,
128 .flags = HWMOD_OMAP4_NO_CONTEXT_LOSS_BIT,
129 },
130 },
131};
132
133/* l4_per2 */
134static struct omap_hwmod dra7xx_l4_per2_hwmod = {
135 .name = "l4_per2",
136 .class = &dra7xx_l4_hwmod_class,
137 .clkdm_name = "l4per2_clkdm",
138 .prcm = {
139 .omap4 = {
140 .clkctrl_offs = DRA7XX_CM_L4PER2_L4_PER2_CLKCTRL_OFFSET,
141 .flags = HWMOD_OMAP4_NO_CONTEXT_LOSS_BIT,
142 },
143 },
144};
145
146/* l4_per3 */
147static struct omap_hwmod dra7xx_l4_per3_hwmod = {
148 .name = "l4_per3",
149 .class = &dra7xx_l4_hwmod_class,
150 .clkdm_name = "l4per3_clkdm",
151 .prcm = {
152 .omap4 = {
153 .clkctrl_offs = DRA7XX_CM_L4PER3_L4_PER3_CLKCTRL_OFFSET,
154 .flags = HWMOD_OMAP4_NO_CONTEXT_LOSS_BIT,
155 },
156 },
157};
158
159/* l4_wkup */
160static struct omap_hwmod dra7xx_l4_wkup_hwmod = {
161 .name = "l4_wkup",
162 .class = &dra7xx_l4_hwmod_class,
163 .clkdm_name = "wkupaon_clkdm",
164 .prcm = {
165 .omap4 = {
166 .clkctrl_offs = DRA7XX_CM_WKUPAON_L4_WKUP_CLKCTRL_OFFSET,
167 .context_offs = DRA7XX_RM_WKUPAON_L4_WKUP_CONTEXT_OFFSET,
168 },
169 },
170};
171
172/*
173 * 'atl' class
174 *
175 */
176
177static struct omap_hwmod_class dra7xx_atl_hwmod_class = {
178 .name = "atl",
179};
180
181/* atl */
182static struct omap_hwmod dra7xx_atl_hwmod = {
183 .name = "atl",
184 .class = &dra7xx_atl_hwmod_class,
185 .clkdm_name = "atl_clkdm",
186 .main_clk = "atl_gfclk_mux",
187 .prcm = {
188 .omap4 = {
189 .clkctrl_offs = DRA7XX_CM_ATL_ATL_CLKCTRL_OFFSET,
190 .context_offs = DRA7XX_RM_ATL_ATL_CONTEXT_OFFSET,
191 .modulemode = MODULEMODE_SWCTRL,
192 },
193 },
194};
195
196/*
197 * 'bb2d' class
198 *
199 */
200
201static struct omap_hwmod_class dra7xx_bb2d_hwmod_class = {
202 .name = "bb2d",
203};
204
205/* bb2d */
206static struct omap_hwmod dra7xx_bb2d_hwmod = {
207 .name = "bb2d",
208 .class = &dra7xx_bb2d_hwmod_class,
209 .clkdm_name = "dss_clkdm",
210 .main_clk = "dpll_core_h24x2_ck",
211 .prcm = {
212 .omap4 = {
213 .clkctrl_offs = DRA7XX_CM_DSS_BB2D_CLKCTRL_OFFSET,
214 .context_offs = DRA7XX_RM_DSS_BB2D_CONTEXT_OFFSET,
215 .modulemode = MODULEMODE_SWCTRL,
216 },
217 },
218};
219
220/*
221 * 'counter' class
222 *
223 */
224
225static struct omap_hwmod_class_sysconfig dra7xx_counter_sysc = {
226 .rev_offs = 0x0000,
227 .sysc_offs = 0x0010,
228 .sysc_flags = SYSC_HAS_SIDLEMODE,
229 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
230 SIDLE_SMART_WKUP),
231 .sysc_fields = &omap_hwmod_sysc_type1,
232};
233
234static struct omap_hwmod_class dra7xx_counter_hwmod_class = {
235 .name = "counter",
236 .sysc = &dra7xx_counter_sysc,
237};
238
239/* counter_32k */
240static struct omap_hwmod dra7xx_counter_32k_hwmod = {
241 .name = "counter_32k",
242 .class = &dra7xx_counter_hwmod_class,
243 .clkdm_name = "wkupaon_clkdm",
244 .flags = HWMOD_SWSUP_SIDLE,
245 .main_clk = "wkupaon_iclk_mux",
246 .prcm = {
247 .omap4 = {
248 .clkctrl_offs = DRA7XX_CM_WKUPAON_COUNTER_32K_CLKCTRL_OFFSET,
249 .context_offs = DRA7XX_RM_WKUPAON_COUNTER_32K_CONTEXT_OFFSET,
250 },
251 },
252};
253
254/*
255 * 'ctrl_module' class
256 *
257 */
258
259static struct omap_hwmod_class dra7xx_ctrl_module_hwmod_class = {
260 .name = "ctrl_module",
261};
262
263/* ctrl_module_wkup */
264static struct omap_hwmod dra7xx_ctrl_module_wkup_hwmod = {
265 .name = "ctrl_module_wkup",
266 .class = &dra7xx_ctrl_module_hwmod_class,
267 .clkdm_name = "wkupaon_clkdm",
268 .prcm = {
269 .omap4 = {
270 .flags = HWMOD_OMAP4_NO_CONTEXT_LOSS_BIT,
271 },
272 },
273};
274
275/*
Mugunthan V N077c42f2014-07-08 18:46:39 +0530276 * 'gmac' class
277 * cpsw/gmac sub system
278 */
279static struct omap_hwmod_class_sysconfig dra7xx_gmac_sysc = {
280 .rev_offs = 0x0,
281 .sysc_offs = 0x8,
282 .syss_offs = 0x4,
283 .sysc_flags = (SYSC_HAS_SIDLEMODE | SYSC_HAS_MIDLEMODE |
284 SYSS_HAS_RESET_STATUS),
285 .idlemodes = (SIDLE_FORCE | SIDLE_NO | MSTANDBY_FORCE |
286 MSTANDBY_NO),
287 .sysc_fields = &omap_hwmod_sysc_type3,
288};
289
290static struct omap_hwmod_class dra7xx_gmac_hwmod_class = {
291 .name = "gmac",
292 .sysc = &dra7xx_gmac_sysc,
293};
294
295static struct omap_hwmod dra7xx_gmac_hwmod = {
296 .name = "gmac",
297 .class = &dra7xx_gmac_hwmod_class,
298 .clkdm_name = "gmac_clkdm",
299 .flags = (HWMOD_SWSUP_SIDLE | HWMOD_SWSUP_MSTANDBY),
300 .main_clk = "dpll_gmac_ck",
301 .mpu_rt_idx = 1,
302 .prcm = {
303 .omap4 = {
304 .clkctrl_offs = DRA7XX_CM_GMAC_GMAC_CLKCTRL_OFFSET,
305 .context_offs = DRA7XX_RM_GMAC_GMAC_CONTEXT_OFFSET,
306 .modulemode = MODULEMODE_SWCTRL,
307 },
308 },
309};
310
311/*
312 * 'mdio' class
313 */
314static struct omap_hwmod_class dra7xx_mdio_hwmod_class = {
315 .name = "davinci_mdio",
316};
317
318static struct omap_hwmod dra7xx_mdio_hwmod = {
319 .name = "davinci_mdio",
320 .class = &dra7xx_mdio_hwmod_class,
321 .clkdm_name = "gmac_clkdm",
322 .main_clk = "dpll_gmac_ck",
323};
324
325/*
Ambresh K90020c72013-07-09 13:02:16 +0530326 * 'dcan' class
327 *
328 */
329
330static struct omap_hwmod_class dra7xx_dcan_hwmod_class = {
331 .name = "dcan",
332};
333
334/* dcan1 */
335static struct omap_hwmod dra7xx_dcan1_hwmod = {
336 .name = "dcan1",
337 .class = &dra7xx_dcan_hwmod_class,
338 .clkdm_name = "wkupaon_clkdm",
339 .main_clk = "dcan1_sys_clk_mux",
340 .prcm = {
341 .omap4 = {
342 .clkctrl_offs = DRA7XX_CM_WKUPAON_DCAN1_CLKCTRL_OFFSET,
343 .context_offs = DRA7XX_RM_WKUPAON_DCAN1_CONTEXT_OFFSET,
344 .modulemode = MODULEMODE_SWCTRL,
345 },
346 },
347};
348
349/* dcan2 */
350static struct omap_hwmod dra7xx_dcan2_hwmod = {
351 .name = "dcan2",
352 .class = &dra7xx_dcan_hwmod_class,
353 .clkdm_name = "l4per2_clkdm",
354 .main_clk = "sys_clkin1",
355 .prcm = {
356 .omap4 = {
357 .clkctrl_offs = DRA7XX_CM_L4PER2_DCAN2_CLKCTRL_OFFSET,
358 .context_offs = DRA7XX_RM_L4PER2_DCAN2_CONTEXT_OFFSET,
359 .modulemode = MODULEMODE_SWCTRL,
360 },
361 },
362};
363
364/*
365 * 'dma' class
366 *
367 */
368
369static struct omap_hwmod_class_sysconfig dra7xx_dma_sysc = {
370 .rev_offs = 0x0000,
371 .sysc_offs = 0x002c,
372 .syss_offs = 0x0028,
373 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_CLOCKACTIVITY |
374 SYSC_HAS_EMUFREE | SYSC_HAS_MIDLEMODE |
375 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
376 SYSS_HAS_RESET_STATUS),
377 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
378 SIDLE_SMART_WKUP | MSTANDBY_FORCE | MSTANDBY_NO |
379 MSTANDBY_SMART | MSTANDBY_SMART_WKUP),
380 .sysc_fields = &omap_hwmod_sysc_type1,
381};
382
383static struct omap_hwmod_class dra7xx_dma_hwmod_class = {
384 .name = "dma",
385 .sysc = &dra7xx_dma_sysc,
386};
387
388/* dma dev_attr */
389static struct omap_dma_dev_attr dma_dev_attr = {
390 .dev_caps = RESERVE_CHANNEL | DMA_LINKED_LCH | GLOBAL_PRIORITY |
391 IS_CSSA_32 | IS_CDSA_32 | IS_RW_PRIORITY,
392 .lch_count = 32,
393};
394
395/* dma_system */
396static struct omap_hwmod_irq_info dra7xx_dma_system_irqs[] = {
397 { .name = "0", .irq = 12 + DRA7XX_IRQ_GIC_START },
398 { .name = "1", .irq = 13 + DRA7XX_IRQ_GIC_START },
399 { .name = "2", .irq = 14 + DRA7XX_IRQ_GIC_START },
400 { .name = "3", .irq = 15 + DRA7XX_IRQ_GIC_START },
401 { .irq = -1 }
402};
403
404static struct omap_hwmod dra7xx_dma_system_hwmod = {
405 .name = "dma_system",
406 .class = &dra7xx_dma_hwmod_class,
407 .clkdm_name = "dma_clkdm",
408 .mpu_irqs = dra7xx_dma_system_irqs,
409 .main_clk = "l3_iclk_div",
410 .prcm = {
411 .omap4 = {
412 .clkctrl_offs = DRA7XX_CM_DMA_DMA_SYSTEM_CLKCTRL_OFFSET,
413 .context_offs = DRA7XX_RM_DMA_DMA_SYSTEM_CONTEXT_OFFSET,
414 },
415 },
416 .dev_attr = &dma_dev_attr,
417};
418
419/*
420 * 'dss' class
421 *
422 */
423
424static struct omap_hwmod_class_sysconfig dra7xx_dss_sysc = {
425 .rev_offs = 0x0000,
426 .syss_offs = 0x0014,
427 .sysc_flags = SYSS_HAS_RESET_STATUS,
428};
429
430static struct omap_hwmod_class dra7xx_dss_hwmod_class = {
431 .name = "dss",
432 .sysc = &dra7xx_dss_sysc,
433 .reset = omap_dss_reset,
434};
435
436/* dss */
437static struct omap_hwmod_dma_info dra7xx_dss_sdma_reqs[] = {
438 { .dma_req = 75 + DRA7XX_DMA_REQ_START },
439 { .dma_req = -1 }
440};
441
442static struct omap_hwmod_opt_clk dss_opt_clks[] = {
443 { .role = "dss_clk", .clk = "dss_dss_clk" },
444 { .role = "hdmi_phy_clk", .clk = "dss_48mhz_clk" },
445 { .role = "32khz_clk", .clk = "dss_32khz_clk" },
446 { .role = "video2_clk", .clk = "dss_video2_clk" },
447 { .role = "video1_clk", .clk = "dss_video1_clk" },
448 { .role = "hdmi_clk", .clk = "dss_hdmi_clk" },
449};
450
451static struct omap_hwmod dra7xx_dss_hwmod = {
452 .name = "dss_core",
453 .class = &dra7xx_dss_hwmod_class,
454 .clkdm_name = "dss_clkdm",
455 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
456 .sdma_reqs = dra7xx_dss_sdma_reqs,
457 .main_clk = "dss_dss_clk",
458 .prcm = {
459 .omap4 = {
460 .clkctrl_offs = DRA7XX_CM_DSS_DSS_CLKCTRL_OFFSET,
461 .context_offs = DRA7XX_RM_DSS_DSS_CONTEXT_OFFSET,
462 .modulemode = MODULEMODE_SWCTRL,
463 },
464 },
465 .opt_clks = dss_opt_clks,
466 .opt_clks_cnt = ARRAY_SIZE(dss_opt_clks),
467};
468
469/*
470 * 'dispc' class
471 * display controller
472 */
473
474static struct omap_hwmod_class_sysconfig dra7xx_dispc_sysc = {
475 .rev_offs = 0x0000,
476 .sysc_offs = 0x0010,
477 .syss_offs = 0x0014,
478 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_CLOCKACTIVITY |
479 SYSC_HAS_ENAWAKEUP | SYSC_HAS_MIDLEMODE |
480 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
481 SYSS_HAS_RESET_STATUS),
482 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
483 MSTANDBY_FORCE | MSTANDBY_NO | MSTANDBY_SMART),
484 .sysc_fields = &omap_hwmod_sysc_type1,
485};
486
487static struct omap_hwmod_class dra7xx_dispc_hwmod_class = {
488 .name = "dispc",
489 .sysc = &dra7xx_dispc_sysc,
490};
491
492/* dss_dispc */
493/* dss_dispc dev_attr */
494static struct omap_dss_dispc_dev_attr dss_dispc_dev_attr = {
495 .has_framedonetv_irq = 1,
496 .manager_count = 4,
497};
498
499static struct omap_hwmod dra7xx_dss_dispc_hwmod = {
500 .name = "dss_dispc",
501 .class = &dra7xx_dispc_hwmod_class,
502 .clkdm_name = "dss_clkdm",
503 .main_clk = "dss_dss_clk",
504 .prcm = {
505 .omap4 = {
506 .clkctrl_offs = DRA7XX_CM_DSS_DSS_CLKCTRL_OFFSET,
507 .flags = HWMOD_OMAP4_NO_CONTEXT_LOSS_BIT,
508 },
509 },
510 .dev_attr = &dss_dispc_dev_attr,
511};
512
513/*
514 * 'hdmi' class
515 * hdmi controller
516 */
517
518static struct omap_hwmod_class_sysconfig dra7xx_hdmi_sysc = {
519 .rev_offs = 0x0000,
520 .sysc_offs = 0x0010,
521 .sysc_flags = (SYSC_HAS_RESET_STATUS | SYSC_HAS_SIDLEMODE |
522 SYSC_HAS_SOFTRESET),
523 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
524 SIDLE_SMART_WKUP),
525 .sysc_fields = &omap_hwmod_sysc_type2,
526};
527
528static struct omap_hwmod_class dra7xx_hdmi_hwmod_class = {
529 .name = "hdmi",
530 .sysc = &dra7xx_hdmi_sysc,
531};
532
533/* dss_hdmi */
534
535static struct omap_hwmod_opt_clk dss_hdmi_opt_clks[] = {
536 { .role = "sys_clk", .clk = "dss_hdmi_clk" },
537};
538
539static struct omap_hwmod dra7xx_dss_hdmi_hwmod = {
540 .name = "dss_hdmi",
541 .class = &dra7xx_hdmi_hwmod_class,
542 .clkdm_name = "dss_clkdm",
543 .main_clk = "dss_48mhz_clk",
544 .prcm = {
545 .omap4 = {
546 .clkctrl_offs = DRA7XX_CM_DSS_DSS_CLKCTRL_OFFSET,
547 .flags = HWMOD_OMAP4_NO_CONTEXT_LOSS_BIT,
548 },
549 },
550 .opt_clks = dss_hdmi_opt_clks,
551 .opt_clks_cnt = ARRAY_SIZE(dss_hdmi_opt_clks),
552};
553
554/*
555 * 'elm' class
556 *
557 */
558
559static struct omap_hwmod_class_sysconfig dra7xx_elm_sysc = {
560 .rev_offs = 0x0000,
561 .sysc_offs = 0x0010,
562 .syss_offs = 0x0014,
563 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_CLOCKACTIVITY |
564 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
565 SYSS_HAS_RESET_STATUS),
566 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
567 SIDLE_SMART_WKUP),
568 .sysc_fields = &omap_hwmod_sysc_type1,
569};
570
571static struct omap_hwmod_class dra7xx_elm_hwmod_class = {
572 .name = "elm",
573 .sysc = &dra7xx_elm_sysc,
574};
575
576/* elm */
577
578static struct omap_hwmod dra7xx_elm_hwmod = {
579 .name = "elm",
580 .class = &dra7xx_elm_hwmod_class,
581 .clkdm_name = "l4per_clkdm",
582 .main_clk = "l3_iclk_div",
583 .prcm = {
584 .omap4 = {
585 .clkctrl_offs = DRA7XX_CM_L4PER_ELM_CLKCTRL_OFFSET,
586 .context_offs = DRA7XX_RM_L4PER_ELM_CONTEXT_OFFSET,
587 },
588 },
589};
590
591/*
592 * 'gpio' class
593 *
594 */
595
596static struct omap_hwmod_class_sysconfig dra7xx_gpio_sysc = {
597 .rev_offs = 0x0000,
598 .sysc_offs = 0x0010,
599 .syss_offs = 0x0114,
600 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_ENAWAKEUP |
601 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
602 SYSS_HAS_RESET_STATUS),
603 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
604 SIDLE_SMART_WKUP),
605 .sysc_fields = &omap_hwmod_sysc_type1,
606};
607
608static struct omap_hwmod_class dra7xx_gpio_hwmod_class = {
609 .name = "gpio",
610 .sysc = &dra7xx_gpio_sysc,
611 .rev = 2,
612};
613
614/* gpio dev_attr */
615static struct omap_gpio_dev_attr gpio_dev_attr = {
616 .bank_width = 32,
617 .dbck_flag = true,
618};
619
620/* gpio1 */
621static struct omap_hwmod_opt_clk gpio1_opt_clks[] = {
622 { .role = "dbclk", .clk = "gpio1_dbclk" },
623};
624
625static struct omap_hwmod dra7xx_gpio1_hwmod = {
626 .name = "gpio1",
627 .class = &dra7xx_gpio_hwmod_class,
628 .clkdm_name = "wkupaon_clkdm",
629 .main_clk = "wkupaon_iclk_mux",
630 .prcm = {
631 .omap4 = {
632 .clkctrl_offs = DRA7XX_CM_WKUPAON_GPIO1_CLKCTRL_OFFSET,
633 .context_offs = DRA7XX_RM_WKUPAON_GPIO1_CONTEXT_OFFSET,
634 .modulemode = MODULEMODE_HWCTRL,
635 },
636 },
637 .opt_clks = gpio1_opt_clks,
638 .opt_clks_cnt = ARRAY_SIZE(gpio1_opt_clks),
639 .dev_attr = &gpio_dev_attr,
640};
641
642/* gpio2 */
643static struct omap_hwmod_opt_clk gpio2_opt_clks[] = {
644 { .role = "dbclk", .clk = "gpio2_dbclk" },
645};
646
647static struct omap_hwmod dra7xx_gpio2_hwmod = {
648 .name = "gpio2",
649 .class = &dra7xx_gpio_hwmod_class,
650 .clkdm_name = "l4per_clkdm",
651 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
652 .main_clk = "l3_iclk_div",
653 .prcm = {
654 .omap4 = {
655 .clkctrl_offs = DRA7XX_CM_L4PER_GPIO2_CLKCTRL_OFFSET,
656 .context_offs = DRA7XX_RM_L4PER_GPIO2_CONTEXT_OFFSET,
657 .modulemode = MODULEMODE_HWCTRL,
658 },
659 },
660 .opt_clks = gpio2_opt_clks,
661 .opt_clks_cnt = ARRAY_SIZE(gpio2_opt_clks),
662 .dev_attr = &gpio_dev_attr,
663};
664
665/* gpio3 */
666static struct omap_hwmod_opt_clk gpio3_opt_clks[] = {
667 { .role = "dbclk", .clk = "gpio3_dbclk" },
668};
669
670static struct omap_hwmod dra7xx_gpio3_hwmod = {
671 .name = "gpio3",
672 .class = &dra7xx_gpio_hwmod_class,
673 .clkdm_name = "l4per_clkdm",
674 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
675 .main_clk = "l3_iclk_div",
676 .prcm = {
677 .omap4 = {
678 .clkctrl_offs = DRA7XX_CM_L4PER_GPIO3_CLKCTRL_OFFSET,
679 .context_offs = DRA7XX_RM_L4PER_GPIO3_CONTEXT_OFFSET,
680 .modulemode = MODULEMODE_HWCTRL,
681 },
682 },
683 .opt_clks = gpio3_opt_clks,
684 .opt_clks_cnt = ARRAY_SIZE(gpio3_opt_clks),
685 .dev_attr = &gpio_dev_attr,
686};
687
688/* gpio4 */
689static struct omap_hwmod_opt_clk gpio4_opt_clks[] = {
690 { .role = "dbclk", .clk = "gpio4_dbclk" },
691};
692
693static struct omap_hwmod dra7xx_gpio4_hwmod = {
694 .name = "gpio4",
695 .class = &dra7xx_gpio_hwmod_class,
696 .clkdm_name = "l4per_clkdm",
697 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
698 .main_clk = "l3_iclk_div",
699 .prcm = {
700 .omap4 = {
701 .clkctrl_offs = DRA7XX_CM_L4PER_GPIO4_CLKCTRL_OFFSET,
702 .context_offs = DRA7XX_RM_L4PER_GPIO4_CONTEXT_OFFSET,
703 .modulemode = MODULEMODE_HWCTRL,
704 },
705 },
706 .opt_clks = gpio4_opt_clks,
707 .opt_clks_cnt = ARRAY_SIZE(gpio4_opt_clks),
708 .dev_attr = &gpio_dev_attr,
709};
710
711/* gpio5 */
712static struct omap_hwmod_opt_clk gpio5_opt_clks[] = {
713 { .role = "dbclk", .clk = "gpio5_dbclk" },
714};
715
716static struct omap_hwmod dra7xx_gpio5_hwmod = {
717 .name = "gpio5",
718 .class = &dra7xx_gpio_hwmod_class,
719 .clkdm_name = "l4per_clkdm",
720 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
721 .main_clk = "l3_iclk_div",
722 .prcm = {
723 .omap4 = {
724 .clkctrl_offs = DRA7XX_CM_L4PER_GPIO5_CLKCTRL_OFFSET,
725 .context_offs = DRA7XX_RM_L4PER_GPIO5_CONTEXT_OFFSET,
726 .modulemode = MODULEMODE_HWCTRL,
727 },
728 },
729 .opt_clks = gpio5_opt_clks,
730 .opt_clks_cnt = ARRAY_SIZE(gpio5_opt_clks),
731 .dev_attr = &gpio_dev_attr,
732};
733
734/* gpio6 */
735static struct omap_hwmod_opt_clk gpio6_opt_clks[] = {
736 { .role = "dbclk", .clk = "gpio6_dbclk" },
737};
738
739static struct omap_hwmod dra7xx_gpio6_hwmod = {
740 .name = "gpio6",
741 .class = &dra7xx_gpio_hwmod_class,
742 .clkdm_name = "l4per_clkdm",
743 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
744 .main_clk = "l3_iclk_div",
745 .prcm = {
746 .omap4 = {
747 .clkctrl_offs = DRA7XX_CM_L4PER_GPIO6_CLKCTRL_OFFSET,
748 .context_offs = DRA7XX_RM_L4PER_GPIO6_CONTEXT_OFFSET,
749 .modulemode = MODULEMODE_HWCTRL,
750 },
751 },
752 .opt_clks = gpio6_opt_clks,
753 .opt_clks_cnt = ARRAY_SIZE(gpio6_opt_clks),
754 .dev_attr = &gpio_dev_attr,
755};
756
757/* gpio7 */
758static struct omap_hwmod_opt_clk gpio7_opt_clks[] = {
759 { .role = "dbclk", .clk = "gpio7_dbclk" },
760};
761
762static struct omap_hwmod dra7xx_gpio7_hwmod = {
763 .name = "gpio7",
764 .class = &dra7xx_gpio_hwmod_class,
765 .clkdm_name = "l4per_clkdm",
766 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
767 .main_clk = "l3_iclk_div",
768 .prcm = {
769 .omap4 = {
770 .clkctrl_offs = DRA7XX_CM_L4PER_GPIO7_CLKCTRL_OFFSET,
771 .context_offs = DRA7XX_RM_L4PER_GPIO7_CONTEXT_OFFSET,
772 .modulemode = MODULEMODE_HWCTRL,
773 },
774 },
775 .opt_clks = gpio7_opt_clks,
776 .opt_clks_cnt = ARRAY_SIZE(gpio7_opt_clks),
777 .dev_attr = &gpio_dev_attr,
778};
779
780/* gpio8 */
781static struct omap_hwmod_opt_clk gpio8_opt_clks[] = {
782 { .role = "dbclk", .clk = "gpio8_dbclk" },
783};
784
785static struct omap_hwmod dra7xx_gpio8_hwmod = {
786 .name = "gpio8",
787 .class = &dra7xx_gpio_hwmod_class,
788 .clkdm_name = "l4per_clkdm",
789 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
790 .main_clk = "l3_iclk_div",
791 .prcm = {
792 .omap4 = {
793 .clkctrl_offs = DRA7XX_CM_L4PER_GPIO8_CLKCTRL_OFFSET,
794 .context_offs = DRA7XX_RM_L4PER_GPIO8_CONTEXT_OFFSET,
795 .modulemode = MODULEMODE_HWCTRL,
796 },
797 },
798 .opt_clks = gpio8_opt_clks,
799 .opt_clks_cnt = ARRAY_SIZE(gpio8_opt_clks),
800 .dev_attr = &gpio_dev_attr,
801};
802
803/*
804 * 'gpmc' class
805 *
806 */
807
808static struct omap_hwmod_class_sysconfig dra7xx_gpmc_sysc = {
809 .rev_offs = 0x0000,
810 .sysc_offs = 0x0010,
811 .syss_offs = 0x0014,
812 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_SIDLEMODE |
813 SYSC_HAS_SOFTRESET | SYSS_HAS_RESET_STATUS),
814 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
815 SIDLE_SMART_WKUP),
816 .sysc_fields = &omap_hwmod_sysc_type1,
817};
818
819static struct omap_hwmod_class dra7xx_gpmc_hwmod_class = {
820 .name = "gpmc",
821 .sysc = &dra7xx_gpmc_sysc,
822};
823
824/* gpmc */
825
826static struct omap_hwmod dra7xx_gpmc_hwmod = {
827 .name = "gpmc",
828 .class = &dra7xx_gpmc_hwmod_class,
829 .clkdm_name = "l3main1_clkdm",
830 .flags = HWMOD_INIT_NO_IDLE | HWMOD_INIT_NO_RESET,
831 .main_clk = "l3_iclk_div",
832 .prcm = {
833 .omap4 = {
834 .clkctrl_offs = DRA7XX_CM_L3MAIN1_GPMC_CLKCTRL_OFFSET,
835 .context_offs = DRA7XX_RM_L3MAIN1_GPMC_CONTEXT_OFFSET,
836 .modulemode = MODULEMODE_HWCTRL,
837 },
838 },
839};
840
841/*
842 * 'hdq1w' class
843 *
844 */
845
846static struct omap_hwmod_class_sysconfig dra7xx_hdq1w_sysc = {
847 .rev_offs = 0x0000,
848 .sysc_offs = 0x0014,
849 .syss_offs = 0x0018,
850 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_SOFTRESET |
851 SYSS_HAS_RESET_STATUS),
852 .sysc_fields = &omap_hwmod_sysc_type1,
853};
854
855static struct omap_hwmod_class dra7xx_hdq1w_hwmod_class = {
856 .name = "hdq1w",
857 .sysc = &dra7xx_hdq1w_sysc,
858};
859
860/* hdq1w */
861
862static struct omap_hwmod dra7xx_hdq1w_hwmod = {
863 .name = "hdq1w",
864 .class = &dra7xx_hdq1w_hwmod_class,
865 .clkdm_name = "l4per_clkdm",
866 .flags = HWMOD_INIT_NO_RESET,
867 .main_clk = "func_12m_fclk",
868 .prcm = {
869 .omap4 = {
870 .clkctrl_offs = DRA7XX_CM_L4PER_HDQ1W_CLKCTRL_OFFSET,
871 .context_offs = DRA7XX_RM_L4PER_HDQ1W_CONTEXT_OFFSET,
872 .modulemode = MODULEMODE_SWCTRL,
873 },
874 },
875};
876
877/*
878 * 'i2c' class
879 *
880 */
881
882static struct omap_hwmod_class_sysconfig dra7xx_i2c_sysc = {
883 .sysc_offs = 0x0010,
884 .syss_offs = 0x0090,
885 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_CLOCKACTIVITY |
886 SYSC_HAS_ENAWAKEUP | SYSC_HAS_SIDLEMODE |
887 SYSC_HAS_SOFTRESET | SYSS_HAS_RESET_STATUS),
888 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
889 SIDLE_SMART_WKUP),
890 .clockact = CLOCKACT_TEST_ICLK,
891 .sysc_fields = &omap_hwmod_sysc_type1,
892};
893
894static struct omap_hwmod_class dra7xx_i2c_hwmod_class = {
895 .name = "i2c",
896 .sysc = &dra7xx_i2c_sysc,
897 .reset = &omap_i2c_reset,
898 .rev = OMAP_I2C_IP_VERSION_2,
899};
900
901/* i2c dev_attr */
902static struct omap_i2c_dev_attr i2c_dev_attr = {
903 .flags = OMAP_I2C_FLAG_BUS_SHIFT_NONE,
904};
905
906/* i2c1 */
907static struct omap_hwmod dra7xx_i2c1_hwmod = {
908 .name = "i2c1",
909 .class = &dra7xx_i2c_hwmod_class,
910 .clkdm_name = "l4per_clkdm",
911 .flags = HWMOD_16BIT_REG | HWMOD_SET_DEFAULT_CLOCKACT,
912 .main_clk = "func_96m_fclk",
913 .prcm = {
914 .omap4 = {
915 .clkctrl_offs = DRA7XX_CM_L4PER_I2C1_CLKCTRL_OFFSET,
916 .context_offs = DRA7XX_RM_L4PER_I2C1_CONTEXT_OFFSET,
917 .modulemode = MODULEMODE_SWCTRL,
918 },
919 },
920 .dev_attr = &i2c_dev_attr,
921};
922
923/* i2c2 */
924static struct omap_hwmod dra7xx_i2c2_hwmod = {
925 .name = "i2c2",
926 .class = &dra7xx_i2c_hwmod_class,
927 .clkdm_name = "l4per_clkdm",
928 .flags = HWMOD_16BIT_REG | HWMOD_SET_DEFAULT_CLOCKACT,
929 .main_clk = "func_96m_fclk",
930 .prcm = {
931 .omap4 = {
932 .clkctrl_offs = DRA7XX_CM_L4PER_I2C2_CLKCTRL_OFFSET,
933 .context_offs = DRA7XX_RM_L4PER_I2C2_CONTEXT_OFFSET,
934 .modulemode = MODULEMODE_SWCTRL,
935 },
936 },
937 .dev_attr = &i2c_dev_attr,
938};
939
940/* i2c3 */
941static struct omap_hwmod dra7xx_i2c3_hwmod = {
942 .name = "i2c3",
943 .class = &dra7xx_i2c_hwmod_class,
944 .clkdm_name = "l4per_clkdm",
945 .flags = HWMOD_16BIT_REG | HWMOD_SET_DEFAULT_CLOCKACT,
946 .main_clk = "func_96m_fclk",
947 .prcm = {
948 .omap4 = {
949 .clkctrl_offs = DRA7XX_CM_L4PER_I2C3_CLKCTRL_OFFSET,
950 .context_offs = DRA7XX_RM_L4PER_I2C3_CONTEXT_OFFSET,
951 .modulemode = MODULEMODE_SWCTRL,
952 },
953 },
954 .dev_attr = &i2c_dev_attr,
955};
956
957/* i2c4 */
958static struct omap_hwmod dra7xx_i2c4_hwmod = {
959 .name = "i2c4",
960 .class = &dra7xx_i2c_hwmod_class,
961 .clkdm_name = "l4per_clkdm",
962 .flags = HWMOD_16BIT_REG | HWMOD_SET_DEFAULT_CLOCKACT,
963 .main_clk = "func_96m_fclk",
964 .prcm = {
965 .omap4 = {
966 .clkctrl_offs = DRA7XX_CM_L4PER_I2C4_CLKCTRL_OFFSET,
967 .context_offs = DRA7XX_RM_L4PER_I2C4_CONTEXT_OFFSET,
968 .modulemode = MODULEMODE_SWCTRL,
969 },
970 },
971 .dev_attr = &i2c_dev_attr,
972};
973
974/* i2c5 */
975static struct omap_hwmod dra7xx_i2c5_hwmod = {
976 .name = "i2c5",
977 .class = &dra7xx_i2c_hwmod_class,
978 .clkdm_name = "ipu_clkdm",
979 .flags = HWMOD_16BIT_REG | HWMOD_SET_DEFAULT_CLOCKACT,
980 .main_clk = "func_96m_fclk",
981 .prcm = {
982 .omap4 = {
983 .clkctrl_offs = DRA7XX_CM_IPU_I2C5_CLKCTRL_OFFSET,
984 .context_offs = DRA7XX_RM_IPU_I2C5_CONTEXT_OFFSET,
985 .modulemode = MODULEMODE_SWCTRL,
986 },
987 },
988 .dev_attr = &i2c_dev_attr,
989};
990
991/*
992 * 'mcspi' class
993 *
994 */
995
996static struct omap_hwmod_class_sysconfig dra7xx_mcspi_sysc = {
997 .rev_offs = 0x0000,
998 .sysc_offs = 0x0010,
999 .sysc_flags = (SYSC_HAS_EMUFREE | SYSC_HAS_RESET_STATUS |
1000 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET),
1001 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1002 SIDLE_SMART_WKUP),
1003 .sysc_fields = &omap_hwmod_sysc_type2,
1004};
1005
1006static struct omap_hwmod_class dra7xx_mcspi_hwmod_class = {
1007 .name = "mcspi",
1008 .sysc = &dra7xx_mcspi_sysc,
1009 .rev = OMAP4_MCSPI_REV,
1010};
1011
1012/* mcspi1 */
1013/* mcspi1 dev_attr */
1014static struct omap2_mcspi_dev_attr mcspi1_dev_attr = {
1015 .num_chipselect = 4,
1016};
1017
1018static struct omap_hwmod dra7xx_mcspi1_hwmod = {
1019 .name = "mcspi1",
1020 .class = &dra7xx_mcspi_hwmod_class,
1021 .clkdm_name = "l4per_clkdm",
1022 .main_clk = "func_48m_fclk",
1023 .prcm = {
1024 .omap4 = {
1025 .clkctrl_offs = DRA7XX_CM_L4PER_MCSPI1_CLKCTRL_OFFSET,
1026 .context_offs = DRA7XX_RM_L4PER_MCSPI1_CONTEXT_OFFSET,
1027 .modulemode = MODULEMODE_SWCTRL,
1028 },
1029 },
1030 .dev_attr = &mcspi1_dev_attr,
1031};
1032
1033/* mcspi2 */
1034/* mcspi2 dev_attr */
1035static struct omap2_mcspi_dev_attr mcspi2_dev_attr = {
1036 .num_chipselect = 2,
1037};
1038
1039static struct omap_hwmod dra7xx_mcspi2_hwmod = {
1040 .name = "mcspi2",
1041 .class = &dra7xx_mcspi_hwmod_class,
1042 .clkdm_name = "l4per_clkdm",
1043 .main_clk = "func_48m_fclk",
1044 .prcm = {
1045 .omap4 = {
1046 .clkctrl_offs = DRA7XX_CM_L4PER_MCSPI2_CLKCTRL_OFFSET,
1047 .context_offs = DRA7XX_RM_L4PER_MCSPI2_CONTEXT_OFFSET,
1048 .modulemode = MODULEMODE_SWCTRL,
1049 },
1050 },
1051 .dev_attr = &mcspi2_dev_attr,
1052};
1053
1054/* mcspi3 */
1055/* mcspi3 dev_attr */
1056static struct omap2_mcspi_dev_attr mcspi3_dev_attr = {
1057 .num_chipselect = 2,
1058};
1059
1060static struct omap_hwmod dra7xx_mcspi3_hwmod = {
1061 .name = "mcspi3",
1062 .class = &dra7xx_mcspi_hwmod_class,
1063 .clkdm_name = "l4per_clkdm",
1064 .main_clk = "func_48m_fclk",
1065 .prcm = {
1066 .omap4 = {
1067 .clkctrl_offs = DRA7XX_CM_L4PER_MCSPI3_CLKCTRL_OFFSET,
1068 .context_offs = DRA7XX_RM_L4PER_MCSPI3_CONTEXT_OFFSET,
1069 .modulemode = MODULEMODE_SWCTRL,
1070 },
1071 },
1072 .dev_attr = &mcspi3_dev_attr,
1073};
1074
1075/* mcspi4 */
1076/* mcspi4 dev_attr */
1077static struct omap2_mcspi_dev_attr mcspi4_dev_attr = {
1078 .num_chipselect = 1,
1079};
1080
1081static struct omap_hwmod dra7xx_mcspi4_hwmod = {
1082 .name = "mcspi4",
1083 .class = &dra7xx_mcspi_hwmod_class,
1084 .clkdm_name = "l4per_clkdm",
1085 .main_clk = "func_48m_fclk",
1086 .prcm = {
1087 .omap4 = {
1088 .clkctrl_offs = DRA7XX_CM_L4PER_MCSPI4_CLKCTRL_OFFSET,
1089 .context_offs = DRA7XX_RM_L4PER_MCSPI4_CONTEXT_OFFSET,
1090 .modulemode = MODULEMODE_SWCTRL,
1091 },
1092 },
1093 .dev_attr = &mcspi4_dev_attr,
1094};
1095
1096/*
1097 * 'mmc' class
1098 *
1099 */
1100
1101static struct omap_hwmod_class_sysconfig dra7xx_mmc_sysc = {
1102 .rev_offs = 0x0000,
1103 .sysc_offs = 0x0010,
1104 .sysc_flags = (SYSC_HAS_EMUFREE | SYSC_HAS_MIDLEMODE |
1105 SYSC_HAS_RESET_STATUS | SYSC_HAS_SIDLEMODE |
1106 SYSC_HAS_SOFTRESET),
1107 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1108 SIDLE_SMART_WKUP | MSTANDBY_FORCE | MSTANDBY_NO |
1109 MSTANDBY_SMART | MSTANDBY_SMART_WKUP),
1110 .sysc_fields = &omap_hwmod_sysc_type2,
1111};
1112
1113static struct omap_hwmod_class dra7xx_mmc_hwmod_class = {
1114 .name = "mmc",
1115 .sysc = &dra7xx_mmc_sysc,
1116};
1117
1118/* mmc1 */
1119static struct omap_hwmod_opt_clk mmc1_opt_clks[] = {
1120 { .role = "clk32k", .clk = "mmc1_clk32k" },
1121};
1122
1123/* mmc1 dev_attr */
1124static struct omap_mmc_dev_attr mmc1_dev_attr = {
1125 .flags = OMAP_HSMMC_SUPPORTS_DUAL_VOLT,
1126};
1127
1128static struct omap_hwmod dra7xx_mmc1_hwmod = {
1129 .name = "mmc1",
1130 .class = &dra7xx_mmc_hwmod_class,
1131 .clkdm_name = "l3init_clkdm",
1132 .main_clk = "mmc1_fclk_div",
1133 .prcm = {
1134 .omap4 = {
1135 .clkctrl_offs = DRA7XX_CM_L3INIT_MMC1_CLKCTRL_OFFSET,
1136 .context_offs = DRA7XX_RM_L3INIT_MMC1_CONTEXT_OFFSET,
1137 .modulemode = MODULEMODE_SWCTRL,
1138 },
1139 },
1140 .opt_clks = mmc1_opt_clks,
1141 .opt_clks_cnt = ARRAY_SIZE(mmc1_opt_clks),
1142 .dev_attr = &mmc1_dev_attr,
1143};
1144
1145/* mmc2 */
1146static struct omap_hwmod_opt_clk mmc2_opt_clks[] = {
1147 { .role = "clk32k", .clk = "mmc2_clk32k" },
1148};
1149
1150static struct omap_hwmod dra7xx_mmc2_hwmod = {
1151 .name = "mmc2",
1152 .class = &dra7xx_mmc_hwmod_class,
1153 .clkdm_name = "l3init_clkdm",
1154 .main_clk = "mmc2_fclk_div",
1155 .prcm = {
1156 .omap4 = {
1157 .clkctrl_offs = DRA7XX_CM_L3INIT_MMC2_CLKCTRL_OFFSET,
1158 .context_offs = DRA7XX_RM_L3INIT_MMC2_CONTEXT_OFFSET,
1159 .modulemode = MODULEMODE_SWCTRL,
1160 },
1161 },
1162 .opt_clks = mmc2_opt_clks,
1163 .opt_clks_cnt = ARRAY_SIZE(mmc2_opt_clks),
1164};
1165
1166/* mmc3 */
1167static struct omap_hwmod_opt_clk mmc3_opt_clks[] = {
1168 { .role = "clk32k", .clk = "mmc3_clk32k" },
1169};
1170
1171static struct omap_hwmod dra7xx_mmc3_hwmod = {
1172 .name = "mmc3",
1173 .class = &dra7xx_mmc_hwmod_class,
1174 .clkdm_name = "l4per_clkdm",
1175 .main_clk = "mmc3_gfclk_div",
1176 .prcm = {
1177 .omap4 = {
1178 .clkctrl_offs = DRA7XX_CM_L4PER_MMC3_CLKCTRL_OFFSET,
1179 .context_offs = DRA7XX_RM_L4PER_MMC3_CONTEXT_OFFSET,
1180 .modulemode = MODULEMODE_SWCTRL,
1181 },
1182 },
1183 .opt_clks = mmc3_opt_clks,
1184 .opt_clks_cnt = ARRAY_SIZE(mmc3_opt_clks),
1185};
1186
1187/* mmc4 */
1188static struct omap_hwmod_opt_clk mmc4_opt_clks[] = {
1189 { .role = "clk32k", .clk = "mmc4_clk32k" },
1190};
1191
1192static struct omap_hwmod dra7xx_mmc4_hwmod = {
1193 .name = "mmc4",
1194 .class = &dra7xx_mmc_hwmod_class,
1195 .clkdm_name = "l4per_clkdm",
1196 .main_clk = "mmc4_gfclk_div",
1197 .prcm = {
1198 .omap4 = {
1199 .clkctrl_offs = DRA7XX_CM_L4PER_MMC4_CLKCTRL_OFFSET,
1200 .context_offs = DRA7XX_RM_L4PER_MMC4_CONTEXT_OFFSET,
1201 .modulemode = MODULEMODE_SWCTRL,
1202 },
1203 },
1204 .opt_clks = mmc4_opt_clks,
1205 .opt_clks_cnt = ARRAY_SIZE(mmc4_opt_clks),
1206};
1207
1208/*
1209 * 'mpu' class
1210 *
1211 */
1212
1213static struct omap_hwmod_class dra7xx_mpu_hwmod_class = {
1214 .name = "mpu",
1215};
1216
1217/* mpu */
1218static struct omap_hwmod dra7xx_mpu_hwmod = {
1219 .name = "mpu",
1220 .class = &dra7xx_mpu_hwmod_class,
1221 .clkdm_name = "mpu_clkdm",
1222 .flags = HWMOD_INIT_NO_IDLE | HWMOD_INIT_NO_RESET,
1223 .main_clk = "dpll_mpu_m2_ck",
1224 .prcm = {
1225 .omap4 = {
1226 .clkctrl_offs = DRA7XX_CM_MPU_MPU_CLKCTRL_OFFSET,
1227 .context_offs = DRA7XX_RM_MPU_MPU_CONTEXT_OFFSET,
1228 },
1229 },
1230};
1231
1232/*
1233 * 'ocp2scp' class
1234 *
1235 */
1236
1237static struct omap_hwmod_class_sysconfig dra7xx_ocp2scp_sysc = {
1238 .rev_offs = 0x0000,
1239 .sysc_offs = 0x0010,
1240 .syss_offs = 0x0014,
1241 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_SIDLEMODE |
1242 SYSC_HAS_SOFTRESET | SYSS_HAS_RESET_STATUS),
1243 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1244 SIDLE_SMART_WKUP),
1245 .sysc_fields = &omap_hwmod_sysc_type1,
1246};
1247
1248static struct omap_hwmod_class dra7xx_ocp2scp_hwmod_class = {
1249 .name = "ocp2scp",
1250 .sysc = &dra7xx_ocp2scp_sysc,
1251};
1252
1253/* ocp2scp1 */
1254static struct omap_hwmod dra7xx_ocp2scp1_hwmod = {
1255 .name = "ocp2scp1",
1256 .class = &dra7xx_ocp2scp_hwmod_class,
1257 .clkdm_name = "l3init_clkdm",
1258 .main_clk = "l4_root_clk_div",
1259 .prcm = {
1260 .omap4 = {
1261 .clkctrl_offs = DRA7XX_CM_L3INIT_OCP2SCP1_CLKCTRL_OFFSET,
1262 .context_offs = DRA7XX_RM_L3INIT_OCP2SCP1_CONTEXT_OFFSET,
1263 .modulemode = MODULEMODE_HWCTRL,
1264 },
1265 },
1266};
1267
Roger Quadrosdf0d0f12014-07-05 17:44:58 -06001268/* ocp2scp3 */
1269static struct omap_hwmod dra7xx_ocp2scp3_hwmod = {
1270 .name = "ocp2scp3",
1271 .class = &dra7xx_ocp2scp_hwmod_class,
1272 .clkdm_name = "l3init_clkdm",
1273 .main_clk = "l4_root_clk_div",
1274 .prcm = {
1275 .omap4 = {
1276 .clkctrl_offs = DRA7XX_CM_L3INIT_OCP2SCP3_CLKCTRL_OFFSET,
1277 .context_offs = DRA7XX_RM_L3INIT_OCP2SCP3_CONTEXT_OFFSET,
1278 .modulemode = MODULEMODE_HWCTRL,
1279 },
1280 },
1281};
1282
Ambresh K90020c72013-07-09 13:02:16 +05301283/*
Kishon Vijay Abraham I8dd3eb72014-07-09 14:32:47 +05301284 * 'PCIE' class
1285 *
1286 */
1287
1288static struct omap_hwmod_class dra7xx_pcie_hwmod_class = {
1289 .name = "pcie",
1290};
1291
1292/* pcie1 */
1293static struct omap_hwmod dra7xx_pcie1_hwmod = {
1294 .name = "pcie1",
1295 .class = &dra7xx_pcie_hwmod_class,
1296 .clkdm_name = "pcie_clkdm",
1297 .main_clk = "l4_root_clk_div",
1298 .prcm = {
1299 .omap4 = {
1300 .clkctrl_offs = DRA7XX_CM_PCIE_CLKSTCTRL_OFFSET,
1301 .modulemode = MODULEMODE_SWCTRL,
1302 },
1303 },
1304};
1305
1306/* pcie2 */
1307static struct omap_hwmod dra7xx_pcie2_hwmod = {
1308 .name = "pcie2",
1309 .class = &dra7xx_pcie_hwmod_class,
1310 .clkdm_name = "pcie_clkdm",
1311 .main_clk = "l4_root_clk_div",
1312 .prcm = {
1313 .omap4 = {
1314 .clkctrl_offs = DRA7XX_CM_PCIE_CLKSTCTRL_OFFSET,
1315 .modulemode = MODULEMODE_SWCTRL,
1316 },
1317 },
1318};
1319
1320/*
Kishon Vijay Abraham I70c18ef72014-06-25 23:32:45 +05301321 * 'PCIE PHY' class
1322 *
1323 */
1324
1325static struct omap_hwmod_class dra7xx_pcie_phy_hwmod_class = {
1326 .name = "pcie-phy",
1327};
1328
1329/* pcie1 phy */
1330static struct omap_hwmod dra7xx_pcie1_phy_hwmod = {
1331 .name = "pcie1-phy",
1332 .class = &dra7xx_pcie_phy_hwmod_class,
1333 .clkdm_name = "l3init_clkdm",
1334 .main_clk = "l4_root_clk_div",
1335 .prcm = {
1336 .omap4 = {
1337 .clkctrl_offs = DRA7XX_CM_L3INIT_PCIESS1_CLKCTRL_OFFSET,
1338 .context_offs = DRA7XX_RM_L3INIT_PCIESS1_CONTEXT_OFFSET,
1339 .modulemode = MODULEMODE_SWCTRL,
1340 },
1341 },
1342};
1343
1344/* pcie2 phy */
1345static struct omap_hwmod dra7xx_pcie2_phy_hwmod = {
1346 .name = "pcie2-phy",
1347 .class = &dra7xx_pcie_phy_hwmod_class,
1348 .clkdm_name = "l3init_clkdm",
1349 .main_clk = "l4_root_clk_div",
1350 .prcm = {
1351 .omap4 = {
1352 .clkctrl_offs = DRA7XX_CM_L3INIT_PCIESS2_CLKCTRL_OFFSET,
1353 .context_offs = DRA7XX_RM_L3INIT_PCIESS2_CONTEXT_OFFSET,
1354 .modulemode = MODULEMODE_SWCTRL,
1355 },
1356 },
1357};
1358
1359/*
Ambresh K90020c72013-07-09 13:02:16 +05301360 * 'qspi' class
1361 *
1362 */
1363
1364static struct omap_hwmod_class_sysconfig dra7xx_qspi_sysc = {
1365 .sysc_offs = 0x0010,
1366 .sysc_flags = SYSC_HAS_SIDLEMODE,
1367 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1368 SIDLE_SMART_WKUP),
1369 .sysc_fields = &omap_hwmod_sysc_type2,
1370};
1371
1372static struct omap_hwmod_class dra7xx_qspi_hwmod_class = {
1373 .name = "qspi",
1374 .sysc = &dra7xx_qspi_sysc,
1375};
1376
1377/* qspi */
1378static struct omap_hwmod dra7xx_qspi_hwmod = {
1379 .name = "qspi",
1380 .class = &dra7xx_qspi_hwmod_class,
1381 .clkdm_name = "l4per2_clkdm",
1382 .main_clk = "qspi_gfclk_div",
1383 .prcm = {
1384 .omap4 = {
1385 .clkctrl_offs = DRA7XX_CM_L4PER2_QSPI_CLKCTRL_OFFSET,
1386 .context_offs = DRA7XX_RM_L4PER2_QSPI_CONTEXT_OFFSET,
1387 .modulemode = MODULEMODE_SWCTRL,
1388 },
1389 },
1390};
1391
1392/*
1393 * 'sata' class
1394 *
1395 */
1396
1397static struct omap_hwmod_class_sysconfig dra7xx_sata_sysc = {
1398 .sysc_offs = 0x0000,
1399 .sysc_flags = (SYSC_HAS_MIDLEMODE | SYSC_HAS_SIDLEMODE),
1400 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1401 SIDLE_SMART_WKUP | MSTANDBY_FORCE | MSTANDBY_NO |
1402 MSTANDBY_SMART | MSTANDBY_SMART_WKUP),
1403 .sysc_fields = &omap_hwmod_sysc_type2,
1404};
1405
1406static struct omap_hwmod_class dra7xx_sata_hwmod_class = {
1407 .name = "sata",
1408 .sysc = &dra7xx_sata_sysc,
1409};
1410
1411/* sata */
1412static struct omap_hwmod_opt_clk sata_opt_clks[] = {
1413 { .role = "ref_clk", .clk = "sata_ref_clk" },
1414};
1415
1416static struct omap_hwmod dra7xx_sata_hwmod = {
1417 .name = "sata",
1418 .class = &dra7xx_sata_hwmod_class,
1419 .clkdm_name = "l3init_clkdm",
1420 .flags = HWMOD_SWSUP_SIDLE | HWMOD_SWSUP_MSTANDBY,
1421 .main_clk = "func_48m_fclk",
1422 .prcm = {
1423 .omap4 = {
1424 .clkctrl_offs = DRA7XX_CM_L3INIT_SATA_CLKCTRL_OFFSET,
1425 .context_offs = DRA7XX_RM_L3INIT_SATA_CONTEXT_OFFSET,
1426 .modulemode = MODULEMODE_SWCTRL,
1427 },
1428 },
1429 .opt_clks = sata_opt_clks,
1430 .opt_clks_cnt = ARRAY_SIZE(sata_opt_clks),
1431};
1432
1433/*
1434 * 'smartreflex' class
1435 *
1436 */
1437
1438/* The IP is not compliant to type1 / type2 scheme */
1439static struct omap_hwmod_sysc_fields omap_hwmod_sysc_type_smartreflex = {
1440 .sidle_shift = 24,
1441 .enwkup_shift = 26,
1442};
1443
1444static struct omap_hwmod_class_sysconfig dra7xx_smartreflex_sysc = {
1445 .sysc_offs = 0x0038,
1446 .sysc_flags = (SYSC_HAS_ENAWAKEUP | SYSC_HAS_SIDLEMODE),
1447 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1448 SIDLE_SMART_WKUP),
1449 .sysc_fields = &omap_hwmod_sysc_type_smartreflex,
1450};
1451
1452static struct omap_hwmod_class dra7xx_smartreflex_hwmod_class = {
1453 .name = "smartreflex",
1454 .sysc = &dra7xx_smartreflex_sysc,
1455 .rev = 2,
1456};
1457
1458/* smartreflex_core */
1459/* smartreflex_core dev_attr */
1460static struct omap_smartreflex_dev_attr smartreflex_core_dev_attr = {
1461 .sensor_voltdm_name = "core",
1462};
1463
1464static struct omap_hwmod dra7xx_smartreflex_core_hwmod = {
1465 .name = "smartreflex_core",
1466 .class = &dra7xx_smartreflex_hwmod_class,
1467 .clkdm_name = "coreaon_clkdm",
1468 .main_clk = "wkupaon_iclk_mux",
1469 .prcm = {
1470 .omap4 = {
1471 .clkctrl_offs = DRA7XX_CM_COREAON_SMARTREFLEX_CORE_CLKCTRL_OFFSET,
1472 .context_offs = DRA7XX_RM_COREAON_SMARTREFLEX_CORE_CONTEXT_OFFSET,
1473 .modulemode = MODULEMODE_SWCTRL,
1474 },
1475 },
1476 .dev_attr = &smartreflex_core_dev_attr,
1477};
1478
1479/* smartreflex_mpu */
1480/* smartreflex_mpu dev_attr */
1481static struct omap_smartreflex_dev_attr smartreflex_mpu_dev_attr = {
1482 .sensor_voltdm_name = "mpu",
1483};
1484
1485static struct omap_hwmod dra7xx_smartreflex_mpu_hwmod = {
1486 .name = "smartreflex_mpu",
1487 .class = &dra7xx_smartreflex_hwmod_class,
1488 .clkdm_name = "coreaon_clkdm",
1489 .main_clk = "wkupaon_iclk_mux",
1490 .prcm = {
1491 .omap4 = {
1492 .clkctrl_offs = DRA7XX_CM_COREAON_SMARTREFLEX_MPU_CLKCTRL_OFFSET,
1493 .context_offs = DRA7XX_RM_COREAON_SMARTREFLEX_MPU_CONTEXT_OFFSET,
1494 .modulemode = MODULEMODE_SWCTRL,
1495 },
1496 },
1497 .dev_attr = &smartreflex_mpu_dev_attr,
1498};
1499
1500/*
1501 * 'spinlock' class
1502 *
1503 */
1504
1505static struct omap_hwmod_class_sysconfig dra7xx_spinlock_sysc = {
1506 .rev_offs = 0x0000,
1507 .sysc_offs = 0x0010,
1508 .syss_offs = 0x0014,
Suman Annac317d0f2014-01-10 17:43:08 -06001509 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_ENAWAKEUP |
1510 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
1511 SYSS_HAS_RESET_STATUS),
1512 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
Ambresh K90020c72013-07-09 13:02:16 +05301513 .sysc_fields = &omap_hwmod_sysc_type1,
1514};
1515
1516static struct omap_hwmod_class dra7xx_spinlock_hwmod_class = {
1517 .name = "spinlock",
1518 .sysc = &dra7xx_spinlock_sysc,
1519};
1520
1521/* spinlock */
1522static struct omap_hwmod dra7xx_spinlock_hwmod = {
1523 .name = "spinlock",
1524 .class = &dra7xx_spinlock_hwmod_class,
1525 .clkdm_name = "l4cfg_clkdm",
1526 .main_clk = "l3_iclk_div",
1527 .prcm = {
1528 .omap4 = {
1529 .clkctrl_offs = DRA7XX_CM_L4CFG_SPINLOCK_CLKCTRL_OFFSET,
1530 .context_offs = DRA7XX_RM_L4CFG_SPINLOCK_CONTEXT_OFFSET,
1531 },
1532 },
1533};
1534
1535/*
1536 * 'timer' class
1537 *
1538 * This class contains several variants: ['timer_1ms', 'timer_secure',
1539 * 'timer']
1540 */
1541
1542static struct omap_hwmod_class_sysconfig dra7xx_timer_1ms_sysc = {
1543 .rev_offs = 0x0000,
1544 .sysc_offs = 0x0010,
1545 .sysc_flags = (SYSC_HAS_EMUFREE | SYSC_HAS_RESET_STATUS |
1546 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET),
1547 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1548 SIDLE_SMART_WKUP),
1549 .sysc_fields = &omap_hwmod_sysc_type2,
1550};
1551
1552static struct omap_hwmod_class dra7xx_timer_1ms_hwmod_class = {
1553 .name = "timer",
1554 .sysc = &dra7xx_timer_1ms_sysc,
1555};
1556
1557static struct omap_hwmod_class_sysconfig dra7xx_timer_secure_sysc = {
1558 .rev_offs = 0x0000,
1559 .sysc_offs = 0x0010,
1560 .sysc_flags = (SYSC_HAS_EMUFREE | SYSC_HAS_RESET_STATUS |
1561 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET),
1562 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1563 SIDLE_SMART_WKUP),
1564 .sysc_fields = &omap_hwmod_sysc_type2,
1565};
1566
1567static struct omap_hwmod_class dra7xx_timer_secure_hwmod_class = {
1568 .name = "timer",
1569 .sysc = &dra7xx_timer_secure_sysc,
1570};
1571
1572static struct omap_hwmod_class_sysconfig dra7xx_timer_sysc = {
1573 .rev_offs = 0x0000,
1574 .sysc_offs = 0x0010,
1575 .sysc_flags = (SYSC_HAS_EMUFREE | SYSC_HAS_RESET_STATUS |
1576 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET),
1577 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1578 SIDLE_SMART_WKUP),
1579 .sysc_fields = &omap_hwmod_sysc_type2,
1580};
1581
1582static struct omap_hwmod_class dra7xx_timer_hwmod_class = {
1583 .name = "timer",
1584 .sysc = &dra7xx_timer_sysc,
1585};
1586
1587/* timer1 */
1588static struct omap_hwmod dra7xx_timer1_hwmod = {
1589 .name = "timer1",
1590 .class = &dra7xx_timer_1ms_hwmod_class,
1591 .clkdm_name = "wkupaon_clkdm",
1592 .main_clk = "timer1_gfclk_mux",
1593 .prcm = {
1594 .omap4 = {
1595 .clkctrl_offs = DRA7XX_CM_WKUPAON_TIMER1_CLKCTRL_OFFSET,
1596 .context_offs = DRA7XX_RM_WKUPAON_TIMER1_CONTEXT_OFFSET,
1597 .modulemode = MODULEMODE_SWCTRL,
1598 },
1599 },
1600};
1601
1602/* timer2 */
1603static struct omap_hwmod dra7xx_timer2_hwmod = {
1604 .name = "timer2",
1605 .class = &dra7xx_timer_1ms_hwmod_class,
1606 .clkdm_name = "l4per_clkdm",
1607 .main_clk = "timer2_gfclk_mux",
1608 .prcm = {
1609 .omap4 = {
1610 .clkctrl_offs = DRA7XX_CM_L4PER_TIMER2_CLKCTRL_OFFSET,
1611 .context_offs = DRA7XX_RM_L4PER_TIMER2_CONTEXT_OFFSET,
1612 .modulemode = MODULEMODE_SWCTRL,
1613 },
1614 },
1615};
1616
1617/* timer3 */
1618static struct omap_hwmod dra7xx_timer3_hwmod = {
1619 .name = "timer3",
1620 .class = &dra7xx_timer_hwmod_class,
1621 .clkdm_name = "l4per_clkdm",
1622 .main_clk = "timer3_gfclk_mux",
1623 .prcm = {
1624 .omap4 = {
1625 .clkctrl_offs = DRA7XX_CM_L4PER_TIMER3_CLKCTRL_OFFSET,
1626 .context_offs = DRA7XX_RM_L4PER_TIMER3_CONTEXT_OFFSET,
1627 .modulemode = MODULEMODE_SWCTRL,
1628 },
1629 },
1630};
1631
1632/* timer4 */
1633static struct omap_hwmod dra7xx_timer4_hwmod = {
1634 .name = "timer4",
1635 .class = &dra7xx_timer_secure_hwmod_class,
1636 .clkdm_name = "l4per_clkdm",
1637 .main_clk = "timer4_gfclk_mux",
1638 .prcm = {
1639 .omap4 = {
1640 .clkctrl_offs = DRA7XX_CM_L4PER_TIMER4_CLKCTRL_OFFSET,
1641 .context_offs = DRA7XX_RM_L4PER_TIMER4_CONTEXT_OFFSET,
1642 .modulemode = MODULEMODE_SWCTRL,
1643 },
1644 },
1645};
1646
1647/* timer5 */
1648static struct omap_hwmod dra7xx_timer5_hwmod = {
1649 .name = "timer5",
1650 .class = &dra7xx_timer_hwmod_class,
1651 .clkdm_name = "ipu_clkdm",
1652 .main_clk = "timer5_gfclk_mux",
1653 .prcm = {
1654 .omap4 = {
1655 .clkctrl_offs = DRA7XX_CM_IPU_TIMER5_CLKCTRL_OFFSET,
1656 .context_offs = DRA7XX_RM_IPU_TIMER5_CONTEXT_OFFSET,
1657 .modulemode = MODULEMODE_SWCTRL,
1658 },
1659 },
1660};
1661
1662/* timer6 */
1663static struct omap_hwmod dra7xx_timer6_hwmod = {
1664 .name = "timer6",
1665 .class = &dra7xx_timer_hwmod_class,
1666 .clkdm_name = "ipu_clkdm",
1667 .main_clk = "timer6_gfclk_mux",
1668 .prcm = {
1669 .omap4 = {
1670 .clkctrl_offs = DRA7XX_CM_IPU_TIMER6_CLKCTRL_OFFSET,
1671 .context_offs = DRA7XX_RM_IPU_TIMER6_CONTEXT_OFFSET,
1672 .modulemode = MODULEMODE_SWCTRL,
1673 },
1674 },
1675};
1676
1677/* timer7 */
1678static struct omap_hwmod dra7xx_timer7_hwmod = {
1679 .name = "timer7",
1680 .class = &dra7xx_timer_hwmod_class,
1681 .clkdm_name = "ipu_clkdm",
1682 .main_clk = "timer7_gfclk_mux",
1683 .prcm = {
1684 .omap4 = {
1685 .clkctrl_offs = DRA7XX_CM_IPU_TIMER7_CLKCTRL_OFFSET,
1686 .context_offs = DRA7XX_RM_IPU_TIMER7_CONTEXT_OFFSET,
1687 .modulemode = MODULEMODE_SWCTRL,
1688 },
1689 },
1690};
1691
1692/* timer8 */
1693static struct omap_hwmod dra7xx_timer8_hwmod = {
1694 .name = "timer8",
1695 .class = &dra7xx_timer_hwmod_class,
1696 .clkdm_name = "ipu_clkdm",
1697 .main_clk = "timer8_gfclk_mux",
1698 .prcm = {
1699 .omap4 = {
1700 .clkctrl_offs = DRA7XX_CM_IPU_TIMER8_CLKCTRL_OFFSET,
1701 .context_offs = DRA7XX_RM_IPU_TIMER8_CONTEXT_OFFSET,
1702 .modulemode = MODULEMODE_SWCTRL,
1703 },
1704 },
1705};
1706
1707/* timer9 */
1708static struct omap_hwmod dra7xx_timer9_hwmod = {
1709 .name = "timer9",
1710 .class = &dra7xx_timer_hwmod_class,
1711 .clkdm_name = "l4per_clkdm",
1712 .main_clk = "timer9_gfclk_mux",
1713 .prcm = {
1714 .omap4 = {
1715 .clkctrl_offs = DRA7XX_CM_L4PER_TIMER9_CLKCTRL_OFFSET,
1716 .context_offs = DRA7XX_RM_L4PER_TIMER9_CONTEXT_OFFSET,
1717 .modulemode = MODULEMODE_SWCTRL,
1718 },
1719 },
1720};
1721
1722/* timer10 */
1723static struct omap_hwmod dra7xx_timer10_hwmod = {
1724 .name = "timer10",
1725 .class = &dra7xx_timer_1ms_hwmod_class,
1726 .clkdm_name = "l4per_clkdm",
1727 .main_clk = "timer10_gfclk_mux",
1728 .prcm = {
1729 .omap4 = {
1730 .clkctrl_offs = DRA7XX_CM_L4PER_TIMER10_CLKCTRL_OFFSET,
1731 .context_offs = DRA7XX_RM_L4PER_TIMER10_CONTEXT_OFFSET,
1732 .modulemode = MODULEMODE_SWCTRL,
1733 },
1734 },
1735};
1736
1737/* timer11 */
1738static struct omap_hwmod dra7xx_timer11_hwmod = {
1739 .name = "timer11",
1740 .class = &dra7xx_timer_hwmod_class,
1741 .clkdm_name = "l4per_clkdm",
1742 .main_clk = "timer11_gfclk_mux",
1743 .prcm = {
1744 .omap4 = {
1745 .clkctrl_offs = DRA7XX_CM_L4PER_TIMER11_CLKCTRL_OFFSET,
1746 .context_offs = DRA7XX_RM_L4PER_TIMER11_CONTEXT_OFFSET,
1747 .modulemode = MODULEMODE_SWCTRL,
1748 },
1749 },
1750};
1751
1752/*
1753 * 'uart' class
1754 *
1755 */
1756
1757static struct omap_hwmod_class_sysconfig dra7xx_uart_sysc = {
1758 .rev_offs = 0x0050,
1759 .sysc_offs = 0x0054,
1760 .syss_offs = 0x0058,
1761 .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_ENAWAKEUP |
1762 SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
1763 SYSS_HAS_RESET_STATUS),
1764 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
1765 SIDLE_SMART_WKUP),
1766 .sysc_fields = &omap_hwmod_sysc_type1,
1767};
1768
1769static struct omap_hwmod_class dra7xx_uart_hwmod_class = {
1770 .name = "uart",
1771 .sysc = &dra7xx_uart_sysc,
1772};
1773
1774/* uart1 */
1775static struct omap_hwmod dra7xx_uart1_hwmod = {
1776 .name = "uart1",
1777 .class = &dra7xx_uart_hwmod_class,
1778 .clkdm_name = "l4per_clkdm",
1779 .main_clk = "uart1_gfclk_mux",
Rajendra Nayak38958c12013-12-12 15:22:49 +05301780 .flags = HWMOD_SWSUP_SIDLE_ACT | DEBUG_OMAP2UART1_FLAGS,
Ambresh K90020c72013-07-09 13:02:16 +05301781 .prcm = {
1782 .omap4 = {
1783 .clkctrl_offs = DRA7XX_CM_L4PER_UART1_CLKCTRL_OFFSET,
1784 .context_offs = DRA7XX_RM_L4PER_UART1_CONTEXT_OFFSET,
1785 .modulemode = MODULEMODE_SWCTRL,
1786 },
1787 },
1788};
1789
1790/* uart2 */
1791static struct omap_hwmod dra7xx_uart2_hwmod = {
1792 .name = "uart2",
1793 .class = &dra7xx_uart_hwmod_class,
1794 .clkdm_name = "l4per_clkdm",
1795 .main_clk = "uart2_gfclk_mux",
1796 .flags = HWMOD_SWSUP_SIDLE_ACT,
1797 .prcm = {
1798 .omap4 = {
1799 .clkctrl_offs = DRA7XX_CM_L4PER_UART2_CLKCTRL_OFFSET,
1800 .context_offs = DRA7XX_RM_L4PER_UART2_CONTEXT_OFFSET,
1801 .modulemode = MODULEMODE_SWCTRL,
1802 },
1803 },
1804};
1805
1806/* uart3 */
1807static struct omap_hwmod dra7xx_uart3_hwmod = {
1808 .name = "uart3",
1809 .class = &dra7xx_uart_hwmod_class,
1810 .clkdm_name = "l4per_clkdm",
1811 .main_clk = "uart3_gfclk_mux",
1812 .flags = HWMOD_SWSUP_SIDLE_ACT,
1813 .prcm = {
1814 .omap4 = {
1815 .clkctrl_offs = DRA7XX_CM_L4PER_UART3_CLKCTRL_OFFSET,
1816 .context_offs = DRA7XX_RM_L4PER_UART3_CONTEXT_OFFSET,
1817 .modulemode = MODULEMODE_SWCTRL,
1818 },
1819 },
1820};
1821
1822/* uart4 */
1823static struct omap_hwmod dra7xx_uart4_hwmod = {
1824 .name = "uart4",
1825 .class = &dra7xx_uart_hwmod_class,
1826 .clkdm_name = "l4per_clkdm",
1827 .main_clk = "uart4_gfclk_mux",
1828 .flags = HWMOD_SWSUP_SIDLE_ACT,
1829 .prcm = {
1830 .omap4 = {
1831 .clkctrl_offs = DRA7XX_CM_L4PER_UART4_CLKCTRL_OFFSET,
1832 .context_offs = DRA7XX_RM_L4PER_UART4_CONTEXT_OFFSET,
1833 .modulemode = MODULEMODE_SWCTRL,
1834 },
1835 },
1836};
1837
1838/* uart5 */
1839static struct omap_hwmod dra7xx_uart5_hwmod = {
1840 .name = "uart5",
1841 .class = &dra7xx_uart_hwmod_class,
1842 .clkdm_name = "l4per_clkdm",
1843 .main_clk = "uart5_gfclk_mux",
1844 .flags = HWMOD_SWSUP_SIDLE_ACT,
1845 .prcm = {
1846 .omap4 = {
1847 .clkctrl_offs = DRA7XX_CM_L4PER_UART5_CLKCTRL_OFFSET,
1848 .context_offs = DRA7XX_RM_L4PER_UART5_CONTEXT_OFFSET,
1849 .modulemode = MODULEMODE_SWCTRL,
1850 },
1851 },
1852};
1853
1854/* uart6 */
1855static struct omap_hwmod dra7xx_uart6_hwmod = {
1856 .name = "uart6",
1857 .class = &dra7xx_uart_hwmod_class,
1858 .clkdm_name = "ipu_clkdm",
1859 .main_clk = "uart6_gfclk_mux",
1860 .flags = HWMOD_SWSUP_SIDLE_ACT,
1861 .prcm = {
1862 .omap4 = {
1863 .clkctrl_offs = DRA7XX_CM_IPU_UART6_CLKCTRL_OFFSET,
1864 .context_offs = DRA7XX_RM_IPU_UART6_CONTEXT_OFFSET,
1865 .modulemode = MODULEMODE_SWCTRL,
1866 },
1867 },
1868};
1869
1870/*
1871 * 'usb_otg_ss' class
1872 *
1873 */
1874
1875static struct omap_hwmod_class dra7xx_usb_otg_ss_hwmod_class = {
1876 .name = "usb_otg_ss",
1877};
1878
1879/* usb_otg_ss1 */
1880static struct omap_hwmod_opt_clk usb_otg_ss1_opt_clks[] = {
1881 { .role = "refclk960m", .clk = "usb_otg_ss1_refclk960m" },
1882};
1883
1884static struct omap_hwmod dra7xx_usb_otg_ss1_hwmod = {
1885 .name = "usb_otg_ss1",
1886 .class = &dra7xx_usb_otg_ss_hwmod_class,
1887 .clkdm_name = "l3init_clkdm",
1888 .main_clk = "dpll_core_h13x2_ck",
1889 .prcm = {
1890 .omap4 = {
1891 .clkctrl_offs = DRA7XX_CM_L3INIT_USB_OTG_SS1_CLKCTRL_OFFSET,
1892 .context_offs = DRA7XX_RM_L3INIT_USB_OTG_SS1_CONTEXT_OFFSET,
1893 .modulemode = MODULEMODE_HWCTRL,
1894 },
1895 },
1896 .opt_clks = usb_otg_ss1_opt_clks,
1897 .opt_clks_cnt = ARRAY_SIZE(usb_otg_ss1_opt_clks),
1898};
1899
1900/* usb_otg_ss2 */
1901static struct omap_hwmod_opt_clk usb_otg_ss2_opt_clks[] = {
1902 { .role = "refclk960m", .clk = "usb_otg_ss2_refclk960m" },
1903};
1904
1905static struct omap_hwmod dra7xx_usb_otg_ss2_hwmod = {
1906 .name = "usb_otg_ss2",
1907 .class = &dra7xx_usb_otg_ss_hwmod_class,
1908 .clkdm_name = "l3init_clkdm",
1909 .main_clk = "dpll_core_h13x2_ck",
1910 .prcm = {
1911 .omap4 = {
1912 .clkctrl_offs = DRA7XX_CM_L3INIT_USB_OTG_SS2_CLKCTRL_OFFSET,
1913 .context_offs = DRA7XX_RM_L3INIT_USB_OTG_SS2_CONTEXT_OFFSET,
1914 .modulemode = MODULEMODE_HWCTRL,
1915 },
1916 },
1917 .opt_clks = usb_otg_ss2_opt_clks,
1918 .opt_clks_cnt = ARRAY_SIZE(usb_otg_ss2_opt_clks),
1919};
1920
1921/* usb_otg_ss3 */
1922static struct omap_hwmod dra7xx_usb_otg_ss3_hwmod = {
1923 .name = "usb_otg_ss3",
1924 .class = &dra7xx_usb_otg_ss_hwmod_class,
1925 .clkdm_name = "l3init_clkdm",
1926 .main_clk = "dpll_core_h13x2_ck",
1927 .prcm = {
1928 .omap4 = {
1929 .clkctrl_offs = DRA7XX_CM_L3INIT_USB_OTG_SS3_CLKCTRL_OFFSET,
1930 .context_offs = DRA7XX_RM_L3INIT_USB_OTG_SS3_CONTEXT_OFFSET,
1931 .modulemode = MODULEMODE_HWCTRL,
1932 },
1933 },
1934};
1935
1936/* usb_otg_ss4 */
1937static struct omap_hwmod dra7xx_usb_otg_ss4_hwmod = {
1938 .name = "usb_otg_ss4",
1939 .class = &dra7xx_usb_otg_ss_hwmod_class,
1940 .clkdm_name = "l3init_clkdm",
1941 .main_clk = "dpll_core_h13x2_ck",
1942 .prcm = {
1943 .omap4 = {
1944 .clkctrl_offs = DRA7XX_CM_L3INIT_USB_OTG_SS4_CLKCTRL_OFFSET,
1945 .context_offs = DRA7XX_RM_L3INIT_USB_OTG_SS4_CONTEXT_OFFSET,
1946 .modulemode = MODULEMODE_HWCTRL,
1947 },
1948 },
1949};
1950
1951/*
1952 * 'vcp' class
1953 *
1954 */
1955
1956static struct omap_hwmod_class dra7xx_vcp_hwmod_class = {
1957 .name = "vcp",
1958};
1959
1960/* vcp1 */
1961static struct omap_hwmod dra7xx_vcp1_hwmod = {
1962 .name = "vcp1",
1963 .class = &dra7xx_vcp_hwmod_class,
1964 .clkdm_name = "l3main1_clkdm",
1965 .main_clk = "l3_iclk_div",
1966 .prcm = {
1967 .omap4 = {
1968 .clkctrl_offs = DRA7XX_CM_L3MAIN1_VCP1_CLKCTRL_OFFSET,
1969 .context_offs = DRA7XX_RM_L3MAIN1_VCP1_CONTEXT_OFFSET,
1970 },
1971 },
1972};
1973
1974/* vcp2 */
1975static struct omap_hwmod dra7xx_vcp2_hwmod = {
1976 .name = "vcp2",
1977 .class = &dra7xx_vcp_hwmod_class,
1978 .clkdm_name = "l3main1_clkdm",
1979 .main_clk = "l3_iclk_div",
1980 .prcm = {
1981 .omap4 = {
1982 .clkctrl_offs = DRA7XX_CM_L3MAIN1_VCP2_CLKCTRL_OFFSET,
1983 .context_offs = DRA7XX_RM_L3MAIN1_VCP2_CONTEXT_OFFSET,
1984 },
1985 },
1986};
1987
1988/*
1989 * 'wd_timer' class
1990 *
1991 */
1992
1993static struct omap_hwmod_class_sysconfig dra7xx_wd_timer_sysc = {
1994 .rev_offs = 0x0000,
1995 .sysc_offs = 0x0010,
1996 .syss_offs = 0x0014,
1997 .sysc_flags = (SYSC_HAS_EMUFREE | SYSC_HAS_SIDLEMODE |
1998 SYSC_HAS_SOFTRESET | SYSS_HAS_RESET_STATUS),
1999 .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
2000 SIDLE_SMART_WKUP),
2001 .sysc_fields = &omap_hwmod_sysc_type1,
2002};
2003
2004static struct omap_hwmod_class dra7xx_wd_timer_hwmod_class = {
2005 .name = "wd_timer",
2006 .sysc = &dra7xx_wd_timer_sysc,
2007 .pre_shutdown = &omap2_wd_timer_disable,
2008 .reset = &omap2_wd_timer_reset,
2009};
2010
2011/* wd_timer2 */
2012static struct omap_hwmod dra7xx_wd_timer2_hwmod = {
2013 .name = "wd_timer2",
2014 .class = &dra7xx_wd_timer_hwmod_class,
2015 .clkdm_name = "wkupaon_clkdm",
2016 .main_clk = "sys_32k_ck",
2017 .prcm = {
2018 .omap4 = {
2019 .clkctrl_offs = DRA7XX_CM_WKUPAON_WD_TIMER2_CLKCTRL_OFFSET,
2020 .context_offs = DRA7XX_RM_WKUPAON_WD_TIMER2_CONTEXT_OFFSET,
2021 .modulemode = MODULEMODE_SWCTRL,
2022 },
2023 },
2024};
2025
2026
2027/*
2028 * Interfaces
2029 */
2030
2031/* l3_main_2 -> l3_instr */
2032static struct omap_hwmod_ocp_if dra7xx_l3_main_2__l3_instr = {
2033 .master = &dra7xx_l3_main_2_hwmod,
2034 .slave = &dra7xx_l3_instr_hwmod,
2035 .clk = "l3_iclk_div",
2036 .user = OCP_USER_MPU | OCP_USER_SDMA,
2037};
2038
2039/* l4_cfg -> l3_main_1 */
2040static struct omap_hwmod_ocp_if dra7xx_l4_cfg__l3_main_1 = {
2041 .master = &dra7xx_l4_cfg_hwmod,
2042 .slave = &dra7xx_l3_main_1_hwmod,
2043 .clk = "l3_iclk_div",
2044 .user = OCP_USER_MPU | OCP_USER_SDMA,
2045};
2046
2047/* mpu -> l3_main_1 */
2048static struct omap_hwmod_ocp_if dra7xx_mpu__l3_main_1 = {
2049 .master = &dra7xx_mpu_hwmod,
2050 .slave = &dra7xx_l3_main_1_hwmod,
2051 .clk = "l3_iclk_div",
2052 .user = OCP_USER_MPU,
2053};
2054
2055/* l3_main_1 -> l3_main_2 */
2056static struct omap_hwmod_ocp_if dra7xx_l3_main_1__l3_main_2 = {
2057 .master = &dra7xx_l3_main_1_hwmod,
2058 .slave = &dra7xx_l3_main_2_hwmod,
2059 .clk = "l3_iclk_div",
2060 .user = OCP_USER_MPU,
2061};
2062
2063/* l4_cfg -> l3_main_2 */
2064static struct omap_hwmod_ocp_if dra7xx_l4_cfg__l3_main_2 = {
2065 .master = &dra7xx_l4_cfg_hwmod,
2066 .slave = &dra7xx_l3_main_2_hwmod,
2067 .clk = "l3_iclk_div",
2068 .user = OCP_USER_MPU | OCP_USER_SDMA,
2069};
2070
2071/* l3_main_1 -> l4_cfg */
2072static struct omap_hwmod_ocp_if dra7xx_l3_main_1__l4_cfg = {
2073 .master = &dra7xx_l3_main_1_hwmod,
2074 .slave = &dra7xx_l4_cfg_hwmod,
2075 .clk = "l3_iclk_div",
2076 .user = OCP_USER_MPU | OCP_USER_SDMA,
2077};
2078
2079/* l3_main_1 -> l4_per1 */
2080static struct omap_hwmod_ocp_if dra7xx_l3_main_1__l4_per1 = {
2081 .master = &dra7xx_l3_main_1_hwmod,
2082 .slave = &dra7xx_l4_per1_hwmod,
2083 .clk = "l3_iclk_div",
2084 .user = OCP_USER_MPU | OCP_USER_SDMA,
2085};
2086
2087/* l3_main_1 -> l4_per2 */
2088static struct omap_hwmod_ocp_if dra7xx_l3_main_1__l4_per2 = {
2089 .master = &dra7xx_l3_main_1_hwmod,
2090 .slave = &dra7xx_l4_per2_hwmod,
2091 .clk = "l3_iclk_div",
2092 .user = OCP_USER_MPU | OCP_USER_SDMA,
2093};
2094
2095/* l3_main_1 -> l4_per3 */
2096static struct omap_hwmod_ocp_if dra7xx_l3_main_1__l4_per3 = {
2097 .master = &dra7xx_l3_main_1_hwmod,
2098 .slave = &dra7xx_l4_per3_hwmod,
2099 .clk = "l3_iclk_div",
2100 .user = OCP_USER_MPU | OCP_USER_SDMA,
2101};
2102
2103/* l3_main_1 -> l4_wkup */
2104static struct omap_hwmod_ocp_if dra7xx_l3_main_1__l4_wkup = {
2105 .master = &dra7xx_l3_main_1_hwmod,
2106 .slave = &dra7xx_l4_wkup_hwmod,
2107 .clk = "wkupaon_iclk_mux",
2108 .user = OCP_USER_MPU | OCP_USER_SDMA,
2109};
2110
2111/* l4_per2 -> atl */
2112static struct omap_hwmod_ocp_if dra7xx_l4_per2__atl = {
2113 .master = &dra7xx_l4_per2_hwmod,
2114 .slave = &dra7xx_atl_hwmod,
2115 .clk = "l3_iclk_div",
2116 .user = OCP_USER_MPU | OCP_USER_SDMA,
2117};
2118
2119/* l3_main_1 -> bb2d */
2120static struct omap_hwmod_ocp_if dra7xx_l3_main_1__bb2d = {
2121 .master = &dra7xx_l3_main_1_hwmod,
2122 .slave = &dra7xx_bb2d_hwmod,
2123 .clk = "l3_iclk_div",
2124 .user = OCP_USER_MPU | OCP_USER_SDMA,
2125};
2126
2127/* l4_wkup -> counter_32k */
2128static struct omap_hwmod_ocp_if dra7xx_l4_wkup__counter_32k = {
2129 .master = &dra7xx_l4_wkup_hwmod,
2130 .slave = &dra7xx_counter_32k_hwmod,
2131 .clk = "wkupaon_iclk_mux",
2132 .user = OCP_USER_MPU | OCP_USER_SDMA,
2133};
2134
2135/* l4_wkup -> ctrl_module_wkup */
2136static struct omap_hwmod_ocp_if dra7xx_l4_wkup__ctrl_module_wkup = {
2137 .master = &dra7xx_l4_wkup_hwmod,
2138 .slave = &dra7xx_ctrl_module_wkup_hwmod,
2139 .clk = "wkupaon_iclk_mux",
2140 .user = OCP_USER_MPU | OCP_USER_SDMA,
2141};
2142
Mugunthan V N077c42f2014-07-08 18:46:39 +05302143static struct omap_hwmod_ocp_if dra7xx_l4_per2__cpgmac0 = {
2144 .master = &dra7xx_l4_per2_hwmod,
2145 .slave = &dra7xx_gmac_hwmod,
2146 .clk = "dpll_gmac_ck",
2147 .user = OCP_USER_MPU,
2148};
2149
2150static struct omap_hwmod_ocp_if dra7xx_gmac__mdio = {
2151 .master = &dra7xx_gmac_hwmod,
2152 .slave = &dra7xx_mdio_hwmod,
2153 .user = OCP_USER_MPU,
2154};
2155
Ambresh K90020c72013-07-09 13:02:16 +05302156/* l4_wkup -> dcan1 */
2157static struct omap_hwmod_ocp_if dra7xx_l4_wkup__dcan1 = {
2158 .master = &dra7xx_l4_wkup_hwmod,
2159 .slave = &dra7xx_dcan1_hwmod,
2160 .clk = "wkupaon_iclk_mux",
2161 .user = OCP_USER_MPU | OCP_USER_SDMA,
2162};
2163
2164/* l4_per2 -> dcan2 */
2165static struct omap_hwmod_ocp_if dra7xx_l4_per2__dcan2 = {
2166 .master = &dra7xx_l4_per2_hwmod,
2167 .slave = &dra7xx_dcan2_hwmod,
2168 .clk = "l3_iclk_div",
2169 .user = OCP_USER_MPU | OCP_USER_SDMA,
2170};
2171
2172static struct omap_hwmod_addr_space dra7xx_dma_system_addrs[] = {
2173 {
2174 .pa_start = 0x4a056000,
2175 .pa_end = 0x4a056fff,
2176 .flags = ADDR_TYPE_RT
2177 },
2178 { }
2179};
2180
2181/* l4_cfg -> dma_system */
2182static struct omap_hwmod_ocp_if dra7xx_l4_cfg__dma_system = {
2183 .master = &dra7xx_l4_cfg_hwmod,
2184 .slave = &dra7xx_dma_system_hwmod,
2185 .clk = "l3_iclk_div",
2186 .addr = dra7xx_dma_system_addrs,
2187 .user = OCP_USER_MPU | OCP_USER_SDMA,
2188};
2189
2190static struct omap_hwmod_addr_space dra7xx_dss_addrs[] = {
2191 {
2192 .name = "family",
2193 .pa_start = 0x58000000,
2194 .pa_end = 0x5800007f,
2195 .flags = ADDR_TYPE_RT
2196 },
2197};
2198
2199/* l3_main_1 -> dss */
2200static struct omap_hwmod_ocp_if dra7xx_l3_main_1__dss = {
2201 .master = &dra7xx_l3_main_1_hwmod,
2202 .slave = &dra7xx_dss_hwmod,
2203 .clk = "l3_iclk_div",
2204 .addr = dra7xx_dss_addrs,
2205 .user = OCP_USER_MPU | OCP_USER_SDMA,
2206};
2207
2208static struct omap_hwmod_addr_space dra7xx_dss_dispc_addrs[] = {
2209 {
2210 .name = "dispc",
2211 .pa_start = 0x58001000,
2212 .pa_end = 0x58001fff,
2213 .flags = ADDR_TYPE_RT
2214 },
2215};
2216
2217/* l3_main_1 -> dispc */
2218static struct omap_hwmod_ocp_if dra7xx_l3_main_1__dispc = {
2219 .master = &dra7xx_l3_main_1_hwmod,
2220 .slave = &dra7xx_dss_dispc_hwmod,
2221 .clk = "l3_iclk_div",
2222 .addr = dra7xx_dss_dispc_addrs,
2223 .user = OCP_USER_MPU | OCP_USER_SDMA,
2224};
2225
2226static struct omap_hwmod_addr_space dra7xx_dss_hdmi_addrs[] = {
2227 {
2228 .name = "hdmi_wp",
2229 .pa_start = 0x58040000,
2230 .pa_end = 0x580400ff,
2231 .flags = ADDR_TYPE_RT
2232 },
2233 { }
2234};
2235
2236/* l3_main_1 -> dispc */
2237static struct omap_hwmod_ocp_if dra7xx_l3_main_1__hdmi = {
2238 .master = &dra7xx_l3_main_1_hwmod,
2239 .slave = &dra7xx_dss_hdmi_hwmod,
2240 .clk = "l3_iclk_div",
2241 .addr = dra7xx_dss_hdmi_addrs,
2242 .user = OCP_USER_MPU | OCP_USER_SDMA,
2243};
2244
2245static struct omap_hwmod_addr_space dra7xx_elm_addrs[] = {
2246 {
2247 .pa_start = 0x48078000,
2248 .pa_end = 0x48078fff,
2249 .flags = ADDR_TYPE_RT
2250 },
2251 { }
2252};
2253
2254/* l4_per1 -> elm */
2255static struct omap_hwmod_ocp_if dra7xx_l4_per1__elm = {
2256 .master = &dra7xx_l4_per1_hwmod,
2257 .slave = &dra7xx_elm_hwmod,
2258 .clk = "l3_iclk_div",
2259 .addr = dra7xx_elm_addrs,
2260 .user = OCP_USER_MPU | OCP_USER_SDMA,
2261};
2262
2263/* l4_wkup -> gpio1 */
2264static struct omap_hwmod_ocp_if dra7xx_l4_wkup__gpio1 = {
2265 .master = &dra7xx_l4_wkup_hwmod,
2266 .slave = &dra7xx_gpio1_hwmod,
2267 .clk = "wkupaon_iclk_mux",
2268 .user = OCP_USER_MPU | OCP_USER_SDMA,
2269};
2270
2271/* l4_per1 -> gpio2 */
2272static struct omap_hwmod_ocp_if dra7xx_l4_per1__gpio2 = {
2273 .master = &dra7xx_l4_per1_hwmod,
2274 .slave = &dra7xx_gpio2_hwmod,
2275 .clk = "l3_iclk_div",
2276 .user = OCP_USER_MPU | OCP_USER_SDMA,
2277};
2278
2279/* l4_per1 -> gpio3 */
2280static struct omap_hwmod_ocp_if dra7xx_l4_per1__gpio3 = {
2281 .master = &dra7xx_l4_per1_hwmod,
2282 .slave = &dra7xx_gpio3_hwmod,
2283 .clk = "l3_iclk_div",
2284 .user = OCP_USER_MPU | OCP_USER_SDMA,
2285};
2286
2287/* l4_per1 -> gpio4 */
2288static struct omap_hwmod_ocp_if dra7xx_l4_per1__gpio4 = {
2289 .master = &dra7xx_l4_per1_hwmod,
2290 .slave = &dra7xx_gpio4_hwmod,
2291 .clk = "l3_iclk_div",
2292 .user = OCP_USER_MPU | OCP_USER_SDMA,
2293};
2294
2295/* l4_per1 -> gpio5 */
2296static struct omap_hwmod_ocp_if dra7xx_l4_per1__gpio5 = {
2297 .master = &dra7xx_l4_per1_hwmod,
2298 .slave = &dra7xx_gpio5_hwmod,
2299 .clk = "l3_iclk_div",
2300 .user = OCP_USER_MPU | OCP_USER_SDMA,
2301};
2302
2303/* l4_per1 -> gpio6 */
2304static struct omap_hwmod_ocp_if dra7xx_l4_per1__gpio6 = {
2305 .master = &dra7xx_l4_per1_hwmod,
2306 .slave = &dra7xx_gpio6_hwmod,
2307 .clk = "l3_iclk_div",
2308 .user = OCP_USER_MPU | OCP_USER_SDMA,
2309};
2310
2311/* l4_per1 -> gpio7 */
2312static struct omap_hwmod_ocp_if dra7xx_l4_per1__gpio7 = {
2313 .master = &dra7xx_l4_per1_hwmod,
2314 .slave = &dra7xx_gpio7_hwmod,
2315 .clk = "l3_iclk_div",
2316 .user = OCP_USER_MPU | OCP_USER_SDMA,
2317};
2318
2319/* l4_per1 -> gpio8 */
2320static struct omap_hwmod_ocp_if dra7xx_l4_per1__gpio8 = {
2321 .master = &dra7xx_l4_per1_hwmod,
2322 .slave = &dra7xx_gpio8_hwmod,
2323 .clk = "l3_iclk_div",
2324 .user = OCP_USER_MPU | OCP_USER_SDMA,
2325};
2326
2327static struct omap_hwmod_addr_space dra7xx_gpmc_addrs[] = {
2328 {
2329 .pa_start = 0x50000000,
2330 .pa_end = 0x500003ff,
2331 .flags = ADDR_TYPE_RT
2332 },
2333 { }
2334};
2335
2336/* l3_main_1 -> gpmc */
2337static struct omap_hwmod_ocp_if dra7xx_l3_main_1__gpmc = {
2338 .master = &dra7xx_l3_main_1_hwmod,
2339 .slave = &dra7xx_gpmc_hwmod,
2340 .clk = "l3_iclk_div",
2341 .addr = dra7xx_gpmc_addrs,
2342 .user = OCP_USER_MPU | OCP_USER_SDMA,
2343};
2344
2345static struct omap_hwmod_addr_space dra7xx_hdq1w_addrs[] = {
2346 {
2347 .pa_start = 0x480b2000,
2348 .pa_end = 0x480b201f,
2349 .flags = ADDR_TYPE_RT
2350 },
2351 { }
2352};
2353
2354/* l4_per1 -> hdq1w */
2355static struct omap_hwmod_ocp_if dra7xx_l4_per1__hdq1w = {
2356 .master = &dra7xx_l4_per1_hwmod,
2357 .slave = &dra7xx_hdq1w_hwmod,
2358 .clk = "l3_iclk_div",
2359 .addr = dra7xx_hdq1w_addrs,
2360 .user = OCP_USER_MPU | OCP_USER_SDMA,
2361};
2362
2363/* l4_per1 -> i2c1 */
2364static struct omap_hwmod_ocp_if dra7xx_l4_per1__i2c1 = {
2365 .master = &dra7xx_l4_per1_hwmod,
2366 .slave = &dra7xx_i2c1_hwmod,
2367 .clk = "l3_iclk_div",
2368 .user = OCP_USER_MPU | OCP_USER_SDMA,
2369};
2370
2371/* l4_per1 -> i2c2 */
2372static struct omap_hwmod_ocp_if dra7xx_l4_per1__i2c2 = {
2373 .master = &dra7xx_l4_per1_hwmod,
2374 .slave = &dra7xx_i2c2_hwmod,
2375 .clk = "l3_iclk_div",
2376 .user = OCP_USER_MPU | OCP_USER_SDMA,
2377};
2378
2379/* l4_per1 -> i2c3 */
2380static struct omap_hwmod_ocp_if dra7xx_l4_per1__i2c3 = {
2381 .master = &dra7xx_l4_per1_hwmod,
2382 .slave = &dra7xx_i2c3_hwmod,
2383 .clk = "l3_iclk_div",
2384 .user = OCP_USER_MPU | OCP_USER_SDMA,
2385};
2386
2387/* l4_per1 -> i2c4 */
2388static struct omap_hwmod_ocp_if dra7xx_l4_per1__i2c4 = {
2389 .master = &dra7xx_l4_per1_hwmod,
2390 .slave = &dra7xx_i2c4_hwmod,
2391 .clk = "l3_iclk_div",
2392 .user = OCP_USER_MPU | OCP_USER_SDMA,
2393};
2394
2395/* l4_per1 -> i2c5 */
2396static struct omap_hwmod_ocp_if dra7xx_l4_per1__i2c5 = {
2397 .master = &dra7xx_l4_per1_hwmod,
2398 .slave = &dra7xx_i2c5_hwmod,
2399 .clk = "l3_iclk_div",
2400 .user = OCP_USER_MPU | OCP_USER_SDMA,
2401};
2402
2403/* l4_per1 -> mcspi1 */
2404static struct omap_hwmod_ocp_if dra7xx_l4_per1__mcspi1 = {
2405 .master = &dra7xx_l4_per1_hwmod,
2406 .slave = &dra7xx_mcspi1_hwmod,
2407 .clk = "l3_iclk_div",
2408 .user = OCP_USER_MPU | OCP_USER_SDMA,
2409};
2410
2411/* l4_per1 -> mcspi2 */
2412static struct omap_hwmod_ocp_if dra7xx_l4_per1__mcspi2 = {
2413 .master = &dra7xx_l4_per1_hwmod,
2414 .slave = &dra7xx_mcspi2_hwmod,
2415 .clk = "l3_iclk_div",
2416 .user = OCP_USER_MPU | OCP_USER_SDMA,
2417};
2418
2419/* l4_per1 -> mcspi3 */
2420static struct omap_hwmod_ocp_if dra7xx_l4_per1__mcspi3 = {
2421 .master = &dra7xx_l4_per1_hwmod,
2422 .slave = &dra7xx_mcspi3_hwmod,
2423 .clk = "l3_iclk_div",
2424 .user = OCP_USER_MPU | OCP_USER_SDMA,
2425};
2426
2427/* l4_per1 -> mcspi4 */
2428static struct omap_hwmod_ocp_if dra7xx_l4_per1__mcspi4 = {
2429 .master = &dra7xx_l4_per1_hwmod,
2430 .slave = &dra7xx_mcspi4_hwmod,
2431 .clk = "l3_iclk_div",
2432 .user = OCP_USER_MPU | OCP_USER_SDMA,
2433};
2434
2435/* l4_per1 -> mmc1 */
2436static struct omap_hwmod_ocp_if dra7xx_l4_per1__mmc1 = {
2437 .master = &dra7xx_l4_per1_hwmod,
2438 .slave = &dra7xx_mmc1_hwmod,
2439 .clk = "l3_iclk_div",
2440 .user = OCP_USER_MPU | OCP_USER_SDMA,
2441};
2442
2443/* l4_per1 -> mmc2 */
2444static struct omap_hwmod_ocp_if dra7xx_l4_per1__mmc2 = {
2445 .master = &dra7xx_l4_per1_hwmod,
2446 .slave = &dra7xx_mmc2_hwmod,
2447 .clk = "l3_iclk_div",
2448 .user = OCP_USER_MPU | OCP_USER_SDMA,
2449};
2450
2451/* l4_per1 -> mmc3 */
2452static struct omap_hwmod_ocp_if dra7xx_l4_per1__mmc3 = {
2453 .master = &dra7xx_l4_per1_hwmod,
2454 .slave = &dra7xx_mmc3_hwmod,
2455 .clk = "l3_iclk_div",
2456 .user = OCP_USER_MPU | OCP_USER_SDMA,
2457};
2458
2459/* l4_per1 -> mmc4 */
2460static struct omap_hwmod_ocp_if dra7xx_l4_per1__mmc4 = {
2461 .master = &dra7xx_l4_per1_hwmod,
2462 .slave = &dra7xx_mmc4_hwmod,
2463 .clk = "l3_iclk_div",
2464 .user = OCP_USER_MPU | OCP_USER_SDMA,
2465};
2466
2467/* l4_cfg -> mpu */
2468static struct omap_hwmod_ocp_if dra7xx_l4_cfg__mpu = {
2469 .master = &dra7xx_l4_cfg_hwmod,
2470 .slave = &dra7xx_mpu_hwmod,
2471 .clk = "l3_iclk_div",
2472 .user = OCP_USER_MPU | OCP_USER_SDMA,
2473};
2474
Ambresh K90020c72013-07-09 13:02:16 +05302475/* l4_cfg -> ocp2scp1 */
2476static struct omap_hwmod_ocp_if dra7xx_l4_cfg__ocp2scp1 = {
2477 .master = &dra7xx_l4_cfg_hwmod,
2478 .slave = &dra7xx_ocp2scp1_hwmod,
2479 .clk = "l4_root_clk_div",
Ambresh K90020c72013-07-09 13:02:16 +05302480 .user = OCP_USER_MPU | OCP_USER_SDMA,
2481};
2482
Roger Quadrosdf0d0f12014-07-05 17:44:58 -06002483/* l4_cfg -> ocp2scp3 */
2484static struct omap_hwmod_ocp_if dra7xx_l4_cfg__ocp2scp3 = {
2485 .master = &dra7xx_l4_cfg_hwmod,
2486 .slave = &dra7xx_ocp2scp3_hwmod,
2487 .clk = "l4_root_clk_div",
2488 .user = OCP_USER_MPU | OCP_USER_SDMA,
2489};
2490
Kishon Vijay Abraham I8dd3eb72014-07-09 14:32:47 +05302491/* l3_main_1 -> pcie1 */
2492static struct omap_hwmod_ocp_if dra7xx_l3_main_1__pcie1 = {
2493 .master = &dra7xx_l3_main_1_hwmod,
2494 .slave = &dra7xx_pcie1_hwmod,
2495 .clk = "l3_iclk_div",
2496 .user = OCP_USER_MPU | OCP_USER_SDMA,
2497};
2498
2499/* l4_cfg -> pcie1 */
2500static struct omap_hwmod_ocp_if dra7xx_l4_cfg__pcie1 = {
2501 .master = &dra7xx_l4_cfg_hwmod,
2502 .slave = &dra7xx_pcie1_hwmod,
2503 .clk = "l4_root_clk_div",
2504 .user = OCP_USER_MPU | OCP_USER_SDMA,
2505};
2506
2507/* l3_main_1 -> pcie2 */
2508static struct omap_hwmod_ocp_if dra7xx_l3_main_1__pcie2 = {
2509 .master = &dra7xx_l3_main_1_hwmod,
2510 .slave = &dra7xx_pcie2_hwmod,
2511 .clk = "l3_iclk_div",
2512 .user = OCP_USER_MPU | OCP_USER_SDMA,
2513};
2514
2515/* l4_cfg -> pcie2 */
2516static struct omap_hwmod_ocp_if dra7xx_l4_cfg__pcie2 = {
2517 .master = &dra7xx_l4_cfg_hwmod,
2518 .slave = &dra7xx_pcie2_hwmod,
2519 .clk = "l4_root_clk_div",
2520 .user = OCP_USER_MPU | OCP_USER_SDMA,
2521};
2522
Kishon Vijay Abraham I70c18ef72014-06-25 23:32:45 +05302523/* l4_cfg -> pcie1 phy */
2524static struct omap_hwmod_ocp_if dra7xx_l4_cfg__pcie1_phy = {
2525 .master = &dra7xx_l4_cfg_hwmod,
2526 .slave = &dra7xx_pcie1_phy_hwmod,
2527 .clk = "l4_root_clk_div",
2528 .user = OCP_USER_MPU | OCP_USER_SDMA,
2529};
2530
2531/* l4_cfg -> pcie2 phy */
2532static struct omap_hwmod_ocp_if dra7xx_l4_cfg__pcie2_phy = {
2533 .master = &dra7xx_l4_cfg_hwmod,
2534 .slave = &dra7xx_pcie2_phy_hwmod,
2535 .clk = "l4_root_clk_div",
2536 .user = OCP_USER_MPU | OCP_USER_SDMA,
2537};
2538
Ambresh K90020c72013-07-09 13:02:16 +05302539static struct omap_hwmod_addr_space dra7xx_qspi_addrs[] = {
2540 {
2541 .pa_start = 0x4b300000,
2542 .pa_end = 0x4b30007f,
2543 .flags = ADDR_TYPE_RT
2544 },
2545 { }
2546};
2547
2548/* l3_main_1 -> qspi */
2549static struct omap_hwmod_ocp_if dra7xx_l3_main_1__qspi = {
2550 .master = &dra7xx_l3_main_1_hwmod,
2551 .slave = &dra7xx_qspi_hwmod,
2552 .clk = "l3_iclk_div",
2553 .addr = dra7xx_qspi_addrs,
2554 .user = OCP_USER_MPU | OCP_USER_SDMA,
2555};
2556
2557static struct omap_hwmod_addr_space dra7xx_sata_addrs[] = {
2558 {
2559 .name = "sysc",
2560 .pa_start = 0x4a141100,
2561 .pa_end = 0x4a141107,
2562 .flags = ADDR_TYPE_RT
2563 },
2564 { }
2565};
2566
2567/* l4_cfg -> sata */
2568static struct omap_hwmod_ocp_if dra7xx_l4_cfg__sata = {
2569 .master = &dra7xx_l4_cfg_hwmod,
2570 .slave = &dra7xx_sata_hwmod,
2571 .clk = "l3_iclk_div",
2572 .addr = dra7xx_sata_addrs,
2573 .user = OCP_USER_MPU | OCP_USER_SDMA,
2574};
2575
2576static struct omap_hwmod_addr_space dra7xx_smartreflex_core_addrs[] = {
2577 {
2578 .pa_start = 0x4a0dd000,
2579 .pa_end = 0x4a0dd07f,
2580 .flags = ADDR_TYPE_RT
2581 },
2582 { }
2583};
2584
2585/* l4_cfg -> smartreflex_core */
2586static struct omap_hwmod_ocp_if dra7xx_l4_cfg__smartreflex_core = {
2587 .master = &dra7xx_l4_cfg_hwmod,
2588 .slave = &dra7xx_smartreflex_core_hwmod,
2589 .clk = "l4_root_clk_div",
2590 .addr = dra7xx_smartreflex_core_addrs,
2591 .user = OCP_USER_MPU | OCP_USER_SDMA,
2592};
2593
2594static struct omap_hwmod_addr_space dra7xx_smartreflex_mpu_addrs[] = {
2595 {
2596 .pa_start = 0x4a0d9000,
2597 .pa_end = 0x4a0d907f,
2598 .flags = ADDR_TYPE_RT
2599 },
2600 { }
2601};
2602
2603/* l4_cfg -> smartreflex_mpu */
2604static struct omap_hwmod_ocp_if dra7xx_l4_cfg__smartreflex_mpu = {
2605 .master = &dra7xx_l4_cfg_hwmod,
2606 .slave = &dra7xx_smartreflex_mpu_hwmod,
2607 .clk = "l4_root_clk_div",
2608 .addr = dra7xx_smartreflex_mpu_addrs,
2609 .user = OCP_USER_MPU | OCP_USER_SDMA,
2610};
2611
2612static struct omap_hwmod_addr_space dra7xx_spinlock_addrs[] = {
2613 {
2614 .pa_start = 0x4a0f6000,
2615 .pa_end = 0x4a0f6fff,
2616 .flags = ADDR_TYPE_RT
2617 },
2618 { }
2619};
2620
2621/* l4_cfg -> spinlock */
2622static struct omap_hwmod_ocp_if dra7xx_l4_cfg__spinlock = {
2623 .master = &dra7xx_l4_cfg_hwmod,
2624 .slave = &dra7xx_spinlock_hwmod,
2625 .clk = "l3_iclk_div",
2626 .addr = dra7xx_spinlock_addrs,
2627 .user = OCP_USER_MPU | OCP_USER_SDMA,
2628};
2629
2630/* l4_wkup -> timer1 */
2631static struct omap_hwmod_ocp_if dra7xx_l4_wkup__timer1 = {
2632 .master = &dra7xx_l4_wkup_hwmod,
2633 .slave = &dra7xx_timer1_hwmod,
2634 .clk = "wkupaon_iclk_mux",
2635 .user = OCP_USER_MPU | OCP_USER_SDMA,
2636};
2637
2638/* l4_per1 -> timer2 */
2639static struct omap_hwmod_ocp_if dra7xx_l4_per1__timer2 = {
2640 .master = &dra7xx_l4_per1_hwmod,
2641 .slave = &dra7xx_timer2_hwmod,
2642 .clk = "l3_iclk_div",
2643 .user = OCP_USER_MPU | OCP_USER_SDMA,
2644};
2645
2646/* l4_per1 -> timer3 */
2647static struct omap_hwmod_ocp_if dra7xx_l4_per1__timer3 = {
2648 .master = &dra7xx_l4_per1_hwmod,
2649 .slave = &dra7xx_timer3_hwmod,
2650 .clk = "l3_iclk_div",
2651 .user = OCP_USER_MPU | OCP_USER_SDMA,
2652};
2653
2654/* l4_per1 -> timer4 */
2655static struct omap_hwmod_ocp_if dra7xx_l4_per1__timer4 = {
2656 .master = &dra7xx_l4_per1_hwmod,
2657 .slave = &dra7xx_timer4_hwmod,
2658 .clk = "l3_iclk_div",
2659 .user = OCP_USER_MPU | OCP_USER_SDMA,
2660};
2661
2662/* l4_per3 -> timer5 */
2663static struct omap_hwmod_ocp_if dra7xx_l4_per3__timer5 = {
2664 .master = &dra7xx_l4_per3_hwmod,
2665 .slave = &dra7xx_timer5_hwmod,
2666 .clk = "l3_iclk_div",
2667 .user = OCP_USER_MPU | OCP_USER_SDMA,
2668};
2669
2670/* l4_per3 -> timer6 */
2671static struct omap_hwmod_ocp_if dra7xx_l4_per3__timer6 = {
2672 .master = &dra7xx_l4_per3_hwmod,
2673 .slave = &dra7xx_timer6_hwmod,
2674 .clk = "l3_iclk_div",
2675 .user = OCP_USER_MPU | OCP_USER_SDMA,
2676};
2677
2678/* l4_per3 -> timer7 */
2679static struct omap_hwmod_ocp_if dra7xx_l4_per3__timer7 = {
2680 .master = &dra7xx_l4_per3_hwmod,
2681 .slave = &dra7xx_timer7_hwmod,
2682 .clk = "l3_iclk_div",
2683 .user = OCP_USER_MPU | OCP_USER_SDMA,
2684};
2685
2686/* l4_per3 -> timer8 */
2687static struct omap_hwmod_ocp_if dra7xx_l4_per3__timer8 = {
2688 .master = &dra7xx_l4_per3_hwmod,
2689 .slave = &dra7xx_timer8_hwmod,
2690 .clk = "l3_iclk_div",
2691 .user = OCP_USER_MPU | OCP_USER_SDMA,
2692};
2693
2694/* l4_per1 -> timer9 */
2695static struct omap_hwmod_ocp_if dra7xx_l4_per1__timer9 = {
2696 .master = &dra7xx_l4_per1_hwmod,
2697 .slave = &dra7xx_timer9_hwmod,
2698 .clk = "l3_iclk_div",
2699 .user = OCP_USER_MPU | OCP_USER_SDMA,
2700};
2701
2702/* l4_per1 -> timer10 */
2703static struct omap_hwmod_ocp_if dra7xx_l4_per1__timer10 = {
2704 .master = &dra7xx_l4_per1_hwmod,
2705 .slave = &dra7xx_timer10_hwmod,
2706 .clk = "l3_iclk_div",
2707 .user = OCP_USER_MPU | OCP_USER_SDMA,
2708};
2709
2710/* l4_per1 -> timer11 */
2711static struct omap_hwmod_ocp_if dra7xx_l4_per1__timer11 = {
2712 .master = &dra7xx_l4_per1_hwmod,
2713 .slave = &dra7xx_timer11_hwmod,
2714 .clk = "l3_iclk_div",
2715 .user = OCP_USER_MPU | OCP_USER_SDMA,
2716};
2717
2718/* l4_per1 -> uart1 */
2719static struct omap_hwmod_ocp_if dra7xx_l4_per1__uart1 = {
2720 .master = &dra7xx_l4_per1_hwmod,
2721 .slave = &dra7xx_uart1_hwmod,
2722 .clk = "l3_iclk_div",
2723 .user = OCP_USER_MPU | OCP_USER_SDMA,
2724};
2725
2726/* l4_per1 -> uart2 */
2727static struct omap_hwmod_ocp_if dra7xx_l4_per1__uart2 = {
2728 .master = &dra7xx_l4_per1_hwmod,
2729 .slave = &dra7xx_uart2_hwmod,
2730 .clk = "l3_iclk_div",
2731 .user = OCP_USER_MPU | OCP_USER_SDMA,
2732};
2733
2734/* l4_per1 -> uart3 */
2735static struct omap_hwmod_ocp_if dra7xx_l4_per1__uart3 = {
2736 .master = &dra7xx_l4_per1_hwmod,
2737 .slave = &dra7xx_uart3_hwmod,
2738 .clk = "l3_iclk_div",
2739 .user = OCP_USER_MPU | OCP_USER_SDMA,
2740};
2741
2742/* l4_per1 -> uart4 */
2743static struct omap_hwmod_ocp_if dra7xx_l4_per1__uart4 = {
2744 .master = &dra7xx_l4_per1_hwmod,
2745 .slave = &dra7xx_uart4_hwmod,
2746 .clk = "l3_iclk_div",
2747 .user = OCP_USER_MPU | OCP_USER_SDMA,
2748};
2749
2750/* l4_per1 -> uart5 */
2751static struct omap_hwmod_ocp_if dra7xx_l4_per1__uart5 = {
2752 .master = &dra7xx_l4_per1_hwmod,
2753 .slave = &dra7xx_uart5_hwmod,
2754 .clk = "l3_iclk_div",
2755 .user = OCP_USER_MPU | OCP_USER_SDMA,
2756};
2757
2758/* l4_per1 -> uart6 */
2759static struct omap_hwmod_ocp_if dra7xx_l4_per1__uart6 = {
2760 .master = &dra7xx_l4_per1_hwmod,
2761 .slave = &dra7xx_uart6_hwmod,
2762 .clk = "l3_iclk_div",
2763 .user = OCP_USER_MPU | OCP_USER_SDMA,
2764};
2765
2766/* l4_per3 -> usb_otg_ss1 */
2767static struct omap_hwmod_ocp_if dra7xx_l4_per3__usb_otg_ss1 = {
2768 .master = &dra7xx_l4_per3_hwmod,
2769 .slave = &dra7xx_usb_otg_ss1_hwmod,
2770 .clk = "dpll_core_h13x2_ck",
2771 .user = OCP_USER_MPU | OCP_USER_SDMA,
2772};
2773
2774/* l4_per3 -> usb_otg_ss2 */
2775static struct omap_hwmod_ocp_if dra7xx_l4_per3__usb_otg_ss2 = {
2776 .master = &dra7xx_l4_per3_hwmod,
2777 .slave = &dra7xx_usb_otg_ss2_hwmod,
2778 .clk = "dpll_core_h13x2_ck",
2779 .user = OCP_USER_MPU | OCP_USER_SDMA,
2780};
2781
2782/* l4_per3 -> usb_otg_ss3 */
2783static struct omap_hwmod_ocp_if dra7xx_l4_per3__usb_otg_ss3 = {
2784 .master = &dra7xx_l4_per3_hwmod,
2785 .slave = &dra7xx_usb_otg_ss3_hwmod,
2786 .clk = "dpll_core_h13x2_ck",
2787 .user = OCP_USER_MPU | OCP_USER_SDMA,
2788};
2789
2790/* l4_per3 -> usb_otg_ss4 */
2791static struct omap_hwmod_ocp_if dra7xx_l4_per3__usb_otg_ss4 = {
2792 .master = &dra7xx_l4_per3_hwmod,
2793 .slave = &dra7xx_usb_otg_ss4_hwmod,
2794 .clk = "dpll_core_h13x2_ck",
2795 .user = OCP_USER_MPU | OCP_USER_SDMA,
2796};
2797
2798/* l3_main_1 -> vcp1 */
2799static struct omap_hwmod_ocp_if dra7xx_l3_main_1__vcp1 = {
2800 .master = &dra7xx_l3_main_1_hwmod,
2801 .slave = &dra7xx_vcp1_hwmod,
2802 .clk = "l3_iclk_div",
2803 .user = OCP_USER_MPU | OCP_USER_SDMA,
2804};
2805
2806/* l4_per2 -> vcp1 */
2807static struct omap_hwmod_ocp_if dra7xx_l4_per2__vcp1 = {
2808 .master = &dra7xx_l4_per2_hwmod,
2809 .slave = &dra7xx_vcp1_hwmod,
2810 .clk = "l3_iclk_div",
2811 .user = OCP_USER_MPU | OCP_USER_SDMA,
2812};
2813
2814/* l3_main_1 -> vcp2 */
2815static struct omap_hwmod_ocp_if dra7xx_l3_main_1__vcp2 = {
2816 .master = &dra7xx_l3_main_1_hwmod,
2817 .slave = &dra7xx_vcp2_hwmod,
2818 .clk = "l3_iclk_div",
2819 .user = OCP_USER_MPU | OCP_USER_SDMA,
2820};
2821
2822/* l4_per2 -> vcp2 */
2823static struct omap_hwmod_ocp_if dra7xx_l4_per2__vcp2 = {
2824 .master = &dra7xx_l4_per2_hwmod,
2825 .slave = &dra7xx_vcp2_hwmod,
2826 .clk = "l3_iclk_div",
2827 .user = OCP_USER_MPU | OCP_USER_SDMA,
2828};
2829
2830/* l4_wkup -> wd_timer2 */
2831static struct omap_hwmod_ocp_if dra7xx_l4_wkup__wd_timer2 = {
2832 .master = &dra7xx_l4_wkup_hwmod,
2833 .slave = &dra7xx_wd_timer2_hwmod,
2834 .clk = "wkupaon_iclk_mux",
2835 .user = OCP_USER_MPU | OCP_USER_SDMA,
2836};
2837
2838static struct omap_hwmod_ocp_if *dra7xx_hwmod_ocp_ifs[] __initdata = {
2839 &dra7xx_l3_main_2__l3_instr,
2840 &dra7xx_l4_cfg__l3_main_1,
2841 &dra7xx_mpu__l3_main_1,
2842 &dra7xx_l3_main_1__l3_main_2,
2843 &dra7xx_l4_cfg__l3_main_2,
2844 &dra7xx_l3_main_1__l4_cfg,
2845 &dra7xx_l3_main_1__l4_per1,
2846 &dra7xx_l3_main_1__l4_per2,
2847 &dra7xx_l3_main_1__l4_per3,
2848 &dra7xx_l3_main_1__l4_wkup,
2849 &dra7xx_l4_per2__atl,
2850 &dra7xx_l3_main_1__bb2d,
2851 &dra7xx_l4_wkup__counter_32k,
2852 &dra7xx_l4_wkup__ctrl_module_wkup,
2853 &dra7xx_l4_wkup__dcan1,
2854 &dra7xx_l4_per2__dcan2,
Mugunthan V N077c42f2014-07-08 18:46:39 +05302855 &dra7xx_l4_per2__cpgmac0,
2856 &dra7xx_gmac__mdio,
Ambresh K90020c72013-07-09 13:02:16 +05302857 &dra7xx_l4_cfg__dma_system,
2858 &dra7xx_l3_main_1__dss,
2859 &dra7xx_l3_main_1__dispc,
2860 &dra7xx_l3_main_1__hdmi,
2861 &dra7xx_l4_per1__elm,
2862 &dra7xx_l4_wkup__gpio1,
2863 &dra7xx_l4_per1__gpio2,
2864 &dra7xx_l4_per1__gpio3,
2865 &dra7xx_l4_per1__gpio4,
2866 &dra7xx_l4_per1__gpio5,
2867 &dra7xx_l4_per1__gpio6,
2868 &dra7xx_l4_per1__gpio7,
2869 &dra7xx_l4_per1__gpio8,
2870 &dra7xx_l3_main_1__gpmc,
2871 &dra7xx_l4_per1__hdq1w,
2872 &dra7xx_l4_per1__i2c1,
2873 &dra7xx_l4_per1__i2c2,
2874 &dra7xx_l4_per1__i2c3,
2875 &dra7xx_l4_per1__i2c4,
2876 &dra7xx_l4_per1__i2c5,
2877 &dra7xx_l4_per1__mcspi1,
2878 &dra7xx_l4_per1__mcspi2,
2879 &dra7xx_l4_per1__mcspi3,
2880 &dra7xx_l4_per1__mcspi4,
2881 &dra7xx_l4_per1__mmc1,
2882 &dra7xx_l4_per1__mmc2,
2883 &dra7xx_l4_per1__mmc3,
2884 &dra7xx_l4_per1__mmc4,
2885 &dra7xx_l4_cfg__mpu,
2886 &dra7xx_l4_cfg__ocp2scp1,
Roger Quadrosdf0d0f12014-07-05 17:44:58 -06002887 &dra7xx_l4_cfg__ocp2scp3,
Kishon Vijay Abraham I8dd3eb72014-07-09 14:32:47 +05302888 &dra7xx_l3_main_1__pcie1,
2889 &dra7xx_l4_cfg__pcie1,
2890 &dra7xx_l3_main_1__pcie2,
2891 &dra7xx_l4_cfg__pcie2,
Kishon Vijay Abraham I70c18ef72014-06-25 23:32:45 +05302892 &dra7xx_l4_cfg__pcie1_phy,
2893 &dra7xx_l4_cfg__pcie2_phy,
Ambresh K90020c72013-07-09 13:02:16 +05302894 &dra7xx_l3_main_1__qspi,
2895 &dra7xx_l4_cfg__sata,
2896 &dra7xx_l4_cfg__smartreflex_core,
2897 &dra7xx_l4_cfg__smartreflex_mpu,
2898 &dra7xx_l4_cfg__spinlock,
2899 &dra7xx_l4_wkup__timer1,
2900 &dra7xx_l4_per1__timer2,
2901 &dra7xx_l4_per1__timer3,
2902 &dra7xx_l4_per1__timer4,
2903 &dra7xx_l4_per3__timer5,
2904 &dra7xx_l4_per3__timer6,
2905 &dra7xx_l4_per3__timer7,
2906 &dra7xx_l4_per3__timer8,
2907 &dra7xx_l4_per1__timer9,
2908 &dra7xx_l4_per1__timer10,
2909 &dra7xx_l4_per1__timer11,
2910 &dra7xx_l4_per1__uart1,
2911 &dra7xx_l4_per1__uart2,
2912 &dra7xx_l4_per1__uart3,
2913 &dra7xx_l4_per1__uart4,
2914 &dra7xx_l4_per1__uart5,
2915 &dra7xx_l4_per1__uart6,
2916 &dra7xx_l4_per3__usb_otg_ss1,
2917 &dra7xx_l4_per3__usb_otg_ss2,
2918 &dra7xx_l4_per3__usb_otg_ss3,
2919 &dra7xx_l4_per3__usb_otg_ss4,
2920 &dra7xx_l3_main_1__vcp1,
2921 &dra7xx_l4_per2__vcp1,
2922 &dra7xx_l3_main_1__vcp2,
2923 &dra7xx_l4_per2__vcp2,
2924 &dra7xx_l4_wkup__wd_timer2,
2925 NULL,
2926};
2927
2928int __init dra7xx_hwmod_init(void)
2929{
2930 omap_hwmod_init();
2931 return omap_hwmod_register_links(dra7xx_hwmod_ocp_ifs);
2932}