1 // SPDX-License-Identifier: GPL-2.0-only
3 * DRA7xx Clock domains framework
5 * Copyright (C) 2009-2013 Texas Instruments, Inc.
6 * Copyright (C) 2009-2011 Nokia Corporation
8 * Generated by code originally written by:
9 * Abhijit Pagare (abhijitpagare@ti.com)
10 * Benoit Cousson (b-cousson@ti.com)
11 * Paul Walmsley (paul@pwsan.com)
13 * This file is automatically generated from the OMAP hardware databases.
14 * We respectfully ask that any modifications to this file be coordinated
15 * with the public linux-omap@vger.kernel.org mailing list and the
16 * authors above to ensure that the autogeneration scripts are kept
17 * up-to-date with the file contents.
20 #include <linux/kernel.h>
23 #include "clockdomain.h"
27 #include "cm-regbits-7xx.h"
30 #include "prcm_mpu7xx.h"
32 /* Static Dependencies for DRA7xx Clock Domains */
34 static struct clkdm_dep cam_wkup_sleep_deps
[] = {
35 { .clkdm_name
= "emif_clkdm" },
39 static struct clkdm_dep dma_wkup_sleep_deps
[] = {
40 { .clkdm_name
= "dss_clkdm" },
41 { .clkdm_name
= "emif_clkdm" },
42 { .clkdm_name
= "ipu_clkdm" },
43 { .clkdm_name
= "ipu1_clkdm" },
44 { .clkdm_name
= "ipu2_clkdm" },
45 { .clkdm_name
= "iva_clkdm" },
46 { .clkdm_name
= "l3init_clkdm" },
47 { .clkdm_name
= "l4cfg_clkdm" },
48 { .clkdm_name
= "l4per_clkdm" },
49 { .clkdm_name
= "l4per2_clkdm" },
50 { .clkdm_name
= "l4per3_clkdm" },
51 { .clkdm_name
= "l4sec_clkdm" },
52 { .clkdm_name
= "pcie_clkdm" },
53 { .clkdm_name
= "wkupaon_clkdm" },
57 static struct clkdm_dep dsp1_wkup_sleep_deps
[] = {
58 { .clkdm_name
= "atl_clkdm" },
59 { .clkdm_name
= "cam_clkdm" },
60 { .clkdm_name
= "dsp2_clkdm" },
61 { .clkdm_name
= "dss_clkdm" },
62 { .clkdm_name
= "emif_clkdm" },
63 { .clkdm_name
= "eve1_clkdm" },
64 { .clkdm_name
= "eve2_clkdm" },
65 { .clkdm_name
= "eve3_clkdm" },
66 { .clkdm_name
= "eve4_clkdm" },
67 { .clkdm_name
= "gmac_clkdm" },
68 { .clkdm_name
= "gpu_clkdm" },
69 { .clkdm_name
= "ipu_clkdm" },
70 { .clkdm_name
= "ipu1_clkdm" },
71 { .clkdm_name
= "ipu2_clkdm" },
72 { .clkdm_name
= "iva_clkdm" },
73 { .clkdm_name
= "l3init_clkdm" },
74 { .clkdm_name
= "l4per_clkdm" },
75 { .clkdm_name
= "l4per2_clkdm" },
76 { .clkdm_name
= "l4per3_clkdm" },
77 { .clkdm_name
= "l4sec_clkdm" },
78 { .clkdm_name
= "pcie_clkdm" },
79 { .clkdm_name
= "vpe_clkdm" },
80 { .clkdm_name
= "wkupaon_clkdm" },
84 static struct clkdm_dep dsp2_wkup_sleep_deps
[] = {
85 { .clkdm_name
= "atl_clkdm" },
86 { .clkdm_name
= "cam_clkdm" },
87 { .clkdm_name
= "dsp1_clkdm" },
88 { .clkdm_name
= "dss_clkdm" },
89 { .clkdm_name
= "emif_clkdm" },
90 { .clkdm_name
= "eve1_clkdm" },
91 { .clkdm_name
= "eve2_clkdm" },
92 { .clkdm_name
= "eve3_clkdm" },
93 { .clkdm_name
= "eve4_clkdm" },
94 { .clkdm_name
= "gmac_clkdm" },
95 { .clkdm_name
= "gpu_clkdm" },
96 { .clkdm_name
= "ipu_clkdm" },
97 { .clkdm_name
= "ipu1_clkdm" },
98 { .clkdm_name
= "ipu2_clkdm" },
99 { .clkdm_name
= "iva_clkdm" },
100 { .clkdm_name
= "l3init_clkdm" },
101 { .clkdm_name
= "l4per_clkdm" },
102 { .clkdm_name
= "l4per2_clkdm" },
103 { .clkdm_name
= "l4per3_clkdm" },
104 { .clkdm_name
= "l4sec_clkdm" },
105 { .clkdm_name
= "pcie_clkdm" },
106 { .clkdm_name
= "vpe_clkdm" },
107 { .clkdm_name
= "wkupaon_clkdm" },
111 static struct clkdm_dep dss_wkup_sleep_deps
[] = {
112 { .clkdm_name
= "emif_clkdm" },
113 { .clkdm_name
= "iva_clkdm" },
117 static struct clkdm_dep eve1_wkup_sleep_deps
[] = {
118 { .clkdm_name
= "emif_clkdm" },
119 { .clkdm_name
= "eve2_clkdm" },
120 { .clkdm_name
= "eve3_clkdm" },
121 { .clkdm_name
= "eve4_clkdm" },
122 { .clkdm_name
= "iva_clkdm" },
126 static struct clkdm_dep eve2_wkup_sleep_deps
[] = {
127 { .clkdm_name
= "emif_clkdm" },
128 { .clkdm_name
= "eve1_clkdm" },
129 { .clkdm_name
= "eve3_clkdm" },
130 { .clkdm_name
= "eve4_clkdm" },
131 { .clkdm_name
= "iva_clkdm" },
135 static struct clkdm_dep eve3_wkup_sleep_deps
[] = {
136 { .clkdm_name
= "emif_clkdm" },
137 { .clkdm_name
= "eve1_clkdm" },
138 { .clkdm_name
= "eve2_clkdm" },
139 { .clkdm_name
= "eve4_clkdm" },
140 { .clkdm_name
= "iva_clkdm" },
144 static struct clkdm_dep eve4_wkup_sleep_deps
[] = {
145 { .clkdm_name
= "emif_clkdm" },
146 { .clkdm_name
= "eve1_clkdm" },
147 { .clkdm_name
= "eve2_clkdm" },
148 { .clkdm_name
= "eve3_clkdm" },
149 { .clkdm_name
= "iva_clkdm" },
153 static struct clkdm_dep gmac_wkup_sleep_deps
[] = {
154 { .clkdm_name
= "emif_clkdm" },
155 { .clkdm_name
= "l4per2_clkdm" },
159 static struct clkdm_dep gpu_wkup_sleep_deps
[] = {
160 { .clkdm_name
= "emif_clkdm" },
161 { .clkdm_name
= "iva_clkdm" },
165 static struct clkdm_dep ipu1_wkup_sleep_deps
[] = {
166 { .clkdm_name
= "atl_clkdm" },
167 { .clkdm_name
= "dsp1_clkdm" },
168 { .clkdm_name
= "dsp2_clkdm" },
169 { .clkdm_name
= "dss_clkdm" },
170 { .clkdm_name
= "emif_clkdm" },
171 { .clkdm_name
= "eve1_clkdm" },
172 { .clkdm_name
= "eve2_clkdm" },
173 { .clkdm_name
= "eve3_clkdm" },
174 { .clkdm_name
= "eve4_clkdm" },
175 { .clkdm_name
= "gmac_clkdm" },
176 { .clkdm_name
= "gpu_clkdm" },
177 { .clkdm_name
= "ipu_clkdm" },
178 { .clkdm_name
= "ipu2_clkdm" },
179 { .clkdm_name
= "iva_clkdm" },
180 { .clkdm_name
= "l3init_clkdm" },
181 { .clkdm_name
= "l3main1_clkdm" },
182 { .clkdm_name
= "l4cfg_clkdm" },
183 { .clkdm_name
= "l4per_clkdm" },
184 { .clkdm_name
= "l4per2_clkdm" },
185 { .clkdm_name
= "l4per3_clkdm" },
186 { .clkdm_name
= "l4sec_clkdm" },
187 { .clkdm_name
= "pcie_clkdm" },
188 { .clkdm_name
= "vpe_clkdm" },
189 { .clkdm_name
= "wkupaon_clkdm" },
193 static struct clkdm_dep ipu2_wkup_sleep_deps
[] = {
194 { .clkdm_name
= "atl_clkdm" },
195 { .clkdm_name
= "dsp1_clkdm" },
196 { .clkdm_name
= "dsp2_clkdm" },
197 { .clkdm_name
= "dss_clkdm" },
198 { .clkdm_name
= "emif_clkdm" },
199 { .clkdm_name
= "eve1_clkdm" },
200 { .clkdm_name
= "eve2_clkdm" },
201 { .clkdm_name
= "eve3_clkdm" },
202 { .clkdm_name
= "eve4_clkdm" },
203 { .clkdm_name
= "gmac_clkdm" },
204 { .clkdm_name
= "gpu_clkdm" },
205 { .clkdm_name
= "ipu_clkdm" },
206 { .clkdm_name
= "ipu1_clkdm" },
207 { .clkdm_name
= "iva_clkdm" },
208 { .clkdm_name
= "l3init_clkdm" },
209 { .clkdm_name
= "l3main1_clkdm" },
210 { .clkdm_name
= "l4cfg_clkdm" },
211 { .clkdm_name
= "l4per_clkdm" },
212 { .clkdm_name
= "l4per2_clkdm" },
213 { .clkdm_name
= "l4per3_clkdm" },
214 { .clkdm_name
= "l4sec_clkdm" },
215 { .clkdm_name
= "pcie_clkdm" },
216 { .clkdm_name
= "vpe_clkdm" },
217 { .clkdm_name
= "wkupaon_clkdm" },
221 static struct clkdm_dep iva_wkup_sleep_deps
[] = {
222 { .clkdm_name
= "emif_clkdm" },
226 static struct clkdm_dep l3init_wkup_sleep_deps
[] = {
227 { .clkdm_name
= "emif_clkdm" },
228 { .clkdm_name
= "iva_clkdm" },
229 { .clkdm_name
= "l4cfg_clkdm" },
230 { .clkdm_name
= "l4per_clkdm" },
231 { .clkdm_name
= "l4per3_clkdm" },
232 { .clkdm_name
= "l4sec_clkdm" },
233 { .clkdm_name
= "wkupaon_clkdm" },
237 static struct clkdm_dep l4per2_wkup_sleep_deps
[] = {
238 { .clkdm_name
= "dsp1_clkdm" },
239 { .clkdm_name
= "dsp2_clkdm" },
240 { .clkdm_name
= "ipu1_clkdm" },
241 { .clkdm_name
= "ipu2_clkdm" },
245 static struct clkdm_dep l4sec_wkup_sleep_deps
[] = {
246 { .clkdm_name
= "emif_clkdm" },
247 { .clkdm_name
= "l4per_clkdm" },
251 static struct clkdm_dep mpu_wkup_sleep_deps
[] = {
252 { .clkdm_name
= "cam_clkdm" },
253 { .clkdm_name
= "dsp1_clkdm" },
254 { .clkdm_name
= "dsp2_clkdm" },
255 { .clkdm_name
= "dss_clkdm" },
256 { .clkdm_name
= "emif_clkdm" },
257 { .clkdm_name
= "eve1_clkdm" },
258 { .clkdm_name
= "eve2_clkdm" },
259 { .clkdm_name
= "eve3_clkdm" },
260 { .clkdm_name
= "eve4_clkdm" },
261 { .clkdm_name
= "gmac_clkdm" },
262 { .clkdm_name
= "gpu_clkdm" },
263 { .clkdm_name
= "ipu_clkdm" },
264 { .clkdm_name
= "ipu1_clkdm" },
265 { .clkdm_name
= "ipu2_clkdm" },
266 { .clkdm_name
= "iva_clkdm" },
267 { .clkdm_name
= "l3init_clkdm" },
268 { .clkdm_name
= "l3main1_clkdm" },
269 { .clkdm_name
= "l4cfg_clkdm" },
270 { .clkdm_name
= "l4per_clkdm" },
271 { .clkdm_name
= "l4per2_clkdm" },
272 { .clkdm_name
= "l4per3_clkdm" },
273 { .clkdm_name
= "l4sec_clkdm" },
274 { .clkdm_name
= "pcie_clkdm" },
275 { .clkdm_name
= "vpe_clkdm" },
276 { .clkdm_name
= "wkupaon_clkdm" },
280 static struct clkdm_dep pcie_wkup_sleep_deps
[] = {
281 { .clkdm_name
= "atl_clkdm" },
282 { .clkdm_name
= "cam_clkdm" },
283 { .clkdm_name
= "dsp1_clkdm" },
284 { .clkdm_name
= "dsp2_clkdm" },
285 { .clkdm_name
= "dss_clkdm" },
286 { .clkdm_name
= "emif_clkdm" },
287 { .clkdm_name
= "eve1_clkdm" },
288 { .clkdm_name
= "eve2_clkdm" },
289 { .clkdm_name
= "eve3_clkdm" },
290 { .clkdm_name
= "eve4_clkdm" },
291 { .clkdm_name
= "gmac_clkdm" },
292 { .clkdm_name
= "gpu_clkdm" },
293 { .clkdm_name
= "ipu_clkdm" },
294 { .clkdm_name
= "ipu1_clkdm" },
295 { .clkdm_name
= "iva_clkdm" },
296 { .clkdm_name
= "l3init_clkdm" },
297 { .clkdm_name
= "l4cfg_clkdm" },
298 { .clkdm_name
= "l4per_clkdm" },
299 { .clkdm_name
= "l4per2_clkdm" },
300 { .clkdm_name
= "l4per3_clkdm" },
301 { .clkdm_name
= "l4sec_clkdm" },
302 { .clkdm_name
= "vpe_clkdm" },
306 static struct clkdm_dep vpe_wkup_sleep_deps
[] = {
307 { .clkdm_name
= "emif_clkdm" },
308 { .clkdm_name
= "l4per3_clkdm" },
312 static struct clockdomain l4per3_7xx_clkdm
= {
313 .name
= "l4per3_clkdm",
314 .pwrdm
= { .name
= "l4per_pwrdm" },
315 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
316 .cm_inst
= DRA7XX_CM_CORE_L4PER_INST
,
317 .clkdm_offs
= DRA7XX_CM_CORE_L4PER_L4PER3_CDOFFS
,
318 .dep_bit
= DRA7XX_L4PER3_STATDEP_SHIFT
,
319 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
322 static struct clockdomain l4per2_7xx_clkdm
= {
323 .name
= "l4per2_clkdm",
324 .pwrdm
= { .name
= "l4per_pwrdm" },
325 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
326 .cm_inst
= DRA7XX_CM_CORE_L4PER_INST
,
327 .clkdm_offs
= DRA7XX_CM_CORE_L4PER_L4PER2_CDOFFS
,
328 .dep_bit
= DRA7XX_L4PER2_STATDEP_SHIFT
,
329 .wkdep_srcs
= l4per2_wkup_sleep_deps
,
330 .sleepdep_srcs
= l4per2_wkup_sleep_deps
,
331 .flags
= CLKDM_CAN_SWSUP
,
334 static struct clockdomain mpu0_7xx_clkdm
= {
335 .name
= "mpu0_clkdm",
336 .pwrdm
= { .name
= "cpu0_pwrdm" },
337 .prcm_partition
= DRA7XX_MPU_PRCM_PARTITION
,
338 .cm_inst
= DRA7XX_MPU_PRCM_CM_C0_INST
,
339 .clkdm_offs
= DRA7XX_MPU_PRCM_CM_C0_CPU0_CDOFFS
,
340 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
343 static struct clockdomain iva_7xx_clkdm
= {
345 .pwrdm
= { .name
= "iva_pwrdm" },
346 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
347 .cm_inst
= DRA7XX_CM_CORE_IVA_INST
,
348 .clkdm_offs
= DRA7XX_CM_CORE_IVA_IVA_CDOFFS
,
349 .dep_bit
= DRA7XX_IVA_STATDEP_SHIFT
,
350 .wkdep_srcs
= iva_wkup_sleep_deps
,
351 .sleepdep_srcs
= iva_wkup_sleep_deps
,
352 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
355 static struct clockdomain coreaon_7xx_clkdm
= {
356 .name
= "coreaon_clkdm",
357 .pwrdm
= { .name
= "coreaon_pwrdm" },
358 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
359 .cm_inst
= DRA7XX_CM_CORE_COREAON_INST
,
360 .clkdm_offs
= DRA7XX_CM_CORE_COREAON_COREAON_CDOFFS
,
361 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
364 static struct clockdomain ipu1_7xx_clkdm
= {
365 .name
= "ipu1_clkdm",
366 .pwrdm
= { .name
= "ipu_pwrdm" },
367 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
368 .cm_inst
= DRA7XX_CM_CORE_AON_IPU_INST
,
369 .clkdm_offs
= DRA7XX_CM_CORE_AON_IPU_IPU1_CDOFFS
,
370 .dep_bit
= DRA7XX_IPU1_STATDEP_SHIFT
,
371 .wkdep_srcs
= ipu1_wkup_sleep_deps
,
372 .sleepdep_srcs
= ipu1_wkup_sleep_deps
,
373 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
376 static struct clockdomain ipu2_7xx_clkdm
= {
377 .name
= "ipu2_clkdm",
378 .pwrdm
= { .name
= "core_pwrdm" },
379 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
380 .cm_inst
= DRA7XX_CM_CORE_CORE_INST
,
381 .clkdm_offs
= DRA7XX_CM_CORE_CORE_IPU2_CDOFFS
,
382 .dep_bit
= DRA7XX_IPU2_STATDEP_SHIFT
,
383 .wkdep_srcs
= ipu2_wkup_sleep_deps
,
384 .sleepdep_srcs
= ipu2_wkup_sleep_deps
,
385 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
388 static struct clockdomain l3init_7xx_clkdm
= {
389 .name
= "l3init_clkdm",
390 .pwrdm
= { .name
= "l3init_pwrdm" },
391 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
392 .cm_inst
= DRA7XX_CM_CORE_L3INIT_INST
,
393 .clkdm_offs
= DRA7XX_CM_CORE_L3INIT_L3INIT_CDOFFS
,
394 .dep_bit
= DRA7XX_L3INIT_STATDEP_SHIFT
,
395 .wkdep_srcs
= l3init_wkup_sleep_deps
,
396 .sleepdep_srcs
= l3init_wkup_sleep_deps
,
397 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
400 static struct clockdomain l4sec_7xx_clkdm
= {
401 .name
= "l4sec_clkdm",
402 .pwrdm
= { .name
= "l4per_pwrdm" },
403 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
404 .cm_inst
= DRA7XX_CM_CORE_L4PER_INST
,
405 .clkdm_offs
= DRA7XX_CM_CORE_L4PER_L4SEC_CDOFFS
,
406 .dep_bit
= DRA7XX_L4SEC_STATDEP_SHIFT
,
407 .wkdep_srcs
= l4sec_wkup_sleep_deps
,
408 .sleepdep_srcs
= l4sec_wkup_sleep_deps
,
409 .flags
= CLKDM_CAN_SWSUP
,
412 static struct clockdomain l3main1_7xx_clkdm
= {
413 .name
= "l3main1_clkdm",
414 .pwrdm
= { .name
= "core_pwrdm" },
415 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
416 .cm_inst
= DRA7XX_CM_CORE_CORE_INST
,
417 .clkdm_offs
= DRA7XX_CM_CORE_CORE_L3MAIN1_CDOFFS
,
418 .dep_bit
= DRA7XX_L3MAIN1_STATDEP_SHIFT
,
419 .flags
= CLKDM_CAN_HWSUP
,
422 static struct clockdomain vpe_7xx_clkdm
= {
424 .pwrdm
= { .name
= "vpe_pwrdm" },
425 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
426 .cm_inst
= DRA7XX_CM_CORE_AON_VPE_INST
,
427 .clkdm_offs
= DRA7XX_CM_CORE_AON_VPE_VPE_CDOFFS
,
428 .dep_bit
= DRA7XX_VPE_STATDEP_SHIFT
,
429 .wkdep_srcs
= vpe_wkup_sleep_deps
,
430 .sleepdep_srcs
= vpe_wkup_sleep_deps
,
431 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
434 static struct clockdomain mpu_7xx_clkdm
= {
436 .pwrdm
= { .name
= "mpu_pwrdm" },
437 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
438 .cm_inst
= DRA7XX_CM_CORE_AON_MPU_INST
,
439 .clkdm_offs
= DRA7XX_CM_CORE_AON_MPU_MPU_CDOFFS
,
440 .wkdep_srcs
= mpu_wkup_sleep_deps
,
441 .sleepdep_srcs
= mpu_wkup_sleep_deps
,
442 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
445 static struct clockdomain custefuse_7xx_clkdm
= {
446 .name
= "custefuse_clkdm",
447 .pwrdm
= { .name
= "custefuse_pwrdm" },
448 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
449 .cm_inst
= DRA7XX_CM_CORE_CUSTEFUSE_INST
,
450 .clkdm_offs
= DRA7XX_CM_CORE_CUSTEFUSE_CUSTEFUSE_CDOFFS
,
451 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
454 static struct clockdomain ipu_7xx_clkdm
= {
456 .pwrdm
= { .name
= "ipu_pwrdm" },
457 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
458 .cm_inst
= DRA7XX_CM_CORE_AON_IPU_INST
,
459 .clkdm_offs
= DRA7XX_CM_CORE_AON_IPU_IPU_CDOFFS
,
460 .dep_bit
= DRA7XX_IPU_STATDEP_SHIFT
,
461 .flags
= CLKDM_CAN_SWSUP
,
464 static struct clockdomain mpu1_7xx_clkdm
= {
465 .name
= "mpu1_clkdm",
466 .pwrdm
= { .name
= "cpu1_pwrdm" },
467 .prcm_partition
= DRA7XX_MPU_PRCM_PARTITION
,
468 .cm_inst
= DRA7XX_MPU_PRCM_CM_C1_INST
,
469 .clkdm_offs
= DRA7XX_MPU_PRCM_CM_C1_CPU1_CDOFFS
,
470 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
473 static struct clockdomain gmac_7xx_clkdm
= {
474 .name
= "gmac_clkdm",
475 .pwrdm
= { .name
= "l3init_pwrdm" },
476 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
477 .cm_inst
= DRA7XX_CM_CORE_L3INIT_INST
,
478 .clkdm_offs
= DRA7XX_CM_CORE_L3INIT_GMAC_CDOFFS
,
479 .dep_bit
= DRA7XX_GMAC_STATDEP_SHIFT
,
480 .wkdep_srcs
= gmac_wkup_sleep_deps
,
481 .sleepdep_srcs
= gmac_wkup_sleep_deps
,
482 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
485 static struct clockdomain l4cfg_7xx_clkdm
= {
486 .name
= "l4cfg_clkdm",
487 .pwrdm
= { .name
= "core_pwrdm" },
488 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
489 .cm_inst
= DRA7XX_CM_CORE_CORE_INST
,
490 .clkdm_offs
= DRA7XX_CM_CORE_CORE_L4CFG_CDOFFS
,
491 .dep_bit
= DRA7XX_L4CFG_STATDEP_SHIFT
,
492 .flags
= CLKDM_CAN_HWSUP
,
495 static struct clockdomain dma_7xx_clkdm
= {
497 .pwrdm
= { .name
= "core_pwrdm" },
498 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
499 .cm_inst
= DRA7XX_CM_CORE_CORE_INST
,
500 .clkdm_offs
= DRA7XX_CM_CORE_CORE_DMA_CDOFFS
,
501 .wkdep_srcs
= dma_wkup_sleep_deps
,
502 .sleepdep_srcs
= dma_wkup_sleep_deps
,
503 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
506 static struct clockdomain rtc_7xx_clkdm
= {
508 .pwrdm
= { .name
= "rtc_pwrdm" },
509 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
510 .cm_inst
= DRA7XX_CM_CORE_AON_RTC_INST
,
511 .clkdm_offs
= DRA7XX_CM_CORE_AON_RTC_RTC_CDOFFS
,
512 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
515 static struct clockdomain pcie_7xx_clkdm
= {
516 .name
= "pcie_clkdm",
517 .pwrdm
= { .name
= "l3init_pwrdm" },
518 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
519 .cm_inst
= DRA7XX_CM_CORE_L3INIT_INST
,
520 .clkdm_offs
= DRA7XX_CM_CORE_L3INIT_PCIE_CDOFFS
,
521 .dep_bit
= DRA7XX_PCIE_STATDEP_SHIFT
,
522 .wkdep_srcs
= pcie_wkup_sleep_deps
,
523 .sleepdep_srcs
= pcie_wkup_sleep_deps
,
524 .flags
= CLKDM_CAN_SWSUP
,
527 static struct clockdomain atl_7xx_clkdm
= {
529 .pwrdm
= { .name
= "core_pwrdm" },
530 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
531 .cm_inst
= DRA7XX_CM_CORE_CORE_INST
,
532 .clkdm_offs
= DRA7XX_CM_CORE_CORE_ATL_CDOFFS
,
533 .dep_bit
= DRA7XX_ATL_STATDEP_SHIFT
,
534 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
537 static struct clockdomain l3instr_7xx_clkdm
= {
538 .name
= "l3instr_clkdm",
539 .pwrdm
= { .name
= "core_pwrdm" },
540 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
541 .cm_inst
= DRA7XX_CM_CORE_CORE_INST
,
542 .clkdm_offs
= DRA7XX_CM_CORE_CORE_L3INSTR_CDOFFS
,
545 static struct clockdomain dss_7xx_clkdm
= {
547 .pwrdm
= { .name
= "dss_pwrdm" },
548 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
549 .cm_inst
= DRA7XX_CM_CORE_DSS_INST
,
550 .clkdm_offs
= DRA7XX_CM_CORE_DSS_DSS_CDOFFS
,
551 .dep_bit
= DRA7XX_DSS_STATDEP_SHIFT
,
552 .wkdep_srcs
= dss_wkup_sleep_deps
,
553 .sleepdep_srcs
= dss_wkup_sleep_deps
,
554 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
557 static struct clockdomain emif_7xx_clkdm
= {
558 .name
= "emif_clkdm",
559 .pwrdm
= { .name
= "core_pwrdm" },
560 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
561 .cm_inst
= DRA7XX_CM_CORE_CORE_INST
,
562 .clkdm_offs
= DRA7XX_CM_CORE_CORE_EMIF_CDOFFS
,
563 .dep_bit
= DRA7XX_EMIF_STATDEP_SHIFT
,
564 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
567 static struct clockdomain emu_7xx_clkdm
= {
569 .pwrdm
= { .name
= "emu_pwrdm" },
570 .prcm_partition
= DRA7XX_PRM_PARTITION
,
571 .cm_inst
= DRA7XX_PRM_EMU_CM_INST
,
572 .clkdm_offs
= DRA7XX_PRM_EMU_CM_EMU_CDOFFS
,
573 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
576 static struct clockdomain dsp2_7xx_clkdm
= {
577 .name
= "dsp2_clkdm",
578 .pwrdm
= { .name
= "dsp2_pwrdm" },
579 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
580 .cm_inst
= DRA7XX_CM_CORE_AON_DSP2_INST
,
581 .clkdm_offs
= DRA7XX_CM_CORE_AON_DSP2_DSP2_CDOFFS
,
582 .dep_bit
= DRA7XX_DSP2_STATDEP_SHIFT
,
583 .wkdep_srcs
= dsp2_wkup_sleep_deps
,
584 .sleepdep_srcs
= dsp2_wkup_sleep_deps
,
585 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
588 static struct clockdomain dsp1_7xx_clkdm
= {
589 .name
= "dsp1_clkdm",
590 .pwrdm
= { .name
= "dsp1_pwrdm" },
591 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
592 .cm_inst
= DRA7XX_CM_CORE_AON_DSP1_INST
,
593 .clkdm_offs
= DRA7XX_CM_CORE_AON_DSP1_DSP1_CDOFFS
,
594 .dep_bit
= DRA7XX_DSP1_STATDEP_SHIFT
,
595 .wkdep_srcs
= dsp1_wkup_sleep_deps
,
596 .sleepdep_srcs
= dsp1_wkup_sleep_deps
,
597 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
600 static struct clockdomain cam_7xx_clkdm
= {
602 .pwrdm
= { .name
= "cam_pwrdm" },
603 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
604 .cm_inst
= DRA7XX_CM_CORE_CAM_INST
,
605 .clkdm_offs
= DRA7XX_CM_CORE_CAM_CAM_CDOFFS
,
606 .dep_bit
= DRA7XX_CAM_STATDEP_SHIFT
,
607 .wkdep_srcs
= cam_wkup_sleep_deps
,
608 .sleepdep_srcs
= cam_wkup_sleep_deps
,
609 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
612 static struct clockdomain l4per_7xx_clkdm
= {
613 .name
= "l4per_clkdm",
614 .pwrdm
= { .name
= "l4per_pwrdm" },
615 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
616 .cm_inst
= DRA7XX_CM_CORE_L4PER_INST
,
617 .clkdm_offs
= DRA7XX_CM_CORE_L4PER_L4PER_CDOFFS
,
618 .dep_bit
= DRA7XX_L4PER_STATDEP_SHIFT
,
619 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
622 static struct clockdomain gpu_7xx_clkdm
= {
624 .pwrdm
= { .name
= "gpu_pwrdm" },
625 .prcm_partition
= DRA7XX_CM_CORE_PARTITION
,
626 .cm_inst
= DRA7XX_CM_CORE_GPU_INST
,
627 .clkdm_offs
= DRA7XX_CM_CORE_GPU_GPU_CDOFFS
,
628 .dep_bit
= DRA7XX_GPU_STATDEP_SHIFT
,
629 .wkdep_srcs
= gpu_wkup_sleep_deps
,
630 .sleepdep_srcs
= gpu_wkup_sleep_deps
,
631 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
634 static struct clockdomain eve4_7xx_clkdm
= {
635 .name
= "eve4_clkdm",
636 .pwrdm
= { .name
= "eve4_pwrdm" },
637 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
638 .cm_inst
= DRA7XX_CM_CORE_AON_EVE4_INST
,
639 .clkdm_offs
= DRA7XX_CM_CORE_AON_EVE4_EVE4_CDOFFS
,
640 .dep_bit
= DRA7XX_EVE4_STATDEP_SHIFT
,
641 .wkdep_srcs
= eve4_wkup_sleep_deps
,
642 .sleepdep_srcs
= eve4_wkup_sleep_deps
,
643 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
646 static struct clockdomain eve2_7xx_clkdm
= {
647 .name
= "eve2_clkdm",
648 .pwrdm
= { .name
= "eve2_pwrdm" },
649 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
650 .cm_inst
= DRA7XX_CM_CORE_AON_EVE2_INST
,
651 .clkdm_offs
= DRA7XX_CM_CORE_AON_EVE2_EVE2_CDOFFS
,
652 .dep_bit
= DRA7XX_EVE2_STATDEP_SHIFT
,
653 .wkdep_srcs
= eve2_wkup_sleep_deps
,
654 .sleepdep_srcs
= eve2_wkup_sleep_deps
,
655 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
658 static struct clockdomain eve3_7xx_clkdm
= {
659 .name
= "eve3_clkdm",
660 .pwrdm
= { .name
= "eve3_pwrdm" },
661 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
662 .cm_inst
= DRA7XX_CM_CORE_AON_EVE3_INST
,
663 .clkdm_offs
= DRA7XX_CM_CORE_AON_EVE3_EVE3_CDOFFS
,
664 .dep_bit
= DRA7XX_EVE3_STATDEP_SHIFT
,
665 .wkdep_srcs
= eve3_wkup_sleep_deps
,
666 .sleepdep_srcs
= eve3_wkup_sleep_deps
,
667 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
670 static struct clockdomain wkupaon_7xx_clkdm
= {
671 .name
= "wkupaon_clkdm",
672 .pwrdm
= { .name
= "wkupaon_pwrdm" },
673 .prcm_partition
= DRA7XX_PRM_PARTITION
,
674 .cm_inst
= DRA7XX_PRM_WKUPAON_CM_INST
,
675 .clkdm_offs
= DRA7XX_PRM_WKUPAON_CM_WKUPAON_CDOFFS
,
676 .dep_bit
= DRA7XX_WKUPAON_STATDEP_SHIFT
,
677 .flags
= CLKDM_CAN_FORCE_WAKEUP
| CLKDM_CAN_HWSUP
,
680 static struct clockdomain eve1_7xx_clkdm
= {
681 .name
= "eve1_clkdm",
682 .pwrdm
= { .name
= "eve1_pwrdm" },
683 .prcm_partition
= DRA7XX_CM_CORE_AON_PARTITION
,
684 .cm_inst
= DRA7XX_CM_CORE_AON_EVE1_INST
,
685 .clkdm_offs
= DRA7XX_CM_CORE_AON_EVE1_EVE1_CDOFFS
,
686 .dep_bit
= DRA7XX_EVE1_STATDEP_SHIFT
,
687 .wkdep_srcs
= eve1_wkup_sleep_deps
,
688 .sleepdep_srcs
= eve1_wkup_sleep_deps
,
689 .flags
= CLKDM_CAN_HWSUP_SWSUP
,
692 /* As clockdomains are added or removed above, this list must also be changed */
693 static struct clockdomain
*clockdomains_dra7xx
[] __initdata
= {
706 &custefuse_7xx_clkdm
,
732 void __init
dra7xx_clockdomains_init(void)
734 clkdm_register_platform_funcs(&omap4_clkdm_operations
);
735 clkdm_register_clkdms(clockdomains_dra7xx
);
736 clkdm_complete_init();