2 * OMAP4 Clock domains framework
4 * Copyright (C) 2009 Texas Instruments, Inc.
5 * Copyright (C) 2009 Nokia Corporation
7 * Abhijit Pagare (abhijitpagare@ti.com)
8 * Benoit Cousson (b-cousson@ti.com)
10 * This file is automatically generated from the OMAP hardware databases.
11 * We respectfully ask that any modifications to this file be coordinated
12 * with the public linux-omap@vger.kernel.org mailing list and the
13 * authors above to ensure that the autogeneration scripts are kept
14 * up-to-date with the file contents.
16 * This program is free software; you can redistribute it and/or modify
17 * it under the terms of the GNU General Public License version 2 as
18 * published by the Free Software Foundation.
21 #include <linux/kernel.h>
24 #include "clockdomain.h"
28 #include "cm-regbits-44xx.h"
31 #include "prcm_mpu44xx.h"
33 /* Static Dependencies for OMAP4 Clock Domains */
35 static struct clkdm_dep ducati_wkup_sleep_deps
[] = {
37 .clkdm_name
= "abe_clkdm",
38 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
41 .clkdm_name
= "ivahd_clkdm",
42 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
45 .clkdm_name
= "l3_1_clkdm",
46 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
49 .clkdm_name
= "l3_2_clkdm",
50 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
53 .clkdm_name
= "l3_dss_clkdm",
54 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
57 .clkdm_name
= "l3_emif_clkdm",
58 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
61 .clkdm_name
= "l3_gfx_clkdm",
62 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
65 .clkdm_name
= "l3_init_clkdm",
66 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
69 .clkdm_name
= "l4_cfg_clkdm",
70 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
73 .clkdm_name
= "l4_per_clkdm",
74 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
77 .clkdm_name
= "l4_secure_clkdm",
78 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
81 .clkdm_name
= "l4_wkup_clkdm",
82 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
85 .clkdm_name
= "tesla_clkdm",
86 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
91 static struct clkdm_dep iss_wkup_sleep_deps
[] = {
93 .clkdm_name
= "ivahd_clkdm",
94 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
97 .clkdm_name
= "l3_1_clkdm",
98 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
101 .clkdm_name
= "l3_emif_clkdm",
102 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
107 static struct clkdm_dep ivahd_wkup_sleep_deps
[] = {
109 .clkdm_name
= "l3_1_clkdm",
110 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
113 .clkdm_name
= "l3_emif_clkdm",
114 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
119 static struct clkdm_dep l3_d2d_wkup_sleep_deps
[] = {
121 .clkdm_name
= "abe_clkdm",
122 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
125 .clkdm_name
= "ivahd_clkdm",
126 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
129 .clkdm_name
= "l3_1_clkdm",
130 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
133 .clkdm_name
= "l3_2_clkdm",
134 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
137 .clkdm_name
= "l3_emif_clkdm",
138 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
141 .clkdm_name
= "l3_init_clkdm",
142 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
145 .clkdm_name
= "l4_cfg_clkdm",
146 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
149 .clkdm_name
= "l4_per_clkdm",
150 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
155 static struct clkdm_dep l3_dma_wkup_sleep_deps
[] = {
157 .clkdm_name
= "abe_clkdm",
158 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
161 .clkdm_name
= "ducati_clkdm",
162 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
165 .clkdm_name
= "ivahd_clkdm",
166 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
169 .clkdm_name
= "l3_1_clkdm",
170 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
173 .clkdm_name
= "l3_dss_clkdm",
174 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
177 .clkdm_name
= "l3_emif_clkdm",
178 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
181 .clkdm_name
= "l3_init_clkdm",
182 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
185 .clkdm_name
= "l4_cfg_clkdm",
186 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
189 .clkdm_name
= "l4_per_clkdm",
190 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
193 .clkdm_name
= "l4_secure_clkdm",
194 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
197 .clkdm_name
= "l4_wkup_clkdm",
198 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
203 static struct clkdm_dep l3_dss_wkup_sleep_deps
[] = {
205 .clkdm_name
= "ivahd_clkdm",
206 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
209 .clkdm_name
= "l3_2_clkdm",
210 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
213 .clkdm_name
= "l3_emif_clkdm",
214 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
219 static struct clkdm_dep l3_gfx_wkup_sleep_deps
[] = {
221 .clkdm_name
= "ivahd_clkdm",
222 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
225 .clkdm_name
= "l3_1_clkdm",
226 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
229 .clkdm_name
= "l3_emif_clkdm",
230 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
235 static struct clkdm_dep l3_init_wkup_sleep_deps
[] = {
237 .clkdm_name
= "abe_clkdm",
238 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
241 .clkdm_name
= "ivahd_clkdm",
242 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
245 .clkdm_name
= "l3_emif_clkdm",
246 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
249 .clkdm_name
= "l4_cfg_clkdm",
250 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
253 .clkdm_name
= "l4_per_clkdm",
254 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
257 .clkdm_name
= "l4_secure_clkdm",
258 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
261 .clkdm_name
= "l4_wkup_clkdm",
262 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
267 static struct clkdm_dep l4_secure_wkup_sleep_deps
[] = {
269 .clkdm_name
= "l3_1_clkdm",
270 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
273 .clkdm_name
= "l3_emif_clkdm",
274 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
277 .clkdm_name
= "l4_per_clkdm",
278 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
283 static struct clkdm_dep mpuss_wkup_sleep_deps
[] = {
285 .clkdm_name
= "abe_clkdm",
286 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
289 .clkdm_name
= "ducati_clkdm",
290 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
293 .clkdm_name
= "ivahd_clkdm",
294 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
297 .clkdm_name
= "l3_1_clkdm",
298 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
301 .clkdm_name
= "l3_2_clkdm",
302 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
305 .clkdm_name
= "l3_dss_clkdm",
306 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
309 .clkdm_name
= "l3_emif_clkdm",
310 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
313 .clkdm_name
= "l3_gfx_clkdm",
314 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
317 .clkdm_name
= "l3_init_clkdm",
318 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
321 .clkdm_name
= "l4_cfg_clkdm",
322 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
325 .clkdm_name
= "l4_per_clkdm",
326 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
329 .clkdm_name
= "l4_secure_clkdm",
330 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
333 .clkdm_name
= "l4_wkup_clkdm",
334 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
337 .clkdm_name
= "tesla_clkdm",
338 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
343 static struct clkdm_dep tesla_wkup_sleep_deps
[] = {
345 .clkdm_name
= "abe_clkdm",
346 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
349 .clkdm_name
= "ivahd_clkdm",
350 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
353 .clkdm_name
= "l3_1_clkdm",
354 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
357 .clkdm_name
= "l3_2_clkdm",
358 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
361 .clkdm_name
= "l3_emif_clkdm",
362 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
365 .clkdm_name
= "l3_init_clkdm",
366 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
369 .clkdm_name
= "l4_cfg_clkdm",
370 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
373 .clkdm_name
= "l4_per_clkdm",
374 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
377 .clkdm_name
= "l4_wkup_clkdm",
378 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
)
383 static struct clockdomain l4_cefuse_44xx_clkdm
= {
384 .name
= "l4_cefuse_clkdm",
385 .pwrdm
= { .name
= "cefuse_pwrdm" },
386 .prcm_partition
= OMAP4430_CM2_PARTITION
,
387 .cm_inst
= OMAP4430_CM2_CEFUSE_INST
,
388 .clkdm_offs
= OMAP4430_CM2_CEFUSE_CEFUSE_CDOFFS
,
389 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
390 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
393 static struct clockdomain l4_cfg_44xx_clkdm
= {
394 .name
= "l4_cfg_clkdm",
395 .pwrdm
= { .name
= "core_pwrdm" },
396 .prcm_partition
= OMAP4430_CM2_PARTITION
,
397 .cm_inst
= OMAP4430_CM2_CORE_INST
,
398 .clkdm_offs
= OMAP4430_CM2_CORE_L4CFG_CDOFFS
,
399 .dep_bit
= OMAP4430_L4CFG_STATDEP_SHIFT
,
400 .flags
= CLKDM_CAN_HWSUP
,
401 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
404 static struct clockdomain tesla_44xx_clkdm
= {
405 .name
= "tesla_clkdm",
406 .pwrdm
= { .name
= "tesla_pwrdm" },
407 .prcm_partition
= OMAP4430_CM1_PARTITION
,
408 .cm_inst
= OMAP4430_CM1_TESLA_INST
,
409 .clkdm_offs
= OMAP4430_CM1_TESLA_TESLA_CDOFFS
,
410 .dep_bit
= OMAP4430_TESLA_STATDEP_SHIFT
,
411 .wkdep_srcs
= tesla_wkup_sleep_deps
,
412 .sleepdep_srcs
= tesla_wkup_sleep_deps
,
413 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
414 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
417 static struct clockdomain l3_gfx_44xx_clkdm
= {
418 .name
= "l3_gfx_clkdm",
419 .pwrdm
= { .name
= "gfx_pwrdm" },
420 .prcm_partition
= OMAP4430_CM2_PARTITION
,
421 .cm_inst
= OMAP4430_CM2_GFX_INST
,
422 .clkdm_offs
= OMAP4430_CM2_GFX_GFX_CDOFFS
,
423 .dep_bit
= OMAP4430_GFX_STATDEP_SHIFT
,
424 .wkdep_srcs
= l3_gfx_wkup_sleep_deps
,
425 .sleepdep_srcs
= l3_gfx_wkup_sleep_deps
,
426 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
427 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
430 static struct clockdomain ivahd_44xx_clkdm
= {
431 .name
= "ivahd_clkdm",
432 .pwrdm
= { .name
= "ivahd_pwrdm" },
433 .prcm_partition
= OMAP4430_CM2_PARTITION
,
434 .cm_inst
= OMAP4430_CM2_IVAHD_INST
,
435 .clkdm_offs
= OMAP4430_CM2_IVAHD_IVAHD_CDOFFS
,
436 .dep_bit
= OMAP4430_IVAHD_STATDEP_SHIFT
,
437 .wkdep_srcs
= ivahd_wkup_sleep_deps
,
438 .sleepdep_srcs
= ivahd_wkup_sleep_deps
,
439 .flags
= CLKDM_CAN_SWSUP
,
440 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
443 static struct clockdomain l4_secure_44xx_clkdm
= {
444 .name
= "l4_secure_clkdm",
445 .pwrdm
= { .name
= "l4per_pwrdm" },
446 .prcm_partition
= OMAP4430_CM2_PARTITION
,
447 .cm_inst
= OMAP4430_CM2_L4PER_INST
,
448 .clkdm_offs
= OMAP4430_CM2_L4PER_L4SEC_CDOFFS
,
449 .dep_bit
= OMAP4430_L4SEC_STATDEP_SHIFT
,
450 .wkdep_srcs
= l4_secure_wkup_sleep_deps
,
451 .sleepdep_srcs
= l4_secure_wkup_sleep_deps
,
452 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
453 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
456 static struct clockdomain l4_per_44xx_clkdm
= {
457 .name
= "l4_per_clkdm",
458 .pwrdm
= { .name
= "l4per_pwrdm" },
459 .prcm_partition
= OMAP4430_CM2_PARTITION
,
460 .cm_inst
= OMAP4430_CM2_L4PER_INST
,
461 .clkdm_offs
= OMAP4430_CM2_L4PER_L4PER_CDOFFS
,
462 .dep_bit
= OMAP4430_L4PER_STATDEP_SHIFT
,
463 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
464 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
467 static struct clockdomain abe_44xx_clkdm
= {
469 .pwrdm
= { .name
= "abe_pwrdm" },
470 .prcm_partition
= OMAP4430_CM1_PARTITION
,
471 .cm_inst
= OMAP4430_CM1_ABE_INST
,
472 .clkdm_offs
= OMAP4430_CM1_ABE_ABE_CDOFFS
,
473 .dep_bit
= OMAP4430_ABE_STATDEP_SHIFT
,
474 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
475 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
478 static struct clockdomain l3_instr_44xx_clkdm
= {
479 .name
= "l3_instr_clkdm",
480 .pwrdm
= { .name
= "core_pwrdm" },
481 .prcm_partition
= OMAP4430_CM2_PARTITION
,
482 .cm_inst
= OMAP4430_CM2_CORE_INST
,
483 .clkdm_offs
= OMAP4430_CM2_CORE_L3INSTR_CDOFFS
,
484 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
487 static struct clockdomain l3_init_44xx_clkdm
= {
488 .name
= "l3_init_clkdm",
489 .pwrdm
= { .name
= "l3init_pwrdm" },
490 .prcm_partition
= OMAP4430_CM2_PARTITION
,
491 .cm_inst
= OMAP4430_CM2_L3INIT_INST
,
492 .clkdm_offs
= OMAP4430_CM2_L3INIT_L3INIT_CDOFFS
,
493 .dep_bit
= OMAP4430_L3INIT_STATDEP_SHIFT
,
494 .wkdep_srcs
= l3_init_wkup_sleep_deps
,
495 .sleepdep_srcs
= l3_init_wkup_sleep_deps
,
496 .flags
= CLKDM_CAN_SWSUP
,
497 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
500 static struct clockdomain mpuss_44xx_clkdm
= {
501 .name
= "mpuss_clkdm",
502 .pwrdm
= { .name
= "mpu_pwrdm" },
503 .prcm_partition
= OMAP4430_CM1_PARTITION
,
504 .cm_inst
= OMAP4430_CM1_MPU_INST
,
505 .clkdm_offs
= OMAP4430_CM1_MPU_MPU_CDOFFS
,
506 .wkdep_srcs
= mpuss_wkup_sleep_deps
,
507 .sleepdep_srcs
= mpuss_wkup_sleep_deps
,
508 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
509 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
512 static struct clockdomain mpu0_44xx_clkdm
= {
513 .name
= "mpu0_clkdm",
514 .pwrdm
= { .name
= "cpu0_pwrdm" },
515 .prcm_partition
= OMAP4430_PRCM_MPU_PARTITION
,
516 .cm_inst
= OMAP4430_PRCM_MPU_CPU0_INST
,
517 .clkdm_offs
= OMAP4430_PRCM_MPU_CPU0_CPU0_CDOFFS
,
518 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
519 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
522 static struct clockdomain mpu1_44xx_clkdm
= {
523 .name
= "mpu1_clkdm",
524 .pwrdm
= { .name
= "cpu1_pwrdm" },
525 .prcm_partition
= OMAP4430_PRCM_MPU_PARTITION
,
526 .cm_inst
= OMAP4430_PRCM_MPU_CPU1_INST
,
527 .clkdm_offs
= OMAP4430_PRCM_MPU_CPU1_CPU1_CDOFFS
,
528 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
529 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
532 static struct clockdomain l3_emif_44xx_clkdm
= {
533 .name
= "l3_emif_clkdm",
534 .pwrdm
= { .name
= "core_pwrdm" },
535 .prcm_partition
= OMAP4430_CM2_PARTITION
,
536 .cm_inst
= OMAP4430_CM2_CORE_INST
,
537 .clkdm_offs
= OMAP4430_CM2_CORE_MEMIF_CDOFFS
,
538 .dep_bit
= OMAP4430_MEMIF_STATDEP_SHIFT
,
539 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
540 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
543 static struct clockdomain l4_ao_44xx_clkdm
= {
544 .name
= "l4_ao_clkdm",
545 .pwrdm
= { .name
= "always_on_core_pwrdm" },
546 .prcm_partition
= OMAP4430_CM2_PARTITION
,
547 .cm_inst
= OMAP4430_CM2_ALWAYS_ON_INST
,
548 .clkdm_offs
= OMAP4430_CM2_ALWAYS_ON_ALWON_CDOFFS
,
549 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
550 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
553 static struct clockdomain ducati_44xx_clkdm
= {
554 .name
= "ducati_clkdm",
555 .pwrdm
= { .name
= "core_pwrdm" },
556 .prcm_partition
= OMAP4430_CM2_PARTITION
,
557 .cm_inst
= OMAP4430_CM2_CORE_INST
,
558 .clkdm_offs
= OMAP4430_CM2_CORE_DUCATI_CDOFFS
,
559 .dep_bit
= OMAP4430_DUCATI_STATDEP_SHIFT
,
560 .wkdep_srcs
= ducati_wkup_sleep_deps
,
561 .sleepdep_srcs
= ducati_wkup_sleep_deps
,
562 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
563 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
566 static struct clockdomain l3_2_44xx_clkdm
= {
567 .name
= "l3_2_clkdm",
568 .pwrdm
= { .name
= "core_pwrdm" },
569 .prcm_partition
= OMAP4430_CM2_PARTITION
,
570 .cm_inst
= OMAP4430_CM2_CORE_INST
,
571 .clkdm_offs
= OMAP4430_CM2_CORE_L3_2_CDOFFS
,
572 .dep_bit
= OMAP4430_L3_2_STATDEP_SHIFT
,
573 .flags
= CLKDM_CAN_HWSUP
,
574 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
577 static struct clockdomain l3_1_44xx_clkdm
= {
578 .name
= "l3_1_clkdm",
579 .pwrdm
= { .name
= "core_pwrdm" },
580 .prcm_partition
= OMAP4430_CM2_PARTITION
,
581 .cm_inst
= OMAP4430_CM2_CORE_INST
,
582 .clkdm_offs
= OMAP4430_CM2_CORE_L3_1_CDOFFS
,
583 .dep_bit
= OMAP4430_L3_1_STATDEP_SHIFT
,
584 .flags
= CLKDM_CAN_HWSUP
,
585 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
588 static struct clockdomain l3_d2d_44xx_clkdm
= {
589 .name
= "l3_d2d_clkdm",
590 .pwrdm
= { .name
= "core_pwrdm" },
591 .prcm_partition
= OMAP4430_CM2_PARTITION
,
592 .cm_inst
= OMAP4430_CM2_CORE_INST
,
593 .clkdm_offs
= OMAP4430_CM2_CORE_D2D_CDOFFS
,
594 .wkdep_srcs
= l3_d2d_wkup_sleep_deps
,
595 .sleepdep_srcs
= l3_d2d_wkup_sleep_deps
,
596 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
597 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
600 static struct clockdomain iss_44xx_clkdm
= {
602 .pwrdm
= { .name
= "cam_pwrdm" },
603 .prcm_partition
= OMAP4430_CM2_PARTITION
,
604 .cm_inst
= OMAP4430_CM2_CAM_INST
,
605 .clkdm_offs
= OMAP4430_CM2_CAM_CAM_CDOFFS
,
606 .wkdep_srcs
= iss_wkup_sleep_deps
,
607 .sleepdep_srcs
= iss_wkup_sleep_deps
,
608 .flags
= CLKDM_CAN_SWSUP
,
609 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
612 static struct clockdomain l3_dss_44xx_clkdm
= {
613 .name
= "l3_dss_clkdm",
614 .pwrdm
= { .name
= "dss_pwrdm" },
615 .prcm_partition
= OMAP4430_CM2_PARTITION
,
616 .cm_inst
= OMAP4430_CM2_DSS_INST
,
617 .clkdm_offs
= OMAP4430_CM2_DSS_DSS_CDOFFS
,
618 .dep_bit
= OMAP4430_DSS_STATDEP_SHIFT
,
619 .wkdep_srcs
= l3_dss_wkup_sleep_deps
,
620 .sleepdep_srcs
= l3_dss_wkup_sleep_deps
,
621 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
622 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
625 static struct clockdomain l4_wkup_44xx_clkdm
= {
626 .name
= "l4_wkup_clkdm",
627 .pwrdm
= { .name
= "wkup_pwrdm" },
628 .prcm_partition
= OMAP4430_PRM_PARTITION
,
629 .cm_inst
= OMAP4430_PRM_WKUP_CM_INST
,
630 .clkdm_offs
= OMAP4430_PRM_WKUP_CM_WKUP_CDOFFS
,
631 .dep_bit
= OMAP4430_L4WKUP_STATDEP_SHIFT
,
632 .flags
= CLKDM_CAN_HWSUP
,
633 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
636 static struct clockdomain emu_sys_44xx_clkdm
= {
637 .name
= "emu_sys_clkdm",
638 .pwrdm
= { .name
= "emu_pwrdm" },
639 .prcm_partition
= OMAP4430_PRM_PARTITION
,
640 .cm_inst
= OMAP4430_PRM_EMU_CM_INST
,
641 .clkdm_offs
= OMAP4430_PRM_EMU_CM_EMU_CDOFFS
,
642 .flags
= CLKDM_CAN_HWSUP
,
643 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
646 static struct clockdomain l3_dma_44xx_clkdm
= {
647 .name
= "l3_dma_clkdm",
648 .pwrdm
= { .name
= "core_pwrdm" },
649 .prcm_partition
= OMAP4430_CM2_PARTITION
,
650 .cm_inst
= OMAP4430_CM2_CORE_INST
,
651 .clkdm_offs
= OMAP4430_CM2_CORE_SDMA_CDOFFS
,
652 .wkdep_srcs
= l3_dma_wkup_sleep_deps
,
653 .sleepdep_srcs
= l3_dma_wkup_sleep_deps
,
654 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
655 .omap_chip
= OMAP_CHIP_INIT(CHIP_IS_OMAP44XX
),
658 static struct clockdomain
*clockdomains_omap44xx
[] __initdata
= {
659 &l4_cefuse_44xx_clkdm
,
664 &l4_secure_44xx_clkdm
,
667 &l3_instr_44xx_clkdm
,
686 void __init
omap44xx_clockdomains_init(void)
688 clkdm_init(clockdomains_omap44xx
, NULL
, &omap4_clkdm_operations
);