~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/arm/mach-omap2/clockdomains7xx_data.c

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 // SPDX-License-Identifier: GPL-2.0-only
  2 /*
  3  * DRA7xx Clock domains framework
  4  *
  5  * Copyright (C) 2009-2013 Texas Instruments, Inc.
  6  * Copyright (C) 2009-2011 Nokia Corporation
  7  *
  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)
 12  *
 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.
 18  */
 19 
 20 #include <linux/kernel.h>
 21 #include <linux/io.h>
 22 
 23 #include "clockdomain.h"
 24 #include "cm1_7xx.h"
 25 #include "cm2_7xx.h"
 26 
 27 #include "cm-regbits-7xx.h"
 28 #include "prm7xx.h"
 29 #include "prcm44xx.h"
 30 #include "prcm_mpu7xx.h"
 31 
 32 /* Static Dependencies for DRA7xx Clock Domains */
 33 
 34 static struct clkdm_dep cam_wkup_sleep_deps[] = {
 35         { .clkdm_name = "emif_clkdm" },
 36         { NULL },
 37 };
 38 
 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" },
 54         { NULL },
 55 };
 56 
 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" },
 81         { NULL },
 82 };
 83 
 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" },
108         { NULL },
109 };
110 
111 static struct clkdm_dep dss_wkup_sleep_deps[] = {
112         { .clkdm_name = "emif_clkdm" },
113         { .clkdm_name = "iva_clkdm" },
114         { NULL },
115 };
116 
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" },
123         { NULL },
124 };
125 
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" },
132         { NULL },
133 };
134 
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" },
141         { NULL },
142 };
143 
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" },
150         { NULL },
151 };
152 
153 static struct clkdm_dep gmac_wkup_sleep_deps[] = {
154         { .clkdm_name = "emif_clkdm" },
155         { .clkdm_name = "l4per2_clkdm" },
156         { NULL },
157 };
158 
159 static struct clkdm_dep gpu_wkup_sleep_deps[] = {
160         { .clkdm_name = "emif_clkdm" },
161         { .clkdm_name = "iva_clkdm" },
162         { NULL },
163 };
164 
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" },
190         { NULL },
191 };
192 
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" },
218         { NULL },
219 };
220 
221 static struct clkdm_dep iva_wkup_sleep_deps[] = {
222         { .clkdm_name = "emif_clkdm" },
223         { NULL },
224 };
225 
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" },
234         { NULL },
235 };
236 
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" },
242         { NULL },
243 };
244 
245 static struct clkdm_dep l4sec_wkup_sleep_deps[] = {
246         { .clkdm_name = "emif_clkdm" },
247         { .clkdm_name = "l4per_clkdm" },
248         { NULL },
249 };
250 
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" },
277         { NULL },
278 };
279 
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" },
303         { NULL },
304 };
305 
306 static struct clkdm_dep vpe_wkup_sleep_deps[] = {
307         { .clkdm_name = "emif_clkdm" },
308         { .clkdm_name = "l4per3_clkdm" },
309         { NULL },
310 };
311 
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,
320 };
321 
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,
332 };
333 
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,
341 };
342 
343 static struct clockdomain iva_7xx_clkdm = {
344         .name             = "iva_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,
353 };
354 
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,
362 };
363 
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,
374 };
375 
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,
386 };
387 
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,
398 };
399 
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,
410 };
411 
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,
420 };
421 
422 static struct clockdomain vpe_7xx_clkdm = {
423         .name             = "vpe_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,
432 };
433 
434 static struct clockdomain mpu_7xx_clkdm = {
435         .name             = "mpu_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,
443 };
444 
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,
452 };
453 
454 static struct clockdomain ipu_7xx_clkdm = {
455         .name             = "ipu_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,
462 };
463 
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,
471 };
472 
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,
483 };
484 
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,
493 };
494 
495 static struct clockdomain dma_7xx_clkdm = {
496         .name             = "dma_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,
504 };
505 
506 static struct clockdomain rtc_7xx_clkdm = {
507         .name             = "rtc_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,
513 };
514 
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,
525 };
526 
527 static struct clockdomain atl_7xx_clkdm = {
528         .name             = "atl_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,
535 };
536 
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,
543 };
544 
545 static struct clockdomain dss_7xx_clkdm = {
546         .name             = "dss_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,
555 };
556 
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,
565 };
566 
567 static struct clockdomain emu_7xx_clkdm = {
568         .name             = "emu_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,
574 };
575 
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,
586 };
587 
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,
598 };
599 
600 static struct clockdomain cam_7xx_clkdm = {
601         .name             = "cam_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_SWSUP,
610 };
611 
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,
620 };
621 
622 static struct clockdomain gpu_7xx_clkdm = {
623         .name             = "gpu_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,
632 };
633 
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,
644 };
645 
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,
656 };
657 
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,
668 };
669 
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,
678 };
679 
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,
690 };
691 
692 /* As clockdomains are added or removed above, this list must also be changed */
693 static struct clockdomain *clockdomains_dra7xx[] __initdata = {
694         &l4per3_7xx_clkdm,
695         &l4per2_7xx_clkdm,
696         &mpu0_7xx_clkdm,
697         &iva_7xx_clkdm,
698         &coreaon_7xx_clkdm,
699         &ipu1_7xx_clkdm,
700         &ipu2_7xx_clkdm,
701         &l3init_7xx_clkdm,
702         &l4sec_7xx_clkdm,
703         &l3main1_7xx_clkdm,
704         &vpe_7xx_clkdm,
705         &mpu_7xx_clkdm,
706         &custefuse_7xx_clkdm,
707         &ipu_7xx_clkdm,
708         &mpu1_7xx_clkdm,
709         &gmac_7xx_clkdm,
710         &l4cfg_7xx_clkdm,
711         &dma_7xx_clkdm,
712         &rtc_7xx_clkdm,
713         &pcie_7xx_clkdm,
714         &atl_7xx_clkdm,
715         &l3instr_7xx_clkdm,
716         &dss_7xx_clkdm,
717         &emif_7xx_clkdm,
718         &emu_7xx_clkdm,
719         &dsp2_7xx_clkdm,
720         &dsp1_7xx_clkdm,
721         &cam_7xx_clkdm,
722         &l4per_7xx_clkdm,
723         &gpu_7xx_clkdm,
724         &eve4_7xx_clkdm,
725         &eve2_7xx_clkdm,
726         &eve3_7xx_clkdm,
727         &wkupaon_7xx_clkdm,
728         &eve1_7xx_clkdm,
729         NULL
730 };
731 
732 void __init dra7xx_clockdomains_init(void)
733 {
734         clkdm_register_platform_funcs(&omap4_clkdm_operations);
735         clkdm_register_clkdms(clockdomains_dra7xx);
736         clkdm_complete_init();
737 }
738 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php