diff options
author | Mark A. Greer <mgreer@animalcreek.com> | 2012-04-19 16:16:46 -0400 |
---|---|---|
committer | Paul Walmsley <paul@pwsan.com> | 2012-06-28 02:07:32 -0400 |
commit | 16e5e2c471ab889f838bfe1c44032d0481c115e1 (patch) | |
tree | 91e30c4e84b05261791ea1dfaa814b1878d08837 /arch/arm | |
parent | 6b16351acbd415e66ba16bf7d473ece1574cf0bc (diff) |
ARM: OMAP AM35x: clockdomain data: Fix clockdomain dependencies
The am35x family of SoCs do not have an IVA so
a parallel set of clockdomain dependencies are
required that are simililar to OMAP3 but without
any IVA dependencies.
Signed-off-by: Mark A. Greer <mgreer@animalcreek.com>
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Diffstat (limited to 'arch/arm')
-rw-r--r-- | arch/arm/mach-omap2/clockdomains3xxx_data.c | 157 |
1 files changed, 144 insertions, 13 deletions
diff --git a/arch/arm/mach-omap2/clockdomains3xxx_data.c b/arch/arm/mach-omap2/clockdomains3xxx_data.c index 6038adb97710..8e35080026d3 100644 --- a/arch/arm/mach-omap2/clockdomains3xxx_data.c +++ b/arch/arm/mach-omap2/clockdomains3xxx_data.c | |||
@@ -59,6 +59,12 @@ static struct clkdm_dep gfx_sgx_3xxx_wkdeps[] = { | |||
59 | { NULL }, | 59 | { NULL }, |
60 | }; | 60 | }; |
61 | 61 | ||
62 | static struct clkdm_dep gfx_sgx_am35x_wkdeps[] = { | ||
63 | { .clkdm_name = "mpu_clkdm" }, | ||
64 | { .clkdm_name = "wkup_clkdm" }, | ||
65 | { NULL }, | ||
66 | }; | ||
67 | |||
62 | /* 3430: PM_WKDEP_PER: CORE, IVA2, MPU, WKUP */ | 68 | /* 3430: PM_WKDEP_PER: CORE, IVA2, MPU, WKUP */ |
63 | static struct clkdm_dep per_wkdeps[] = { | 69 | static struct clkdm_dep per_wkdeps[] = { |
64 | { .clkdm_name = "core_l3_clkdm" }, | 70 | { .clkdm_name = "core_l3_clkdm" }, |
@@ -69,6 +75,14 @@ static struct clkdm_dep per_wkdeps[] = { | |||
69 | { NULL }, | 75 | { NULL }, |
70 | }; | 76 | }; |
71 | 77 | ||
78 | static struct clkdm_dep per_am35x_wkdeps[] = { | ||
79 | { .clkdm_name = "core_l3_clkdm" }, | ||
80 | { .clkdm_name = "core_l4_clkdm" }, | ||
81 | { .clkdm_name = "mpu_clkdm" }, | ||
82 | { .clkdm_name = "wkup_clkdm" }, | ||
83 | { NULL }, | ||
84 | }; | ||
85 | |||
72 | /* 3430ES2: PM_WKDEP_USBHOST: CORE, IVA2, MPU, WKUP */ | 86 | /* 3430ES2: PM_WKDEP_USBHOST: CORE, IVA2, MPU, WKUP */ |
73 | static struct clkdm_dep usbhost_wkdeps[] = { | 87 | static struct clkdm_dep usbhost_wkdeps[] = { |
74 | { .clkdm_name = "core_l3_clkdm" }, | 88 | { .clkdm_name = "core_l3_clkdm" }, |
@@ -79,6 +93,14 @@ static struct clkdm_dep usbhost_wkdeps[] = { | |||
79 | { NULL }, | 93 | { NULL }, |
80 | }; | 94 | }; |
81 | 95 | ||
96 | static struct clkdm_dep usbhost_am35x_wkdeps[] = { | ||
97 | { .clkdm_name = "core_l3_clkdm" }, | ||
98 | { .clkdm_name = "core_l4_clkdm" }, | ||
99 | { .clkdm_name = "mpu_clkdm" }, | ||
100 | { .clkdm_name = "wkup_clkdm" }, | ||
101 | { NULL }, | ||
102 | }; | ||
103 | |||
82 | /* 3430 PM_WKDEP_MPU: CORE, IVA2, DSS, PER */ | 104 | /* 3430 PM_WKDEP_MPU: CORE, IVA2, DSS, PER */ |
83 | static struct clkdm_dep mpu_3xxx_wkdeps[] = { | 105 | static struct clkdm_dep mpu_3xxx_wkdeps[] = { |
84 | { .clkdm_name = "core_l3_clkdm" }, | 106 | { .clkdm_name = "core_l3_clkdm" }, |
@@ -89,6 +111,14 @@ static struct clkdm_dep mpu_3xxx_wkdeps[] = { | |||
89 | { NULL }, | 111 | { NULL }, |
90 | }; | 112 | }; |
91 | 113 | ||
114 | static struct clkdm_dep mpu_am35x_wkdeps[] = { | ||
115 | { .clkdm_name = "core_l3_clkdm" }, | ||
116 | { .clkdm_name = "core_l4_clkdm" }, | ||
117 | { .clkdm_name = "dss_clkdm" }, | ||
118 | { .clkdm_name = "per_clkdm" }, | ||
119 | { NULL }, | ||
120 | }; | ||
121 | |||
92 | /* 3430 PM_WKDEP_IVA2: CORE, MPU, WKUP, DSS, PER */ | 122 | /* 3430 PM_WKDEP_IVA2: CORE, MPU, WKUP, DSS, PER */ |
93 | static struct clkdm_dep iva2_wkdeps[] = { | 123 | static struct clkdm_dep iva2_wkdeps[] = { |
94 | { .clkdm_name = "core_l3_clkdm" }, | 124 | { .clkdm_name = "core_l3_clkdm" }, |
@@ -116,6 +146,12 @@ static struct clkdm_dep dss_wkdeps[] = { | |||
116 | { NULL }, | 146 | { NULL }, |
117 | }; | 147 | }; |
118 | 148 | ||
149 | static struct clkdm_dep dss_am35x_wkdeps[] = { | ||
150 | { .clkdm_name = "mpu_clkdm" }, | ||
151 | { .clkdm_name = "wkup_clkdm" }, | ||
152 | { NULL }, | ||
153 | }; | ||
154 | |||
119 | /* 3430: PM_WKDEP_NEON: MPU */ | 155 | /* 3430: PM_WKDEP_NEON: MPU */ |
120 | static struct clkdm_dep neon_wkdeps[] = { | 156 | static struct clkdm_dep neon_wkdeps[] = { |
121 | { .clkdm_name = "mpu_clkdm" }, | 157 | { .clkdm_name = "mpu_clkdm" }, |
@@ -131,6 +167,11 @@ static struct clkdm_dep dss_sleepdeps[] = { | |||
131 | { NULL }, | 167 | { NULL }, |
132 | }; | 168 | }; |
133 | 169 | ||
170 | static struct clkdm_dep dss_am35x_sleepdeps[] = { | ||
171 | { .clkdm_name = "mpu_clkdm" }, | ||
172 | { NULL }, | ||
173 | }; | ||
174 | |||
134 | /* 3430: CM_SLEEPDEP_PER: MPU, IVA */ | 175 | /* 3430: CM_SLEEPDEP_PER: MPU, IVA */ |
135 | static struct clkdm_dep per_sleepdeps[] = { | 176 | static struct clkdm_dep per_sleepdeps[] = { |
136 | { .clkdm_name = "mpu_clkdm" }, | 177 | { .clkdm_name = "mpu_clkdm" }, |
@@ -138,6 +179,11 @@ static struct clkdm_dep per_sleepdeps[] = { | |||
138 | { NULL }, | 179 | { NULL }, |
139 | }; | 180 | }; |
140 | 181 | ||
182 | static struct clkdm_dep per_am35x_sleepdeps[] = { | ||
183 | { .clkdm_name = "mpu_clkdm" }, | ||
184 | { NULL }, | ||
185 | }; | ||
186 | |||
141 | /* 3430ES2: CM_SLEEPDEP_USBHOST: MPU, IVA */ | 187 | /* 3430ES2: CM_SLEEPDEP_USBHOST: MPU, IVA */ |
142 | static struct clkdm_dep usbhost_sleepdeps[] = { | 188 | static struct clkdm_dep usbhost_sleepdeps[] = { |
143 | { .clkdm_name = "mpu_clkdm" }, | 189 | { .clkdm_name = "mpu_clkdm" }, |
@@ -145,6 +191,11 @@ static struct clkdm_dep usbhost_sleepdeps[] = { | |||
145 | { NULL }, | 191 | { NULL }, |
146 | }; | 192 | }; |
147 | 193 | ||
194 | static struct clkdm_dep usbhost_am35x_sleepdeps[] = { | ||
195 | { .clkdm_name = "mpu_clkdm" }, | ||
196 | { NULL }, | ||
197 | }; | ||
198 | |||
148 | /* 3430: CM_SLEEPDEP_CAM: MPU */ | 199 | /* 3430: CM_SLEEPDEP_CAM: MPU */ |
149 | static struct clkdm_dep cam_sleepdeps[] = { | 200 | static struct clkdm_dep cam_sleepdeps[] = { |
150 | { .clkdm_name = "mpu_clkdm" }, | 201 | { .clkdm_name = "mpu_clkdm" }, |
@@ -175,6 +226,15 @@ static struct clockdomain mpu_3xxx_clkdm = { | |||
175 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_MPU_MASK, | 226 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_MPU_MASK, |
176 | }; | 227 | }; |
177 | 228 | ||
229 | static struct clockdomain mpu_am35x_clkdm = { | ||
230 | .name = "mpu_clkdm", | ||
231 | .pwrdm = { .name = "mpu_pwrdm" }, | ||
232 | .flags = CLKDM_CAN_HWSUP | CLKDM_CAN_FORCE_WAKEUP, | ||
233 | .dep_bit = OMAP3430_EN_MPU_SHIFT, | ||
234 | .wkdep_srcs = mpu_am35x_wkdeps, | ||
235 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_MPU_MASK, | ||
236 | }; | ||
237 | |||
178 | static struct clockdomain neon_clkdm = { | 238 | static struct clockdomain neon_clkdm = { |
179 | .name = "neon_clkdm", | 239 | .name = "neon_clkdm", |
180 | .pwrdm = { .name = "neon_pwrdm" }, | 240 | .pwrdm = { .name = "neon_pwrdm" }, |
@@ -210,6 +270,15 @@ static struct clockdomain sgx_clkdm = { | |||
210 | .clktrctrl_mask = OMAP3430ES2_CLKTRCTRL_SGX_MASK, | 270 | .clktrctrl_mask = OMAP3430ES2_CLKTRCTRL_SGX_MASK, |
211 | }; | 271 | }; |
212 | 272 | ||
273 | static struct clockdomain sgx_am35x_clkdm = { | ||
274 | .name = "sgx_clkdm", | ||
275 | .pwrdm = { .name = "sgx_pwrdm" }, | ||
276 | .flags = CLKDM_CAN_HWSUP_SWSUP, | ||
277 | .wkdep_srcs = gfx_sgx_am35x_wkdeps, | ||
278 | .sleepdep_srcs = gfx_sgx_sleepdeps, | ||
279 | .clktrctrl_mask = OMAP3430ES2_CLKTRCTRL_SGX_MASK, | ||
280 | }; | ||
281 | |||
213 | /* | 282 | /* |
214 | * The die-to-die clockdomain was documented in the 34xx ES1 TRM, but | 283 | * The die-to-die clockdomain was documented in the 34xx ES1 TRM, but |
215 | * then that information was removed from the 34xx ES2+ TRM. It is | 284 | * then that information was removed from the 34xx ES2+ TRM. It is |
@@ -261,6 +330,16 @@ static struct clockdomain dss_3xxx_clkdm = { | |||
261 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_DSS_MASK, | 330 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_DSS_MASK, |
262 | }; | 331 | }; |
263 | 332 | ||
333 | static struct clockdomain dss_am35x_clkdm = { | ||
334 | .name = "dss_clkdm", | ||
335 | .pwrdm = { .name = "dss_pwrdm" }, | ||
336 | .flags = CLKDM_CAN_HWSUP_SWSUP, | ||
337 | .dep_bit = OMAP3430_PM_WKDEP_MPU_EN_DSS_SHIFT, | ||
338 | .wkdep_srcs = dss_am35x_wkdeps, | ||
339 | .sleepdep_srcs = dss_am35x_sleepdeps, | ||
340 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_DSS_MASK, | ||
341 | }; | ||
342 | |||
264 | static struct clockdomain cam_clkdm = { | 343 | static struct clockdomain cam_clkdm = { |
265 | .name = "cam_clkdm", | 344 | .name = "cam_clkdm", |
266 | .pwrdm = { .name = "cam_pwrdm" }, | 345 | .pwrdm = { .name = "cam_pwrdm" }, |
@@ -279,6 +358,15 @@ static struct clockdomain usbhost_clkdm = { | |||
279 | .clktrctrl_mask = OMAP3430ES2_CLKTRCTRL_USBHOST_MASK, | 358 | .clktrctrl_mask = OMAP3430ES2_CLKTRCTRL_USBHOST_MASK, |
280 | }; | 359 | }; |
281 | 360 | ||
361 | static struct clockdomain usbhost_am35x_clkdm = { | ||
362 | .name = "usbhost_clkdm", | ||
363 | .pwrdm = { .name = "core_pwrdm" }, | ||
364 | .flags = CLKDM_CAN_HWSUP_SWSUP, | ||
365 | .wkdep_srcs = usbhost_am35x_wkdeps, | ||
366 | .sleepdep_srcs = usbhost_am35x_sleepdeps, | ||
367 | .clktrctrl_mask = OMAP3430ES2_CLKTRCTRL_USBHOST_MASK, | ||
368 | }; | ||
369 | |||
282 | static struct clockdomain per_clkdm = { | 370 | static struct clockdomain per_clkdm = { |
283 | .name = "per_clkdm", | 371 | .name = "per_clkdm", |
284 | .pwrdm = { .name = "per_pwrdm" }, | 372 | .pwrdm = { .name = "per_pwrdm" }, |
@@ -289,6 +377,16 @@ static struct clockdomain per_clkdm = { | |||
289 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_PER_MASK, | 377 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_PER_MASK, |
290 | }; | 378 | }; |
291 | 379 | ||
380 | static struct clockdomain per_am35x_clkdm = { | ||
381 | .name = "per_clkdm", | ||
382 | .pwrdm = { .name = "per_pwrdm" }, | ||
383 | .flags = CLKDM_CAN_HWSUP_SWSUP, | ||
384 | .dep_bit = OMAP3430_EN_PER_SHIFT, | ||
385 | .wkdep_srcs = per_am35x_wkdeps, | ||
386 | .sleepdep_srcs = per_am35x_sleepdeps, | ||
387 | .clktrctrl_mask = OMAP3430_CLKTRCTRL_PER_MASK, | ||
388 | }; | ||
389 | |||
292 | /* | 390 | /* |
293 | * Disable hw supervised mode for emu_clkdm, because emu_pwrdm is | 391 | * Disable hw supervised mode for emu_clkdm, because emu_pwrdm is |
294 | * switched of even if sdti is in use | 392 | * switched of even if sdti is in use |
@@ -341,31 +439,44 @@ static struct clkdm_autodep clkdm_autodeps[] = { | |||
341 | } | 439 | } |
342 | }; | 440 | }; |
343 | 441 | ||
442 | static struct clkdm_autodep clkdm_am35x_autodeps[] = { | ||
443 | { | ||
444 | .clkdm = { .name = "mpu_clkdm" }, | ||
445 | }, | ||
446 | { | ||
447 | .clkdm = { .name = NULL }, | ||
448 | } | ||
449 | }; | ||
450 | |||
344 | /* | 451 | /* |
345 | * | 452 | * |
346 | */ | 453 | */ |
347 | 454 | ||
348 | static struct clockdomain *clockdomains_omap3430_common[] __initdata = { | 455 | static struct clockdomain *clockdomains_common[] __initdata = { |
349 | &wkup_common_clkdm, | 456 | &wkup_common_clkdm, |
350 | &cm_common_clkdm, | 457 | &cm_common_clkdm, |
351 | &prm_common_clkdm, | 458 | &prm_common_clkdm, |
352 | &mpu_3xxx_clkdm, | ||
353 | &neon_clkdm, | 459 | &neon_clkdm, |
354 | &iva2_clkdm, | ||
355 | &d2d_clkdm, | ||
356 | &core_l3_3xxx_clkdm, | 460 | &core_l3_3xxx_clkdm, |
357 | &core_l4_3xxx_clkdm, | 461 | &core_l4_3xxx_clkdm, |
358 | &dss_3xxx_clkdm, | ||
359 | &cam_clkdm, | ||
360 | &per_clkdm, | ||
361 | &emu_clkdm, | 462 | &emu_clkdm, |
362 | &dpll1_clkdm, | 463 | &dpll1_clkdm, |
363 | &dpll2_clkdm, | ||
364 | &dpll3_clkdm, | 464 | &dpll3_clkdm, |
365 | &dpll4_clkdm, | 465 | &dpll4_clkdm, |
366 | NULL | 466 | NULL |
367 | }; | 467 | }; |
368 | 468 | ||
469 | static struct clockdomain *clockdomains_omap3430[] __initdata = { | ||
470 | &mpu_3xxx_clkdm, | ||
471 | &iva2_clkdm, | ||
472 | &d2d_clkdm, | ||
473 | &dss_3xxx_clkdm, | ||
474 | &cam_clkdm, | ||
475 | &per_clkdm, | ||
476 | &dpll2_clkdm, | ||
477 | NULL | ||
478 | }; | ||
479 | |||
369 | static struct clockdomain *clockdomains_omap3430es1[] __initdata = { | 480 | static struct clockdomain *clockdomains_omap3430es1[] __initdata = { |
370 | &gfx_3430es1_clkdm, | 481 | &gfx_3430es1_clkdm, |
371 | NULL, | 482 | NULL, |
@@ -378,21 +489,41 @@ static struct clockdomain *clockdomains_omap3430es2plus[] __initdata = { | |||
378 | NULL, | 489 | NULL, |
379 | }; | 490 | }; |
380 | 491 | ||
492 | static struct clockdomain *clockdomains_am35x[] __initdata = { | ||
493 | &mpu_am35x_clkdm, | ||
494 | &sgx_am35x_clkdm, | ||
495 | &dss_am35x_clkdm, | ||
496 | &per_am35x_clkdm, | ||
497 | &usbhost_am35x_clkdm, | ||
498 | &dpll5_clkdm, | ||
499 | NULL | ||
500 | }; | ||
501 | |||
381 | void __init omap3xxx_clockdomains_init(void) | 502 | void __init omap3xxx_clockdomains_init(void) |
382 | { | 503 | { |
383 | struct clockdomain **sc; | 504 | struct clockdomain **sc; |
505 | unsigned int rev; | ||
384 | 506 | ||
385 | if (!cpu_is_omap34xx()) | 507 | if (!cpu_is_omap34xx()) |
386 | return; | 508 | return; |
387 | 509 | ||
388 | clkdm_register_platform_funcs(&omap3_clkdm_operations); | 510 | clkdm_register_platform_funcs(&omap3_clkdm_operations); |
389 | clkdm_register_clkdms(clockdomains_omap3430_common); | 511 | clkdm_register_clkdms(clockdomains_common); |
390 | 512 | ||
391 | sc = (omap_rev() == OMAP3430_REV_ES1_0) ? clockdomains_omap3430es1 : | 513 | rev = omap_rev(); |
392 | clockdomains_omap3430es2plus; | ||
393 | 514 | ||
394 | clkdm_register_clkdms(sc); | 515 | if (rev == AM35XX_REV_ES1_0 || rev == AM35XX_REV_ES1_1) { |
516 | clkdm_register_clkdms(clockdomains_am35x); | ||
517 | clkdm_register_autodeps(clkdm_am35x_autodeps); | ||
518 | } else { | ||
519 | clkdm_register_clkdms(clockdomains_omap3430); | ||
520 | |||
521 | sc = (rev == OMAP3430_REV_ES1_0) ? | ||
522 | clockdomains_omap3430es1 : clockdomains_omap3430es2plus; | ||
523 | |||
524 | clkdm_register_clkdms(sc); | ||
525 | clkdm_register_autodeps(clkdm_autodeps); | ||
526 | } | ||
395 | 527 | ||
396 | clkdm_register_autodeps(clkdm_autodeps); | ||
397 | clkdm_complete_init(); | 528 | clkdm_complete_init(); |
398 | } | 529 | } |