]> git.proxmox.com Git - mirror_ubuntu-kernels.git/blob - drivers/clk/qcom/gcc-sdm845.c
Merge branches 'for-5.1/upstream-fixes', 'for-5.2/core', 'for-5.2/ish', 'for-5.2...
[mirror_ubuntu-kernels.git] / drivers / clk / qcom / gcc-sdm845.c
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Copyright (c) 2018, The Linux Foundation. All rights reserved.
4 */
5
6 #include <linux/kernel.h>
7 #include <linux/bitops.h>
8 #include <linux/err.h>
9 #include <linux/platform_device.h>
10 #include <linux/module.h>
11 #include <linux/of.h>
12 #include <linux/of_device.h>
13 #include <linux/clk-provider.h>
14 #include <linux/regmap.h>
15 #include <linux/reset-controller.h>
16
17 #include <dt-bindings/clock/qcom,gcc-sdm845.h>
18
19 #include "common.h"
20 #include "clk-regmap.h"
21 #include "clk-pll.h"
22 #include "clk-rcg.h"
23 #include "clk-branch.h"
24 #include "clk-alpha-pll.h"
25 #include "gdsc.h"
26 #include "reset.h"
27
28 enum {
29 P_BI_TCXO,
30 P_AUD_REF_CLK,
31 P_CORE_BI_PLL_TEST_SE,
32 P_GPLL0_OUT_EVEN,
33 P_GPLL0_OUT_MAIN,
34 P_GPLL4_OUT_MAIN,
35 P_SLEEP_CLK,
36 };
37
38 static const struct parent_map gcc_parent_map_0[] = {
39 { P_BI_TCXO, 0 },
40 { P_GPLL0_OUT_MAIN, 1 },
41 { P_GPLL0_OUT_EVEN, 6 },
42 { P_CORE_BI_PLL_TEST_SE, 7 },
43 };
44
45 static const char * const gcc_parent_names_0[] = {
46 "bi_tcxo",
47 "gpll0",
48 "gpll0_out_even",
49 "core_bi_pll_test_se",
50 };
51
52 static const struct parent_map gcc_parent_map_1[] = {
53 { P_BI_TCXO, 0 },
54 { P_GPLL0_OUT_MAIN, 1 },
55 { P_SLEEP_CLK, 5 },
56 { P_GPLL0_OUT_EVEN, 6 },
57 { P_CORE_BI_PLL_TEST_SE, 7 },
58 };
59
60 static const char * const gcc_parent_names_1[] = {
61 "bi_tcxo",
62 "gpll0",
63 "core_pi_sleep_clk",
64 "gpll0_out_even",
65 "core_bi_pll_test_se",
66 };
67
68 static const struct parent_map gcc_parent_map_2[] = {
69 { P_BI_TCXO, 0 },
70 { P_SLEEP_CLK, 5 },
71 { P_CORE_BI_PLL_TEST_SE, 7 },
72 };
73
74 static const char * const gcc_parent_names_2[] = {
75 "bi_tcxo",
76 "core_pi_sleep_clk",
77 "core_bi_pll_test_se",
78 };
79
80 static const struct parent_map gcc_parent_map_3[] = {
81 { P_BI_TCXO, 0 },
82 { P_GPLL0_OUT_MAIN, 1 },
83 { P_CORE_BI_PLL_TEST_SE, 7 },
84 };
85
86 static const char * const gcc_parent_names_3[] = {
87 "bi_tcxo",
88 "gpll0",
89 "core_bi_pll_test_se",
90 };
91
92 static const struct parent_map gcc_parent_map_4[] = {
93 { P_BI_TCXO, 0 },
94 { P_CORE_BI_PLL_TEST_SE, 7 },
95 };
96
97 static const char * const gcc_parent_names_4[] = {
98 "bi_tcxo",
99 "core_bi_pll_test_se",
100 };
101
102 static const struct parent_map gcc_parent_map_6[] = {
103 { P_BI_TCXO, 0 },
104 { P_GPLL0_OUT_MAIN, 1 },
105 { P_AUD_REF_CLK, 2 },
106 { P_GPLL0_OUT_EVEN, 6 },
107 { P_CORE_BI_PLL_TEST_SE, 7 },
108 };
109
110 static const char * const gcc_parent_names_6[] = {
111 "bi_tcxo",
112 "gpll0",
113 "aud_ref_clk",
114 "gpll0_out_even",
115 "core_bi_pll_test_se",
116 };
117
118 static const char * const gcc_parent_names_7_ao[] = {
119 "bi_tcxo_ao",
120 "gpll0",
121 "gpll0_out_even",
122 "core_bi_pll_test_se",
123 };
124
125 static const char * const gcc_parent_names_8[] = {
126 "bi_tcxo",
127 "gpll0",
128 "core_bi_pll_test_se",
129 };
130
131 static const char * const gcc_parent_names_8_ao[] = {
132 "bi_tcxo_ao",
133 "gpll0",
134 "core_bi_pll_test_se",
135 };
136
137 static const struct parent_map gcc_parent_map_10[] = {
138 { P_BI_TCXO, 0 },
139 { P_GPLL0_OUT_MAIN, 1 },
140 { P_GPLL4_OUT_MAIN, 5 },
141 { P_GPLL0_OUT_EVEN, 6 },
142 { P_CORE_BI_PLL_TEST_SE, 7 },
143 };
144
145 static const char * const gcc_parent_names_10[] = {
146 "bi_tcxo",
147 "gpll0",
148 "gpll4",
149 "gpll0_out_even",
150 "core_bi_pll_test_se",
151 };
152
153 static struct clk_alpha_pll gpll0 = {
154 .offset = 0x0,
155 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
156 .clkr = {
157 .enable_reg = 0x52000,
158 .enable_mask = BIT(0),
159 .hw.init = &(struct clk_init_data){
160 .name = "gpll0",
161 .parent_names = (const char *[]){ "bi_tcxo" },
162 .num_parents = 1,
163 .ops = &clk_alpha_pll_fixed_fabia_ops,
164 },
165 },
166 };
167
168 static struct clk_alpha_pll gpll4 = {
169 .offset = 0x76000,
170 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
171 .clkr = {
172 .enable_reg = 0x52000,
173 .enable_mask = BIT(4),
174 .hw.init = &(struct clk_init_data){
175 .name = "gpll4",
176 .parent_names = (const char *[]){ "bi_tcxo" },
177 .num_parents = 1,
178 .ops = &clk_alpha_pll_fixed_fabia_ops,
179 },
180 },
181 };
182
183 static const struct clk_div_table post_div_table_fabia_even[] = {
184 { 0x0, 1 },
185 { 0x1, 2 },
186 { 0x3, 4 },
187 { 0x7, 8 },
188 { }
189 };
190
191 static struct clk_alpha_pll_postdiv gpll0_out_even = {
192 .offset = 0x0,
193 .post_div_shift = 8,
194 .post_div_table = post_div_table_fabia_even,
195 .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
196 .width = 4,
197 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
198 .clkr.hw.init = &(struct clk_init_data){
199 .name = "gpll0_out_even",
200 .parent_names = (const char *[]){ "gpll0" },
201 .num_parents = 1,
202 .ops = &clk_alpha_pll_postdiv_fabia_ops,
203 },
204 };
205
206 static const struct freq_tbl ftbl_gcc_cpuss_ahb_clk_src[] = {
207 F(19200000, P_BI_TCXO, 1, 0, 0),
208 { }
209 };
210
211 static struct clk_rcg2 gcc_cpuss_ahb_clk_src = {
212 .cmd_rcgr = 0x48014,
213 .mnd_width = 0,
214 .hid_width = 5,
215 .parent_map = gcc_parent_map_0,
216 .freq_tbl = ftbl_gcc_cpuss_ahb_clk_src,
217 .clkr.hw.init = &(struct clk_init_data){
218 .name = "gcc_cpuss_ahb_clk_src",
219 .parent_names = gcc_parent_names_7_ao,
220 .num_parents = 4,
221 .ops = &clk_rcg2_ops,
222 },
223 };
224
225 static const struct freq_tbl ftbl_gcc_cpuss_rbcpr_clk_src[] = {
226 F(19200000, P_BI_TCXO, 1, 0, 0),
227 { }
228 };
229
230 static struct clk_rcg2 gcc_cpuss_rbcpr_clk_src = {
231 .cmd_rcgr = 0x4815c,
232 .mnd_width = 0,
233 .hid_width = 5,
234 .parent_map = gcc_parent_map_3,
235 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
236 .clkr.hw.init = &(struct clk_init_data){
237 .name = "gcc_cpuss_rbcpr_clk_src",
238 .parent_names = gcc_parent_names_8_ao,
239 .num_parents = 3,
240 .ops = &clk_rcg2_ops,
241 },
242 };
243
244 static const struct freq_tbl ftbl_gcc_gp1_clk_src[] = {
245 F(19200000, P_BI_TCXO, 1, 0, 0),
246 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
247 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
248 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
249 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
250 { }
251 };
252
253 static struct clk_rcg2 gcc_gp1_clk_src = {
254 .cmd_rcgr = 0x64004,
255 .mnd_width = 8,
256 .hid_width = 5,
257 .parent_map = gcc_parent_map_1,
258 .freq_tbl = ftbl_gcc_gp1_clk_src,
259 .clkr.hw.init = &(struct clk_init_data){
260 .name = "gcc_gp1_clk_src",
261 .parent_names = gcc_parent_names_1,
262 .num_parents = 5,
263 .ops = &clk_rcg2_ops,
264 },
265 };
266
267 static struct clk_rcg2 gcc_gp2_clk_src = {
268 .cmd_rcgr = 0x65004,
269 .mnd_width = 8,
270 .hid_width = 5,
271 .parent_map = gcc_parent_map_1,
272 .freq_tbl = ftbl_gcc_gp1_clk_src,
273 .clkr.hw.init = &(struct clk_init_data){
274 .name = "gcc_gp2_clk_src",
275 .parent_names = gcc_parent_names_1,
276 .num_parents = 5,
277 .ops = &clk_rcg2_ops,
278 },
279 };
280
281 static struct clk_rcg2 gcc_gp3_clk_src = {
282 .cmd_rcgr = 0x66004,
283 .mnd_width = 8,
284 .hid_width = 5,
285 .parent_map = gcc_parent_map_1,
286 .freq_tbl = ftbl_gcc_gp1_clk_src,
287 .clkr.hw.init = &(struct clk_init_data){
288 .name = "gcc_gp3_clk_src",
289 .parent_names = gcc_parent_names_1,
290 .num_parents = 5,
291 .ops = &clk_rcg2_ops,
292 },
293 };
294
295 static const struct freq_tbl ftbl_gcc_pcie_0_aux_clk_src[] = {
296 F(9600000, P_BI_TCXO, 2, 0, 0),
297 F(19200000, P_BI_TCXO, 1, 0, 0),
298 { }
299 };
300
301 static struct clk_rcg2 gcc_pcie_0_aux_clk_src = {
302 .cmd_rcgr = 0x6b028,
303 .mnd_width = 16,
304 .hid_width = 5,
305 .parent_map = gcc_parent_map_2,
306 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src,
307 .clkr.hw.init = &(struct clk_init_data){
308 .name = "gcc_pcie_0_aux_clk_src",
309 .parent_names = gcc_parent_names_2,
310 .num_parents = 3,
311 .ops = &clk_rcg2_ops,
312 },
313 };
314
315 static struct clk_rcg2 gcc_pcie_1_aux_clk_src = {
316 .cmd_rcgr = 0x8d028,
317 .mnd_width = 16,
318 .hid_width = 5,
319 .parent_map = gcc_parent_map_2,
320 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src,
321 .clkr.hw.init = &(struct clk_init_data){
322 .name = "gcc_pcie_1_aux_clk_src",
323 .parent_names = gcc_parent_names_2,
324 .num_parents = 3,
325 .ops = &clk_rcg2_ops,
326 },
327 };
328
329 static const struct freq_tbl ftbl_gcc_pcie_phy_refgen_clk_src[] = {
330 F(19200000, P_BI_TCXO, 1, 0, 0),
331 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
332 { }
333 };
334
335 static struct clk_rcg2 gcc_pcie_phy_refgen_clk_src = {
336 .cmd_rcgr = 0x6f014,
337 .mnd_width = 0,
338 .hid_width = 5,
339 .parent_map = gcc_parent_map_0,
340 .freq_tbl = ftbl_gcc_pcie_phy_refgen_clk_src,
341 .clkr.hw.init = &(struct clk_init_data){
342 .name = "gcc_pcie_phy_refgen_clk_src",
343 .parent_names = gcc_parent_names_0,
344 .num_parents = 4,
345 .ops = &clk_rcg2_ops,
346 },
347 };
348
349 static const struct freq_tbl ftbl_gcc_qspi_core_clk_src[] = {
350 F(19200000, P_BI_TCXO, 1, 0, 0),
351 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
352 F(150000000, P_GPLL0_OUT_MAIN, 4, 0, 0),
353 F(300000000, P_GPLL0_OUT_MAIN, 2, 0, 0),
354 { }
355 };
356
357 static struct clk_rcg2 gcc_qspi_core_clk_src = {
358 .cmd_rcgr = 0x4b008,
359 .mnd_width = 0,
360 .hid_width = 5,
361 .parent_map = gcc_parent_map_0,
362 .freq_tbl = ftbl_gcc_qspi_core_clk_src,
363 .clkr.hw.init = &(struct clk_init_data){
364 .name = "gcc_qspi_core_clk_src",
365 .parent_names = gcc_parent_names_0,
366 .num_parents = 4,
367 .ops = &clk_rcg2_floor_ops,
368 },
369 };
370
371 static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = {
372 F(9600000, P_BI_TCXO, 2, 0, 0),
373 F(19200000, P_BI_TCXO, 1, 0, 0),
374 F(60000000, P_GPLL0_OUT_MAIN, 10, 0, 0),
375 { }
376 };
377
378 static struct clk_rcg2 gcc_pdm2_clk_src = {
379 .cmd_rcgr = 0x33010,
380 .mnd_width = 0,
381 .hid_width = 5,
382 .parent_map = gcc_parent_map_0,
383 .freq_tbl = ftbl_gcc_pdm2_clk_src,
384 .clkr.hw.init = &(struct clk_init_data){
385 .name = "gcc_pdm2_clk_src",
386 .parent_names = gcc_parent_names_0,
387 .num_parents = 4,
388 .ops = &clk_rcg2_ops,
389 },
390 };
391
392 static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s0_clk_src[] = {
393 F(7372800, P_GPLL0_OUT_EVEN, 1, 384, 15625),
394 F(14745600, P_GPLL0_OUT_EVEN, 1, 768, 15625),
395 F(19200000, P_BI_TCXO, 1, 0, 0),
396 F(29491200, P_GPLL0_OUT_EVEN, 1, 1536, 15625),
397 F(32000000, P_GPLL0_OUT_EVEN, 1, 8, 75),
398 F(48000000, P_GPLL0_OUT_EVEN, 1, 4, 25),
399 F(64000000, P_GPLL0_OUT_EVEN, 1, 16, 75),
400 F(80000000, P_GPLL0_OUT_EVEN, 1, 4, 15),
401 F(96000000, P_GPLL0_OUT_EVEN, 1, 8, 25),
402 F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
403 F(102400000, P_GPLL0_OUT_EVEN, 1, 128, 375),
404 F(112000000, P_GPLL0_OUT_EVEN, 1, 28, 75),
405 F(117964800, P_GPLL0_OUT_EVEN, 1, 6144, 15625),
406 F(120000000, P_GPLL0_OUT_EVEN, 2.5, 0, 0),
407 F(128000000, P_GPLL0_OUT_MAIN, 1, 16, 75),
408 { }
409 };
410
411 static struct clk_init_data gcc_qupv3_wrap0_s0_clk_init = {
412 .name = "gcc_qupv3_wrap0_s0_clk_src",
413 .parent_names = gcc_parent_names_0,
414 .num_parents = 4,
415 .ops = &clk_rcg2_shared_ops,
416 };
417
418 static struct clk_rcg2 gcc_qupv3_wrap0_s0_clk_src = {
419 .cmd_rcgr = 0x17034,
420 .mnd_width = 16,
421 .hid_width = 5,
422 .parent_map = gcc_parent_map_0,
423 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
424 .clkr.hw.init = &gcc_qupv3_wrap0_s0_clk_init,
425 };
426
427 static struct clk_init_data gcc_qupv3_wrap0_s1_clk_init = {
428 .name = "gcc_qupv3_wrap0_s1_clk_src",
429 .parent_names = gcc_parent_names_0,
430 .num_parents = 4,
431 .ops = &clk_rcg2_shared_ops,
432 };
433
434 static struct clk_rcg2 gcc_qupv3_wrap0_s1_clk_src = {
435 .cmd_rcgr = 0x17164,
436 .mnd_width = 16,
437 .hid_width = 5,
438 .parent_map = gcc_parent_map_0,
439 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
440 .clkr.hw.init = &gcc_qupv3_wrap0_s1_clk_init,
441 };
442
443 static struct clk_init_data gcc_qupv3_wrap0_s2_clk_init = {
444 .name = "gcc_qupv3_wrap0_s2_clk_src",
445 .parent_names = gcc_parent_names_0,
446 .num_parents = 4,
447 .ops = &clk_rcg2_shared_ops,
448 };
449
450 static struct clk_rcg2 gcc_qupv3_wrap0_s2_clk_src = {
451 .cmd_rcgr = 0x17294,
452 .mnd_width = 16,
453 .hid_width = 5,
454 .parent_map = gcc_parent_map_0,
455 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
456 .clkr.hw.init = &gcc_qupv3_wrap0_s2_clk_init,
457 };
458
459 static struct clk_init_data gcc_qupv3_wrap0_s3_clk_init = {
460 .name = "gcc_qupv3_wrap0_s3_clk_src",
461 .parent_names = gcc_parent_names_0,
462 .num_parents = 4,
463 .ops = &clk_rcg2_shared_ops,
464 };
465
466 static struct clk_rcg2 gcc_qupv3_wrap0_s3_clk_src = {
467 .cmd_rcgr = 0x173c4,
468 .mnd_width = 16,
469 .hid_width = 5,
470 .parent_map = gcc_parent_map_0,
471 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
472 .clkr.hw.init = &gcc_qupv3_wrap0_s3_clk_init,
473 };
474
475 static struct clk_init_data gcc_qupv3_wrap0_s4_clk_init = {
476 .name = "gcc_qupv3_wrap0_s4_clk_src",
477 .parent_names = gcc_parent_names_0,
478 .num_parents = 4,
479 .ops = &clk_rcg2_shared_ops,
480 };
481
482 static struct clk_rcg2 gcc_qupv3_wrap0_s4_clk_src = {
483 .cmd_rcgr = 0x174f4,
484 .mnd_width = 16,
485 .hid_width = 5,
486 .parent_map = gcc_parent_map_0,
487 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
488 .clkr.hw.init = &gcc_qupv3_wrap0_s4_clk_init,
489 };
490
491 static struct clk_init_data gcc_qupv3_wrap0_s5_clk_init = {
492 .name = "gcc_qupv3_wrap0_s5_clk_src",
493 .parent_names = gcc_parent_names_0,
494 .num_parents = 4,
495 .ops = &clk_rcg2_shared_ops,
496 };
497
498 static struct clk_rcg2 gcc_qupv3_wrap0_s5_clk_src = {
499 .cmd_rcgr = 0x17624,
500 .mnd_width = 16,
501 .hid_width = 5,
502 .parent_map = gcc_parent_map_0,
503 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
504 .clkr.hw.init = &gcc_qupv3_wrap0_s5_clk_init,
505 };
506
507 static struct clk_init_data gcc_qupv3_wrap0_s6_clk_init = {
508 .name = "gcc_qupv3_wrap0_s6_clk_src",
509 .parent_names = gcc_parent_names_0,
510 .num_parents = 4,
511 .ops = &clk_rcg2_shared_ops,
512 };
513
514 static struct clk_rcg2 gcc_qupv3_wrap0_s6_clk_src = {
515 .cmd_rcgr = 0x17754,
516 .mnd_width = 16,
517 .hid_width = 5,
518 .parent_map = gcc_parent_map_0,
519 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
520 .clkr.hw.init = &gcc_qupv3_wrap0_s6_clk_init,
521 };
522
523 static struct clk_init_data gcc_qupv3_wrap0_s7_clk_init = {
524 .name = "gcc_qupv3_wrap0_s7_clk_src",
525 .parent_names = gcc_parent_names_0,
526 .num_parents = 4,
527 .ops = &clk_rcg2_shared_ops,
528 };
529
530 static struct clk_rcg2 gcc_qupv3_wrap0_s7_clk_src = {
531 .cmd_rcgr = 0x17884,
532 .mnd_width = 16,
533 .hid_width = 5,
534 .parent_map = gcc_parent_map_0,
535 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
536 .clkr.hw.init = &gcc_qupv3_wrap0_s7_clk_init,
537 };
538
539 static struct clk_init_data gcc_qupv3_wrap1_s0_clk_init = {
540 .name = "gcc_qupv3_wrap1_s0_clk_src",
541 .parent_names = gcc_parent_names_0,
542 .num_parents = 4,
543 .ops = &clk_rcg2_shared_ops,
544 };
545
546 static struct clk_rcg2 gcc_qupv3_wrap1_s0_clk_src = {
547 .cmd_rcgr = 0x18018,
548 .mnd_width = 16,
549 .hid_width = 5,
550 .parent_map = gcc_parent_map_0,
551 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
552 .clkr.hw.init = &gcc_qupv3_wrap1_s0_clk_init,
553 };
554
555 static struct clk_init_data gcc_qupv3_wrap1_s1_clk_init = {
556 .name = "gcc_qupv3_wrap1_s1_clk_src",
557 .parent_names = gcc_parent_names_0,
558 .num_parents = 4,
559 .ops = &clk_rcg2_shared_ops,
560 };
561
562 static struct clk_rcg2 gcc_qupv3_wrap1_s1_clk_src = {
563 .cmd_rcgr = 0x18148,
564 .mnd_width = 16,
565 .hid_width = 5,
566 .parent_map = gcc_parent_map_0,
567 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
568 .clkr.hw.init = &gcc_qupv3_wrap1_s1_clk_init,
569 };
570
571 static struct clk_init_data gcc_qupv3_wrap1_s2_clk_init = {
572 .name = "gcc_qupv3_wrap1_s2_clk_src",
573 .parent_names = gcc_parent_names_0,
574 .num_parents = 4,
575 .ops = &clk_rcg2_shared_ops,
576 };
577
578 static struct clk_rcg2 gcc_qupv3_wrap1_s2_clk_src = {
579 .cmd_rcgr = 0x18278,
580 .mnd_width = 16,
581 .hid_width = 5,
582 .parent_map = gcc_parent_map_0,
583 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
584 .clkr.hw.init = &gcc_qupv3_wrap1_s2_clk_init,
585 };
586
587 static struct clk_init_data gcc_qupv3_wrap1_s3_clk_init = {
588 .name = "gcc_qupv3_wrap1_s3_clk_src",
589 .parent_names = gcc_parent_names_0,
590 .num_parents = 4,
591 .ops = &clk_rcg2_shared_ops,
592 };
593
594 static struct clk_rcg2 gcc_qupv3_wrap1_s3_clk_src = {
595 .cmd_rcgr = 0x183a8,
596 .mnd_width = 16,
597 .hid_width = 5,
598 .parent_map = gcc_parent_map_0,
599 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
600 .clkr.hw.init = &gcc_qupv3_wrap1_s3_clk_init,
601 };
602
603 static struct clk_init_data gcc_qupv3_wrap1_s4_clk_init = {
604 .name = "gcc_qupv3_wrap1_s4_clk_src",
605 .parent_names = gcc_parent_names_0,
606 .num_parents = 4,
607 .ops = &clk_rcg2_shared_ops,
608 };
609
610 static struct clk_rcg2 gcc_qupv3_wrap1_s4_clk_src = {
611 .cmd_rcgr = 0x184d8,
612 .mnd_width = 16,
613 .hid_width = 5,
614 .parent_map = gcc_parent_map_0,
615 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
616 .clkr.hw.init = &gcc_qupv3_wrap1_s4_clk_init,
617 };
618
619 static struct clk_init_data gcc_qupv3_wrap1_s5_clk_init = {
620 .name = "gcc_qupv3_wrap1_s5_clk_src",
621 .parent_names = gcc_parent_names_0,
622 .num_parents = 4,
623 .ops = &clk_rcg2_shared_ops,
624 };
625
626 static struct clk_rcg2 gcc_qupv3_wrap1_s5_clk_src = {
627 .cmd_rcgr = 0x18608,
628 .mnd_width = 16,
629 .hid_width = 5,
630 .parent_map = gcc_parent_map_0,
631 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
632 .clkr.hw.init = &gcc_qupv3_wrap1_s5_clk_init,
633 };
634
635 static struct clk_init_data gcc_qupv3_wrap1_s6_clk_init = {
636 .name = "gcc_qupv3_wrap1_s6_clk_src",
637 .parent_names = gcc_parent_names_0,
638 .num_parents = 4,
639 .ops = &clk_rcg2_shared_ops,
640 };
641
642 static struct clk_rcg2 gcc_qupv3_wrap1_s6_clk_src = {
643 .cmd_rcgr = 0x18738,
644 .mnd_width = 16,
645 .hid_width = 5,
646 .parent_map = gcc_parent_map_0,
647 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
648 .clkr.hw.init = &gcc_qupv3_wrap1_s6_clk_init,
649 };
650
651 static struct clk_init_data gcc_qupv3_wrap1_s7_clk_init = {
652 .name = "gcc_qupv3_wrap1_s7_clk_src",
653 .parent_names = gcc_parent_names_0,
654 .num_parents = 4,
655 .ops = &clk_rcg2_shared_ops,
656 };
657
658 static struct clk_rcg2 gcc_qupv3_wrap1_s7_clk_src = {
659 .cmd_rcgr = 0x18868,
660 .mnd_width = 16,
661 .hid_width = 5,
662 .parent_map = gcc_parent_map_0,
663 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
664 .clkr.hw.init = &gcc_qupv3_wrap1_s7_clk_init,
665 };
666
667 static const struct freq_tbl ftbl_gcc_sdcc2_apps_clk_src[] = {
668 F(400000, P_BI_TCXO, 12, 1, 4),
669 F(9600000, P_BI_TCXO, 2, 0, 0),
670 F(19200000, P_BI_TCXO, 1, 0, 0),
671 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
672 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
673 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
674 F(201500000, P_GPLL4_OUT_MAIN, 4, 0, 0),
675 { }
676 };
677
678 static struct clk_rcg2 gcc_sdcc2_apps_clk_src = {
679 .cmd_rcgr = 0x1400c,
680 .mnd_width = 8,
681 .hid_width = 5,
682 .parent_map = gcc_parent_map_10,
683 .freq_tbl = ftbl_gcc_sdcc2_apps_clk_src,
684 .clkr.hw.init = &(struct clk_init_data){
685 .name = "gcc_sdcc2_apps_clk_src",
686 .parent_names = gcc_parent_names_10,
687 .num_parents = 5,
688 .ops = &clk_rcg2_ops,
689 },
690 };
691
692 static const struct freq_tbl ftbl_gcc_sdcc4_apps_clk_src[] = {
693 F(400000, P_BI_TCXO, 12, 1, 4),
694 F(9600000, P_BI_TCXO, 2, 0, 0),
695 F(19200000, P_BI_TCXO, 1, 0, 0),
696 F(25000000, P_GPLL0_OUT_MAIN, 12, 1, 2),
697 F(50000000, P_GPLL0_OUT_MAIN, 12, 0, 0),
698 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
699 { }
700 };
701
702 static struct clk_rcg2 gcc_sdcc4_apps_clk_src = {
703 .cmd_rcgr = 0x1600c,
704 .mnd_width = 8,
705 .hid_width = 5,
706 .parent_map = gcc_parent_map_0,
707 .freq_tbl = ftbl_gcc_sdcc4_apps_clk_src,
708 .clkr.hw.init = &(struct clk_init_data){
709 .name = "gcc_sdcc4_apps_clk_src",
710 .parent_names = gcc_parent_names_0,
711 .num_parents = 4,
712 .ops = &clk_rcg2_ops,
713 },
714 };
715
716 static const struct freq_tbl ftbl_gcc_tsif_ref_clk_src[] = {
717 F(105495, P_BI_TCXO, 2, 1, 91),
718 { }
719 };
720
721 static struct clk_rcg2 gcc_tsif_ref_clk_src = {
722 .cmd_rcgr = 0x36010,
723 .mnd_width = 8,
724 .hid_width = 5,
725 .parent_map = gcc_parent_map_6,
726 .freq_tbl = ftbl_gcc_tsif_ref_clk_src,
727 .clkr.hw.init = &(struct clk_init_data){
728 .name = "gcc_tsif_ref_clk_src",
729 .parent_names = gcc_parent_names_6,
730 .num_parents = 5,
731 .ops = &clk_rcg2_ops,
732 },
733 };
734
735 static const struct freq_tbl ftbl_gcc_ufs_card_axi_clk_src[] = {
736 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
737 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
738 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
739 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
740 F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
741 { }
742 };
743
744 static struct clk_rcg2 gcc_ufs_card_axi_clk_src = {
745 .cmd_rcgr = 0x7501c,
746 .mnd_width = 8,
747 .hid_width = 5,
748 .parent_map = gcc_parent_map_0,
749 .freq_tbl = ftbl_gcc_ufs_card_axi_clk_src,
750 .clkr.hw.init = &(struct clk_init_data){
751 .name = "gcc_ufs_card_axi_clk_src",
752 .parent_names = gcc_parent_names_0,
753 .num_parents = 4,
754 .ops = &clk_rcg2_shared_ops,
755 },
756 };
757
758 static const struct freq_tbl ftbl_gcc_ufs_card_ice_core_clk_src[] = {
759 F(37500000, P_GPLL0_OUT_EVEN, 8, 0, 0),
760 F(75000000, P_GPLL0_OUT_EVEN, 4, 0, 0),
761 F(150000000, P_GPLL0_OUT_MAIN, 4, 0, 0),
762 F(300000000, P_GPLL0_OUT_MAIN, 2, 0, 0),
763 { }
764 };
765
766 static struct clk_rcg2 gcc_ufs_card_ice_core_clk_src = {
767 .cmd_rcgr = 0x7505c,
768 .mnd_width = 0,
769 .hid_width = 5,
770 .parent_map = gcc_parent_map_0,
771 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src,
772 .clkr.hw.init = &(struct clk_init_data){
773 .name = "gcc_ufs_card_ice_core_clk_src",
774 .parent_names = gcc_parent_names_0,
775 .num_parents = 4,
776 .ops = &clk_rcg2_shared_ops,
777 },
778 };
779
780 static struct clk_rcg2 gcc_ufs_card_phy_aux_clk_src = {
781 .cmd_rcgr = 0x75090,
782 .mnd_width = 0,
783 .hid_width = 5,
784 .parent_map = gcc_parent_map_4,
785 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
786 .clkr.hw.init = &(struct clk_init_data){
787 .name = "gcc_ufs_card_phy_aux_clk_src",
788 .parent_names = gcc_parent_names_4,
789 .num_parents = 2,
790 .ops = &clk_rcg2_ops,
791 },
792 };
793
794 static const struct freq_tbl ftbl_gcc_ufs_card_unipro_core_clk_src[] = {
795 F(37500000, P_GPLL0_OUT_EVEN, 8, 0, 0),
796 F(75000000, P_GPLL0_OUT_MAIN, 8, 0, 0),
797 F(150000000, P_GPLL0_OUT_MAIN, 4, 0, 0),
798 { }
799 };
800
801 static struct clk_rcg2 gcc_ufs_card_unipro_core_clk_src = {
802 .cmd_rcgr = 0x75074,
803 .mnd_width = 0,
804 .hid_width = 5,
805 .parent_map = gcc_parent_map_0,
806 .freq_tbl = ftbl_gcc_ufs_card_unipro_core_clk_src,
807 .clkr.hw.init = &(struct clk_init_data){
808 .name = "gcc_ufs_card_unipro_core_clk_src",
809 .parent_names = gcc_parent_names_0,
810 .num_parents = 4,
811 .ops = &clk_rcg2_shared_ops,
812 },
813 };
814
815 static const struct freq_tbl ftbl_gcc_ufs_phy_axi_clk_src[] = {
816 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
817 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
818 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
819 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
820 F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
821 { }
822 };
823
824 static struct clk_rcg2 gcc_ufs_phy_axi_clk_src = {
825 .cmd_rcgr = 0x7701c,
826 .mnd_width = 8,
827 .hid_width = 5,
828 .parent_map = gcc_parent_map_0,
829 .freq_tbl = ftbl_gcc_ufs_phy_axi_clk_src,
830 .clkr.hw.init = &(struct clk_init_data){
831 .name = "gcc_ufs_phy_axi_clk_src",
832 .parent_names = gcc_parent_names_0,
833 .num_parents = 4,
834 .ops = &clk_rcg2_shared_ops,
835 },
836 };
837
838 static struct clk_rcg2 gcc_ufs_phy_ice_core_clk_src = {
839 .cmd_rcgr = 0x7705c,
840 .mnd_width = 0,
841 .hid_width = 5,
842 .parent_map = gcc_parent_map_0,
843 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src,
844 .clkr.hw.init = &(struct clk_init_data){
845 .name = "gcc_ufs_phy_ice_core_clk_src",
846 .parent_names = gcc_parent_names_0,
847 .num_parents = 4,
848 .ops = &clk_rcg2_shared_ops,
849 },
850 };
851
852 static struct clk_rcg2 gcc_ufs_phy_phy_aux_clk_src = {
853 .cmd_rcgr = 0x77090,
854 .mnd_width = 0,
855 .hid_width = 5,
856 .parent_map = gcc_parent_map_4,
857 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src,
858 .clkr.hw.init = &(struct clk_init_data){
859 .name = "gcc_ufs_phy_phy_aux_clk_src",
860 .parent_names = gcc_parent_names_4,
861 .num_parents = 2,
862 .ops = &clk_rcg2_shared_ops,
863 },
864 };
865
866 static struct clk_rcg2 gcc_ufs_phy_unipro_core_clk_src = {
867 .cmd_rcgr = 0x77074,
868 .mnd_width = 0,
869 .hid_width = 5,
870 .parent_map = gcc_parent_map_0,
871 .freq_tbl = ftbl_gcc_ufs_card_unipro_core_clk_src,
872 .clkr.hw.init = &(struct clk_init_data){
873 .name = "gcc_ufs_phy_unipro_core_clk_src",
874 .parent_names = gcc_parent_names_0,
875 .num_parents = 4,
876 .ops = &clk_rcg2_shared_ops,
877 },
878 };
879
880 static const struct freq_tbl ftbl_gcc_usb30_prim_master_clk_src[] = {
881 F(33333333, P_GPLL0_OUT_EVEN, 9, 0, 0),
882 F(66666667, P_GPLL0_OUT_EVEN, 4.5, 0, 0),
883 F(133333333, P_GPLL0_OUT_MAIN, 4.5, 0, 0),
884 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
885 F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
886 { }
887 };
888
889 static struct clk_rcg2 gcc_usb30_prim_master_clk_src = {
890 .cmd_rcgr = 0xf018,
891 .mnd_width = 8,
892 .hid_width = 5,
893 .parent_map = gcc_parent_map_0,
894 .freq_tbl = ftbl_gcc_usb30_prim_master_clk_src,
895 .clkr.hw.init = &(struct clk_init_data){
896 .name = "gcc_usb30_prim_master_clk_src",
897 .parent_names = gcc_parent_names_0,
898 .num_parents = 4,
899 .ops = &clk_rcg2_shared_ops,
900 },
901 };
902
903 static const struct freq_tbl ftbl_gcc_usb30_prim_mock_utmi_clk_src[] = {
904 F(19200000, P_BI_TCXO, 1, 0, 0),
905 F(20000000, P_GPLL0_OUT_EVEN, 15, 0, 0),
906 F(40000000, P_GPLL0_OUT_EVEN, 7.5, 0, 0),
907 F(60000000, P_GPLL0_OUT_MAIN, 10, 0, 0),
908 { }
909 };
910
911 static struct clk_rcg2 gcc_usb30_prim_mock_utmi_clk_src = {
912 .cmd_rcgr = 0xf030,
913 .mnd_width = 0,
914 .hid_width = 5,
915 .parent_map = gcc_parent_map_0,
916 .freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src,
917 .clkr.hw.init = &(struct clk_init_data){
918 .name = "gcc_usb30_prim_mock_utmi_clk_src",
919 .parent_names = gcc_parent_names_0,
920 .num_parents = 4,
921 .ops = &clk_rcg2_shared_ops,
922 },
923 };
924
925 static struct clk_rcg2 gcc_usb30_sec_master_clk_src = {
926 .cmd_rcgr = 0x10018,
927 .mnd_width = 8,
928 .hid_width = 5,
929 .parent_map = gcc_parent_map_0,
930 .freq_tbl = ftbl_gcc_usb30_prim_master_clk_src,
931 .clkr.hw.init = &(struct clk_init_data){
932 .name = "gcc_usb30_sec_master_clk_src",
933 .parent_names = gcc_parent_names_0,
934 .num_parents = 4,
935 .ops = &clk_rcg2_ops,
936 },
937 };
938
939 static struct clk_rcg2 gcc_usb30_sec_mock_utmi_clk_src = {
940 .cmd_rcgr = 0x10030,
941 .mnd_width = 0,
942 .hid_width = 5,
943 .parent_map = gcc_parent_map_0,
944 .freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src,
945 .clkr.hw.init = &(struct clk_init_data){
946 .name = "gcc_usb30_sec_mock_utmi_clk_src",
947 .parent_names = gcc_parent_names_0,
948 .num_parents = 4,
949 .ops = &clk_rcg2_ops,
950 },
951 };
952
953 static struct clk_rcg2 gcc_usb3_prim_phy_aux_clk_src = {
954 .cmd_rcgr = 0xf05c,
955 .mnd_width = 0,
956 .hid_width = 5,
957 .parent_map = gcc_parent_map_2,
958 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
959 .clkr.hw.init = &(struct clk_init_data){
960 .name = "gcc_usb3_prim_phy_aux_clk_src",
961 .parent_names = gcc_parent_names_2,
962 .num_parents = 3,
963 .ops = &clk_rcg2_ops,
964 },
965 };
966
967 static struct clk_rcg2 gcc_usb3_sec_phy_aux_clk_src = {
968 .cmd_rcgr = 0x1005c,
969 .mnd_width = 0,
970 .hid_width = 5,
971 .parent_map = gcc_parent_map_2,
972 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
973 .clkr.hw.init = &(struct clk_init_data){
974 .name = "gcc_usb3_sec_phy_aux_clk_src",
975 .parent_names = gcc_parent_names_2,
976 .num_parents = 3,
977 .ops = &clk_rcg2_shared_ops,
978 },
979 };
980
981 static struct clk_rcg2 gcc_vs_ctrl_clk_src = {
982 .cmd_rcgr = 0x7a030,
983 .mnd_width = 0,
984 .hid_width = 5,
985 .parent_map = gcc_parent_map_3,
986 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
987 .clkr.hw.init = &(struct clk_init_data){
988 .name = "gcc_vs_ctrl_clk_src",
989 .parent_names = gcc_parent_names_3,
990 .num_parents = 3,
991 .ops = &clk_rcg2_ops,
992 },
993 };
994
995 static const struct freq_tbl ftbl_gcc_vsensor_clk_src[] = {
996 F(19200000, P_BI_TCXO, 1, 0, 0),
997 F(300000000, P_GPLL0_OUT_MAIN, 2, 0, 0),
998 F(600000000, P_GPLL0_OUT_MAIN, 1, 0, 0),
999 { }
1000 };
1001
1002 static struct clk_rcg2 gcc_vsensor_clk_src = {
1003 .cmd_rcgr = 0x7a018,
1004 .mnd_width = 0,
1005 .hid_width = 5,
1006 .parent_map = gcc_parent_map_3,
1007 .freq_tbl = ftbl_gcc_vsensor_clk_src,
1008 .clkr.hw.init = &(struct clk_init_data){
1009 .name = "gcc_vsensor_clk_src",
1010 .parent_names = gcc_parent_names_8,
1011 .num_parents = 3,
1012 .ops = &clk_rcg2_ops,
1013 },
1014 };
1015
1016 static struct clk_branch gcc_aggre_noc_pcie_tbu_clk = {
1017 .halt_reg = 0x90014,
1018 .halt_check = BRANCH_HALT,
1019 .clkr = {
1020 .enable_reg = 0x90014,
1021 .enable_mask = BIT(0),
1022 .hw.init = &(struct clk_init_data){
1023 .name = "gcc_aggre_noc_pcie_tbu_clk",
1024 .ops = &clk_branch2_ops,
1025 },
1026 },
1027 };
1028
1029 static struct clk_branch gcc_aggre_ufs_card_axi_clk = {
1030 .halt_reg = 0x82028,
1031 .halt_check = BRANCH_HALT,
1032 .hwcg_reg = 0x82028,
1033 .hwcg_bit = 1,
1034 .clkr = {
1035 .enable_reg = 0x82028,
1036 .enable_mask = BIT(0),
1037 .hw.init = &(struct clk_init_data){
1038 .name = "gcc_aggre_ufs_card_axi_clk",
1039 .parent_names = (const char *[]){
1040 "gcc_ufs_card_axi_clk_src",
1041 },
1042 .num_parents = 1,
1043 .flags = CLK_SET_RATE_PARENT,
1044 .ops = &clk_branch2_ops,
1045 },
1046 },
1047 };
1048
1049 static struct clk_branch gcc_aggre_ufs_phy_axi_clk = {
1050 .halt_reg = 0x82024,
1051 .halt_check = BRANCH_HALT,
1052 .hwcg_reg = 0x82024,
1053 .hwcg_bit = 1,
1054 .clkr = {
1055 .enable_reg = 0x82024,
1056 .enable_mask = BIT(0),
1057 .hw.init = &(struct clk_init_data){
1058 .name = "gcc_aggre_ufs_phy_axi_clk",
1059 .parent_names = (const char *[]){
1060 "gcc_ufs_phy_axi_clk_src",
1061 },
1062 .num_parents = 1,
1063 .flags = CLK_SET_RATE_PARENT,
1064 .ops = &clk_branch2_ops,
1065 },
1066 },
1067 };
1068
1069 static struct clk_branch gcc_aggre_usb3_prim_axi_clk = {
1070 .halt_reg = 0x8201c,
1071 .halt_check = BRANCH_HALT,
1072 .clkr = {
1073 .enable_reg = 0x8201c,
1074 .enable_mask = BIT(0),
1075 .hw.init = &(struct clk_init_data){
1076 .name = "gcc_aggre_usb3_prim_axi_clk",
1077 .parent_names = (const char *[]){
1078 "gcc_usb30_prim_master_clk_src",
1079 },
1080 .num_parents = 1,
1081 .flags = CLK_SET_RATE_PARENT,
1082 .ops = &clk_branch2_ops,
1083 },
1084 },
1085 };
1086
1087 static struct clk_branch gcc_aggre_usb3_sec_axi_clk = {
1088 .halt_reg = 0x82020,
1089 .halt_check = BRANCH_HALT,
1090 .clkr = {
1091 .enable_reg = 0x82020,
1092 .enable_mask = BIT(0),
1093 .hw.init = &(struct clk_init_data){
1094 .name = "gcc_aggre_usb3_sec_axi_clk",
1095 .parent_names = (const char *[]){
1096 "gcc_usb30_sec_master_clk_src",
1097 },
1098 .num_parents = 1,
1099 .flags = CLK_SET_RATE_PARENT,
1100 .ops = &clk_branch2_ops,
1101 },
1102 },
1103 };
1104
1105 static struct clk_branch gcc_apc_vs_clk = {
1106 .halt_reg = 0x7a050,
1107 .halt_check = BRANCH_HALT,
1108 .clkr = {
1109 .enable_reg = 0x7a050,
1110 .enable_mask = BIT(0),
1111 .hw.init = &(struct clk_init_data){
1112 .name = "gcc_apc_vs_clk",
1113 .parent_names = (const char *[]){
1114 "gcc_vsensor_clk_src",
1115 },
1116 .num_parents = 1,
1117 .flags = CLK_SET_RATE_PARENT,
1118 .ops = &clk_branch2_ops,
1119 },
1120 },
1121 };
1122
1123 static struct clk_branch gcc_boot_rom_ahb_clk = {
1124 .halt_reg = 0x38004,
1125 .halt_check = BRANCH_HALT_VOTED,
1126 .hwcg_reg = 0x38004,
1127 .hwcg_bit = 1,
1128 .clkr = {
1129 .enable_reg = 0x52004,
1130 .enable_mask = BIT(10),
1131 .hw.init = &(struct clk_init_data){
1132 .name = "gcc_boot_rom_ahb_clk",
1133 .ops = &clk_branch2_ops,
1134 },
1135 },
1136 };
1137
1138 static struct clk_branch gcc_camera_ahb_clk = {
1139 .halt_reg = 0xb008,
1140 .halt_check = BRANCH_HALT,
1141 .hwcg_reg = 0xb008,
1142 .hwcg_bit = 1,
1143 .clkr = {
1144 .enable_reg = 0xb008,
1145 .enable_mask = BIT(0),
1146 .hw.init = &(struct clk_init_data){
1147 .name = "gcc_camera_ahb_clk",
1148 .flags = CLK_IS_CRITICAL,
1149 .ops = &clk_branch2_ops,
1150 },
1151 },
1152 };
1153
1154 static struct clk_branch gcc_camera_axi_clk = {
1155 .halt_reg = 0xb020,
1156 .halt_check = BRANCH_VOTED,
1157 .clkr = {
1158 .enable_reg = 0xb020,
1159 .enable_mask = BIT(0),
1160 .hw.init = &(struct clk_init_data){
1161 .name = "gcc_camera_axi_clk",
1162 .ops = &clk_branch2_ops,
1163 },
1164 },
1165 };
1166
1167 static struct clk_branch gcc_camera_xo_clk = {
1168 .halt_reg = 0xb02c,
1169 .halt_check = BRANCH_HALT,
1170 .clkr = {
1171 .enable_reg = 0xb02c,
1172 .enable_mask = BIT(0),
1173 .hw.init = &(struct clk_init_data){
1174 .name = "gcc_camera_xo_clk",
1175 .flags = CLK_IS_CRITICAL,
1176 .ops = &clk_branch2_ops,
1177 },
1178 },
1179 };
1180
1181 static struct clk_branch gcc_ce1_ahb_clk = {
1182 .halt_reg = 0x4100c,
1183 .halt_check = BRANCH_HALT_VOTED,
1184 .hwcg_reg = 0x4100c,
1185 .hwcg_bit = 1,
1186 .clkr = {
1187 .enable_reg = 0x52004,
1188 .enable_mask = BIT(3),
1189 .hw.init = &(struct clk_init_data){
1190 .name = "gcc_ce1_ahb_clk",
1191 .ops = &clk_branch2_ops,
1192 },
1193 },
1194 };
1195
1196 static struct clk_branch gcc_ce1_axi_clk = {
1197 .halt_reg = 0x41008,
1198 .halt_check = BRANCH_HALT_VOTED,
1199 .clkr = {
1200 .enable_reg = 0x52004,
1201 .enable_mask = BIT(4),
1202 .hw.init = &(struct clk_init_data){
1203 .name = "gcc_ce1_axi_clk",
1204 .ops = &clk_branch2_ops,
1205 },
1206 },
1207 };
1208
1209 static struct clk_branch gcc_ce1_clk = {
1210 .halt_reg = 0x41004,
1211 .halt_check = BRANCH_HALT_VOTED,
1212 .clkr = {
1213 .enable_reg = 0x52004,
1214 .enable_mask = BIT(5),
1215 .hw.init = &(struct clk_init_data){
1216 .name = "gcc_ce1_clk",
1217 .ops = &clk_branch2_ops,
1218 },
1219 },
1220 };
1221
1222 static struct clk_branch gcc_cfg_noc_usb3_prim_axi_clk = {
1223 .halt_reg = 0x502c,
1224 .halt_check = BRANCH_HALT,
1225 .clkr = {
1226 .enable_reg = 0x502c,
1227 .enable_mask = BIT(0),
1228 .hw.init = &(struct clk_init_data){
1229 .name = "gcc_cfg_noc_usb3_prim_axi_clk",
1230 .parent_names = (const char *[]){
1231 "gcc_usb30_prim_master_clk_src",
1232 },
1233 .num_parents = 1,
1234 .flags = CLK_SET_RATE_PARENT,
1235 .ops = &clk_branch2_ops,
1236 },
1237 },
1238 };
1239
1240 static struct clk_branch gcc_cfg_noc_usb3_sec_axi_clk = {
1241 .halt_reg = 0x5030,
1242 .halt_check = BRANCH_HALT,
1243 .clkr = {
1244 .enable_reg = 0x5030,
1245 .enable_mask = BIT(0),
1246 .hw.init = &(struct clk_init_data){
1247 .name = "gcc_cfg_noc_usb3_sec_axi_clk",
1248 .parent_names = (const char *[]){
1249 "gcc_usb30_sec_master_clk_src",
1250 },
1251 .num_parents = 1,
1252 .flags = CLK_SET_RATE_PARENT,
1253 .ops = &clk_branch2_ops,
1254 },
1255 },
1256 };
1257
1258 static struct clk_branch gcc_cpuss_ahb_clk = {
1259 .halt_reg = 0x48000,
1260 .halt_check = BRANCH_HALT_VOTED,
1261 .clkr = {
1262 .enable_reg = 0x52004,
1263 .enable_mask = BIT(21),
1264 .hw.init = &(struct clk_init_data){
1265 .name = "gcc_cpuss_ahb_clk",
1266 .parent_names = (const char *[]){
1267 "gcc_cpuss_ahb_clk_src",
1268 },
1269 .num_parents = 1,
1270 .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1271 .ops = &clk_branch2_ops,
1272 },
1273 },
1274 };
1275
1276 static struct clk_branch gcc_cpuss_rbcpr_clk = {
1277 .halt_reg = 0x48008,
1278 .halt_check = BRANCH_HALT,
1279 .clkr = {
1280 .enable_reg = 0x48008,
1281 .enable_mask = BIT(0),
1282 .hw.init = &(struct clk_init_data){
1283 .name = "gcc_cpuss_rbcpr_clk",
1284 .parent_names = (const char *[]){
1285 "gcc_cpuss_rbcpr_clk_src",
1286 },
1287 .num_parents = 1,
1288 .flags = CLK_SET_RATE_PARENT,
1289 .ops = &clk_branch2_ops,
1290 },
1291 },
1292 };
1293
1294 static struct clk_branch gcc_ddrss_gpu_axi_clk = {
1295 .halt_reg = 0x44038,
1296 .halt_check = BRANCH_VOTED,
1297 .clkr = {
1298 .enable_reg = 0x44038,
1299 .enable_mask = BIT(0),
1300 .hw.init = &(struct clk_init_data){
1301 .name = "gcc_ddrss_gpu_axi_clk",
1302 .ops = &clk_branch2_ops,
1303 },
1304 },
1305 };
1306
1307 static struct clk_branch gcc_disp_ahb_clk = {
1308 .halt_reg = 0xb00c,
1309 .halt_check = BRANCH_HALT,
1310 .hwcg_reg = 0xb00c,
1311 .hwcg_bit = 1,
1312 .clkr = {
1313 .enable_reg = 0xb00c,
1314 .enable_mask = BIT(0),
1315 .hw.init = &(struct clk_init_data){
1316 .name = "gcc_disp_ahb_clk",
1317 .flags = CLK_IS_CRITICAL,
1318 .ops = &clk_branch2_ops,
1319 },
1320 },
1321 };
1322
1323 static struct clk_branch gcc_disp_axi_clk = {
1324 .halt_reg = 0xb024,
1325 .halt_check = BRANCH_VOTED,
1326 .clkr = {
1327 .enable_reg = 0xb024,
1328 .enable_mask = BIT(0),
1329 .hw.init = &(struct clk_init_data){
1330 .name = "gcc_disp_axi_clk",
1331 .ops = &clk_branch2_ops,
1332 },
1333 },
1334 };
1335
1336 static struct clk_branch gcc_disp_gpll0_clk_src = {
1337 .halt_check = BRANCH_HALT_DELAY,
1338 .clkr = {
1339 .enable_reg = 0x52004,
1340 .enable_mask = BIT(18),
1341 .hw.init = &(struct clk_init_data){
1342 .name = "gcc_disp_gpll0_clk_src",
1343 .parent_names = (const char *[]){
1344 "gpll0",
1345 },
1346 .num_parents = 1,
1347 .ops = &clk_branch2_ops,
1348 },
1349 },
1350 };
1351
1352 static struct clk_branch gcc_disp_gpll0_div_clk_src = {
1353 .halt_check = BRANCH_HALT_DELAY,
1354 .clkr = {
1355 .enable_reg = 0x52004,
1356 .enable_mask = BIT(19),
1357 .hw.init = &(struct clk_init_data){
1358 .name = "gcc_disp_gpll0_div_clk_src",
1359 .parent_names = (const char *[]){
1360 "gpll0_out_even",
1361 },
1362 .num_parents = 1,
1363 .ops = &clk_branch2_ops,
1364 },
1365 },
1366 };
1367
1368 static struct clk_branch gcc_disp_xo_clk = {
1369 .halt_reg = 0xb030,
1370 .halt_check = BRANCH_HALT,
1371 .clkr = {
1372 .enable_reg = 0xb030,
1373 .enable_mask = BIT(0),
1374 .hw.init = &(struct clk_init_data){
1375 .name = "gcc_disp_xo_clk",
1376 .flags = CLK_IS_CRITICAL,
1377 .ops = &clk_branch2_ops,
1378 },
1379 },
1380 };
1381
1382 static struct clk_branch gcc_gp1_clk = {
1383 .halt_reg = 0x64000,
1384 .halt_check = BRANCH_HALT,
1385 .clkr = {
1386 .enable_reg = 0x64000,
1387 .enable_mask = BIT(0),
1388 .hw.init = &(struct clk_init_data){
1389 .name = "gcc_gp1_clk",
1390 .parent_names = (const char *[]){
1391 "gcc_gp1_clk_src",
1392 },
1393 .num_parents = 1,
1394 .flags = CLK_SET_RATE_PARENT,
1395 .ops = &clk_branch2_ops,
1396 },
1397 },
1398 };
1399
1400 static struct clk_branch gcc_gp2_clk = {
1401 .halt_reg = 0x65000,
1402 .halt_check = BRANCH_HALT,
1403 .clkr = {
1404 .enable_reg = 0x65000,
1405 .enable_mask = BIT(0),
1406 .hw.init = &(struct clk_init_data){
1407 .name = "gcc_gp2_clk",
1408 .parent_names = (const char *[]){
1409 "gcc_gp2_clk_src",
1410 },
1411 .num_parents = 1,
1412 .flags = CLK_SET_RATE_PARENT,
1413 .ops = &clk_branch2_ops,
1414 },
1415 },
1416 };
1417
1418 static struct clk_branch gcc_gp3_clk = {
1419 .halt_reg = 0x66000,
1420 .halt_check = BRANCH_HALT,
1421 .clkr = {
1422 .enable_reg = 0x66000,
1423 .enable_mask = BIT(0),
1424 .hw.init = &(struct clk_init_data){
1425 .name = "gcc_gp3_clk",
1426 .parent_names = (const char *[]){
1427 "gcc_gp3_clk_src",
1428 },
1429 .num_parents = 1,
1430 .flags = CLK_SET_RATE_PARENT,
1431 .ops = &clk_branch2_ops,
1432 },
1433 },
1434 };
1435
1436 static struct clk_branch gcc_gpu_cfg_ahb_clk = {
1437 .halt_reg = 0x71004,
1438 .halt_check = BRANCH_HALT,
1439 .hwcg_reg = 0x71004,
1440 .hwcg_bit = 1,
1441 .clkr = {
1442 .enable_reg = 0x71004,
1443 .enable_mask = BIT(0),
1444 .hw.init = &(struct clk_init_data){
1445 .name = "gcc_gpu_cfg_ahb_clk",
1446 .flags = CLK_IS_CRITICAL,
1447 .ops = &clk_branch2_ops,
1448 },
1449 },
1450 };
1451
1452 static struct clk_branch gcc_gpu_gpll0_clk_src = {
1453 .halt_check = BRANCH_HALT_DELAY,
1454 .clkr = {
1455 .enable_reg = 0x52004,
1456 .enable_mask = BIT(15),
1457 .hw.init = &(struct clk_init_data){
1458 .name = "gcc_gpu_gpll0_clk_src",
1459 .parent_names = (const char *[]){
1460 "gpll0",
1461 },
1462 .num_parents = 1,
1463 .ops = &clk_branch2_ops,
1464 },
1465 },
1466 };
1467
1468 static struct clk_branch gcc_gpu_gpll0_div_clk_src = {
1469 .halt_check = BRANCH_HALT_DELAY,
1470 .clkr = {
1471 .enable_reg = 0x52004,
1472 .enable_mask = BIT(16),
1473 .hw.init = &(struct clk_init_data){
1474 .name = "gcc_gpu_gpll0_div_clk_src",
1475 .parent_names = (const char *[]){
1476 "gpll0_out_even",
1477 },
1478 .num_parents = 1,
1479 .ops = &clk_branch2_ops,
1480 },
1481 },
1482 };
1483
1484 static struct clk_branch gcc_gpu_iref_clk = {
1485 .halt_reg = 0x8c010,
1486 .halt_check = BRANCH_HALT,
1487 .clkr = {
1488 .enable_reg = 0x8c010,
1489 .enable_mask = BIT(0),
1490 .hw.init = &(struct clk_init_data){
1491 .name = "gcc_gpu_iref_clk",
1492 .ops = &clk_branch2_ops,
1493 },
1494 },
1495 };
1496
1497 static struct clk_branch gcc_gpu_memnoc_gfx_clk = {
1498 .halt_reg = 0x7100c,
1499 .halt_check = BRANCH_VOTED,
1500 .clkr = {
1501 .enable_reg = 0x7100c,
1502 .enable_mask = BIT(0),
1503 .hw.init = &(struct clk_init_data){
1504 .name = "gcc_gpu_memnoc_gfx_clk",
1505 .ops = &clk_branch2_ops,
1506 },
1507 },
1508 };
1509
1510 static struct clk_branch gcc_gpu_snoc_dvm_gfx_clk = {
1511 .halt_reg = 0x71018,
1512 .halt_check = BRANCH_HALT,
1513 .clkr = {
1514 .enable_reg = 0x71018,
1515 .enable_mask = BIT(0),
1516 .hw.init = &(struct clk_init_data){
1517 .name = "gcc_gpu_snoc_dvm_gfx_clk",
1518 .ops = &clk_branch2_ops,
1519 },
1520 },
1521 };
1522
1523 static struct clk_branch gcc_gpu_vs_clk = {
1524 .halt_reg = 0x7a04c,
1525 .halt_check = BRANCH_HALT,
1526 .clkr = {
1527 .enable_reg = 0x7a04c,
1528 .enable_mask = BIT(0),
1529 .hw.init = &(struct clk_init_data){
1530 .name = "gcc_gpu_vs_clk",
1531 .parent_names = (const char *[]){
1532 "gcc_vsensor_clk_src",
1533 },
1534 .num_parents = 1,
1535 .flags = CLK_SET_RATE_PARENT,
1536 .ops = &clk_branch2_ops,
1537 },
1538 },
1539 };
1540
1541 static struct clk_branch gcc_mss_axis2_clk = {
1542 .halt_reg = 0x8a008,
1543 .halt_check = BRANCH_HALT,
1544 .clkr = {
1545 .enable_reg = 0x8a008,
1546 .enable_mask = BIT(0),
1547 .hw.init = &(struct clk_init_data){
1548 .name = "gcc_mss_axis2_clk",
1549 .ops = &clk_branch2_ops,
1550 },
1551 },
1552 };
1553
1554 static struct clk_branch gcc_mss_cfg_ahb_clk = {
1555 .halt_reg = 0x8a000,
1556 .halt_check = BRANCH_HALT,
1557 .hwcg_reg = 0x8a000,
1558 .hwcg_bit = 1,
1559 .clkr = {
1560 .enable_reg = 0x8a000,
1561 .enable_mask = BIT(0),
1562 .hw.init = &(struct clk_init_data){
1563 .name = "gcc_mss_cfg_ahb_clk",
1564 .ops = &clk_branch2_ops,
1565 },
1566 },
1567 };
1568
1569 static struct clk_branch gcc_mss_gpll0_div_clk_src = {
1570 .halt_check = BRANCH_HALT_DELAY,
1571 .clkr = {
1572 .enable_reg = 0x52004,
1573 .enable_mask = BIT(17),
1574 .hw.init = &(struct clk_init_data){
1575 .name = "gcc_mss_gpll0_div_clk_src",
1576 .ops = &clk_branch2_ops,
1577 },
1578 },
1579 };
1580
1581 static struct clk_branch gcc_mss_mfab_axis_clk = {
1582 .halt_reg = 0x8a004,
1583 .halt_check = BRANCH_VOTED,
1584 .hwcg_reg = 0x8a004,
1585 .hwcg_bit = 1,
1586 .clkr = {
1587 .enable_reg = 0x8a004,
1588 .enable_mask = BIT(0),
1589 .hw.init = &(struct clk_init_data){
1590 .name = "gcc_mss_mfab_axis_clk",
1591 .ops = &clk_branch2_ops,
1592 },
1593 },
1594 };
1595
1596 static struct clk_branch gcc_mss_q6_memnoc_axi_clk = {
1597 .halt_reg = 0x8a154,
1598 .halt_check = BRANCH_VOTED,
1599 .clkr = {
1600 .enable_reg = 0x8a154,
1601 .enable_mask = BIT(0),
1602 .hw.init = &(struct clk_init_data){
1603 .name = "gcc_mss_q6_memnoc_axi_clk",
1604 .ops = &clk_branch2_ops,
1605 },
1606 },
1607 };
1608
1609 static struct clk_branch gcc_mss_snoc_axi_clk = {
1610 .halt_reg = 0x8a150,
1611 .halt_check = BRANCH_HALT,
1612 .clkr = {
1613 .enable_reg = 0x8a150,
1614 .enable_mask = BIT(0),
1615 .hw.init = &(struct clk_init_data){
1616 .name = "gcc_mss_snoc_axi_clk",
1617 .ops = &clk_branch2_ops,
1618 },
1619 },
1620 };
1621
1622 static struct clk_branch gcc_mss_vs_clk = {
1623 .halt_reg = 0x7a048,
1624 .halt_check = BRANCH_HALT,
1625 .clkr = {
1626 .enable_reg = 0x7a048,
1627 .enable_mask = BIT(0),
1628 .hw.init = &(struct clk_init_data){
1629 .name = "gcc_mss_vs_clk",
1630 .parent_names = (const char *[]){
1631 "gcc_vsensor_clk_src",
1632 },
1633 .num_parents = 1,
1634 .flags = CLK_SET_RATE_PARENT,
1635 .ops = &clk_branch2_ops,
1636 },
1637 },
1638 };
1639
1640 static struct clk_branch gcc_pcie_0_aux_clk = {
1641 .halt_reg = 0x6b01c,
1642 .halt_check = BRANCH_HALT_VOTED,
1643 .clkr = {
1644 .enable_reg = 0x5200c,
1645 .enable_mask = BIT(3),
1646 .hw.init = &(struct clk_init_data){
1647 .name = "gcc_pcie_0_aux_clk",
1648 .parent_names = (const char *[]){
1649 "gcc_pcie_0_aux_clk_src",
1650 },
1651 .num_parents = 1,
1652 .flags = CLK_SET_RATE_PARENT,
1653 .ops = &clk_branch2_ops,
1654 },
1655 },
1656 };
1657
1658 static struct clk_branch gcc_pcie_0_cfg_ahb_clk = {
1659 .halt_reg = 0x6b018,
1660 .halt_check = BRANCH_HALT_VOTED,
1661 .hwcg_reg = 0x6b018,
1662 .hwcg_bit = 1,
1663 .clkr = {
1664 .enable_reg = 0x5200c,
1665 .enable_mask = BIT(2),
1666 .hw.init = &(struct clk_init_data){
1667 .name = "gcc_pcie_0_cfg_ahb_clk",
1668 .ops = &clk_branch2_ops,
1669 },
1670 },
1671 };
1672
1673 static struct clk_branch gcc_pcie_0_clkref_clk = {
1674 .halt_reg = 0x8c00c,
1675 .halt_check = BRANCH_HALT,
1676 .clkr = {
1677 .enable_reg = 0x8c00c,
1678 .enable_mask = BIT(0),
1679 .hw.init = &(struct clk_init_data){
1680 .name = "gcc_pcie_0_clkref_clk",
1681 .ops = &clk_branch2_ops,
1682 },
1683 },
1684 };
1685
1686 static struct clk_branch gcc_pcie_0_mstr_axi_clk = {
1687 .halt_reg = 0x6b014,
1688 .halt_check = BRANCH_HALT_VOTED,
1689 .clkr = {
1690 .enable_reg = 0x5200c,
1691 .enable_mask = BIT(1),
1692 .hw.init = &(struct clk_init_data){
1693 .name = "gcc_pcie_0_mstr_axi_clk",
1694 .ops = &clk_branch2_ops,
1695 },
1696 },
1697 };
1698
1699 static struct clk_branch gcc_pcie_0_pipe_clk = {
1700 .halt_check = BRANCH_HALT_SKIP,
1701 .clkr = {
1702 .enable_reg = 0x5200c,
1703 .enable_mask = BIT(4),
1704 .hw.init = &(struct clk_init_data){
1705 .name = "gcc_pcie_0_pipe_clk",
1706 .parent_names = (const char *[]){ "pcie_0_pipe_clk" },
1707 .num_parents = 1,
1708 .flags = CLK_SET_RATE_PARENT,
1709 .ops = &clk_branch2_ops,
1710 },
1711 },
1712 };
1713
1714 static struct clk_branch gcc_pcie_0_slv_axi_clk = {
1715 .halt_reg = 0x6b010,
1716 .halt_check = BRANCH_HALT_VOTED,
1717 .hwcg_reg = 0x6b010,
1718 .hwcg_bit = 1,
1719 .clkr = {
1720 .enable_reg = 0x5200c,
1721 .enable_mask = BIT(0),
1722 .hw.init = &(struct clk_init_data){
1723 .name = "gcc_pcie_0_slv_axi_clk",
1724 .ops = &clk_branch2_ops,
1725 },
1726 },
1727 };
1728
1729 static struct clk_branch gcc_pcie_0_slv_q2a_axi_clk = {
1730 .halt_reg = 0x6b00c,
1731 .halt_check = BRANCH_HALT_VOTED,
1732 .clkr = {
1733 .enable_reg = 0x5200c,
1734 .enable_mask = BIT(5),
1735 .hw.init = &(struct clk_init_data){
1736 .name = "gcc_pcie_0_slv_q2a_axi_clk",
1737 .ops = &clk_branch2_ops,
1738 },
1739 },
1740 };
1741
1742 static struct clk_branch gcc_pcie_1_aux_clk = {
1743 .halt_reg = 0x8d01c,
1744 .halt_check = BRANCH_HALT_VOTED,
1745 .clkr = {
1746 .enable_reg = 0x52004,
1747 .enable_mask = BIT(29),
1748 .hw.init = &(struct clk_init_data){
1749 .name = "gcc_pcie_1_aux_clk",
1750 .parent_names = (const char *[]){
1751 "gcc_pcie_1_aux_clk_src",
1752 },
1753 .num_parents = 1,
1754 .flags = CLK_SET_RATE_PARENT,
1755 .ops = &clk_branch2_ops,
1756 },
1757 },
1758 };
1759
1760 static struct clk_branch gcc_pcie_1_cfg_ahb_clk = {
1761 .halt_reg = 0x8d018,
1762 .halt_check = BRANCH_HALT_VOTED,
1763 .hwcg_reg = 0x8d018,
1764 .hwcg_bit = 1,
1765 .clkr = {
1766 .enable_reg = 0x52004,
1767 .enable_mask = BIT(28),
1768 .hw.init = &(struct clk_init_data){
1769 .name = "gcc_pcie_1_cfg_ahb_clk",
1770 .ops = &clk_branch2_ops,
1771 },
1772 },
1773 };
1774
1775 static struct clk_branch gcc_pcie_1_clkref_clk = {
1776 .halt_reg = 0x8c02c,
1777 .halt_check = BRANCH_HALT,
1778 .clkr = {
1779 .enable_reg = 0x8c02c,
1780 .enable_mask = BIT(0),
1781 .hw.init = &(struct clk_init_data){
1782 .name = "gcc_pcie_1_clkref_clk",
1783 .ops = &clk_branch2_ops,
1784 },
1785 },
1786 };
1787
1788 static struct clk_branch gcc_pcie_1_mstr_axi_clk = {
1789 .halt_reg = 0x8d014,
1790 .halt_check = BRANCH_HALT_VOTED,
1791 .clkr = {
1792 .enable_reg = 0x52004,
1793 .enable_mask = BIT(27),
1794 .hw.init = &(struct clk_init_data){
1795 .name = "gcc_pcie_1_mstr_axi_clk",
1796 .ops = &clk_branch2_ops,
1797 },
1798 },
1799 };
1800
1801 static struct clk_branch gcc_pcie_1_pipe_clk = {
1802 .halt_check = BRANCH_HALT_SKIP,
1803 .clkr = {
1804 .enable_reg = 0x52004,
1805 .enable_mask = BIT(30),
1806 .hw.init = &(struct clk_init_data){
1807 .name = "gcc_pcie_1_pipe_clk",
1808 .parent_names = (const char *[]){ "pcie_1_pipe_clk" },
1809 .num_parents = 1,
1810 .ops = &clk_branch2_ops,
1811 },
1812 },
1813 };
1814
1815 static struct clk_branch gcc_pcie_1_slv_axi_clk = {
1816 .halt_reg = 0x8d010,
1817 .halt_check = BRANCH_HALT_VOTED,
1818 .hwcg_reg = 0x8d010,
1819 .hwcg_bit = 1,
1820 .clkr = {
1821 .enable_reg = 0x52004,
1822 .enable_mask = BIT(26),
1823 .hw.init = &(struct clk_init_data){
1824 .name = "gcc_pcie_1_slv_axi_clk",
1825 .ops = &clk_branch2_ops,
1826 },
1827 },
1828 };
1829
1830 static struct clk_branch gcc_pcie_1_slv_q2a_axi_clk = {
1831 .halt_reg = 0x8d00c,
1832 .halt_check = BRANCH_HALT_VOTED,
1833 .clkr = {
1834 .enable_reg = 0x52004,
1835 .enable_mask = BIT(25),
1836 .hw.init = &(struct clk_init_data){
1837 .name = "gcc_pcie_1_slv_q2a_axi_clk",
1838 .ops = &clk_branch2_ops,
1839 },
1840 },
1841 };
1842
1843 static struct clk_branch gcc_pcie_phy_aux_clk = {
1844 .halt_reg = 0x6f004,
1845 .halt_check = BRANCH_HALT,
1846 .clkr = {
1847 .enable_reg = 0x6f004,
1848 .enable_mask = BIT(0),
1849 .hw.init = &(struct clk_init_data){
1850 .name = "gcc_pcie_phy_aux_clk",
1851 .parent_names = (const char *[]){
1852 "gcc_pcie_0_aux_clk_src",
1853 },
1854 .num_parents = 1,
1855 .flags = CLK_SET_RATE_PARENT,
1856 .ops = &clk_branch2_ops,
1857 },
1858 },
1859 };
1860
1861 static struct clk_branch gcc_pcie_phy_refgen_clk = {
1862 .halt_reg = 0x6f02c,
1863 .halt_check = BRANCH_HALT,
1864 .clkr = {
1865 .enable_reg = 0x6f02c,
1866 .enable_mask = BIT(0),
1867 .hw.init = &(struct clk_init_data){
1868 .name = "gcc_pcie_phy_refgen_clk",
1869 .parent_names = (const char *[]){
1870 "gcc_pcie_phy_refgen_clk_src",
1871 },
1872 .num_parents = 1,
1873 .flags = CLK_SET_RATE_PARENT,
1874 .ops = &clk_branch2_ops,
1875 },
1876 },
1877 };
1878
1879 static struct clk_branch gcc_pdm2_clk = {
1880 .halt_reg = 0x3300c,
1881 .halt_check = BRANCH_HALT,
1882 .clkr = {
1883 .enable_reg = 0x3300c,
1884 .enable_mask = BIT(0),
1885 .hw.init = &(struct clk_init_data){
1886 .name = "gcc_pdm2_clk",
1887 .parent_names = (const char *[]){
1888 "gcc_pdm2_clk_src",
1889 },
1890 .num_parents = 1,
1891 .flags = CLK_SET_RATE_PARENT,
1892 .ops = &clk_branch2_ops,
1893 },
1894 },
1895 };
1896
1897 static struct clk_branch gcc_pdm_ahb_clk = {
1898 .halt_reg = 0x33004,
1899 .halt_check = BRANCH_HALT,
1900 .hwcg_reg = 0x33004,
1901 .hwcg_bit = 1,
1902 .clkr = {
1903 .enable_reg = 0x33004,
1904 .enable_mask = BIT(0),
1905 .hw.init = &(struct clk_init_data){
1906 .name = "gcc_pdm_ahb_clk",
1907 .ops = &clk_branch2_ops,
1908 },
1909 },
1910 };
1911
1912 static struct clk_branch gcc_pdm_xo4_clk = {
1913 .halt_reg = 0x33008,
1914 .halt_check = BRANCH_HALT,
1915 .clkr = {
1916 .enable_reg = 0x33008,
1917 .enable_mask = BIT(0),
1918 .hw.init = &(struct clk_init_data){
1919 .name = "gcc_pdm_xo4_clk",
1920 .ops = &clk_branch2_ops,
1921 },
1922 },
1923 };
1924
1925 static struct clk_branch gcc_prng_ahb_clk = {
1926 .halt_reg = 0x34004,
1927 .halt_check = BRANCH_HALT_VOTED,
1928 .hwcg_reg = 0x34004,
1929 .hwcg_bit = 1,
1930 .clkr = {
1931 .enable_reg = 0x52004,
1932 .enable_mask = BIT(13),
1933 .hw.init = &(struct clk_init_data){
1934 .name = "gcc_prng_ahb_clk",
1935 .ops = &clk_branch2_ops,
1936 },
1937 },
1938 };
1939
1940 static struct clk_branch gcc_qmip_camera_ahb_clk = {
1941 .halt_reg = 0xb014,
1942 .halt_check = BRANCH_HALT,
1943 .hwcg_reg = 0xb014,
1944 .hwcg_bit = 1,
1945 .clkr = {
1946 .enable_reg = 0xb014,
1947 .enable_mask = BIT(0),
1948 .hw.init = &(struct clk_init_data){
1949 .name = "gcc_qmip_camera_ahb_clk",
1950 .ops = &clk_branch2_ops,
1951 },
1952 },
1953 };
1954
1955 static struct clk_branch gcc_qmip_disp_ahb_clk = {
1956 .halt_reg = 0xb018,
1957 .halt_check = BRANCH_HALT,
1958 .hwcg_reg = 0xb018,
1959 .hwcg_bit = 1,
1960 .clkr = {
1961 .enable_reg = 0xb018,
1962 .enable_mask = BIT(0),
1963 .hw.init = &(struct clk_init_data){
1964 .name = "gcc_qmip_disp_ahb_clk",
1965 .ops = &clk_branch2_ops,
1966 },
1967 },
1968 };
1969
1970 static struct clk_branch gcc_qmip_video_ahb_clk = {
1971 .halt_reg = 0xb010,
1972 .halt_check = BRANCH_HALT,
1973 .hwcg_reg = 0xb010,
1974 .hwcg_bit = 1,
1975 .clkr = {
1976 .enable_reg = 0xb010,
1977 .enable_mask = BIT(0),
1978 .hw.init = &(struct clk_init_data){
1979 .name = "gcc_qmip_video_ahb_clk",
1980 .ops = &clk_branch2_ops,
1981 },
1982 },
1983 };
1984
1985 static struct clk_branch gcc_qspi_cnoc_periph_ahb_clk = {
1986 .halt_reg = 0x4b000,
1987 .halt_check = BRANCH_HALT,
1988 .clkr = {
1989 .enable_reg = 0x4b000,
1990 .enable_mask = BIT(0),
1991 .hw.init = &(struct clk_init_data){
1992 .name = "gcc_qspi_cnoc_periph_ahb_clk",
1993 .ops = &clk_branch2_ops,
1994 },
1995 },
1996 };
1997
1998 static struct clk_branch gcc_qspi_core_clk = {
1999 .halt_reg = 0x4b004,
2000 .halt_check = BRANCH_HALT,
2001 .clkr = {
2002 .enable_reg = 0x4b004,
2003 .enable_mask = BIT(0),
2004 .hw.init = &(struct clk_init_data){
2005 .name = "gcc_qspi_core_clk",
2006 .parent_names = (const char *[]){
2007 "gcc_qspi_core_clk_src",
2008 },
2009 .num_parents = 1,
2010 .flags = CLK_SET_RATE_PARENT,
2011 .ops = &clk_branch2_ops,
2012 },
2013 },
2014 };
2015
2016 static struct clk_branch gcc_qupv3_wrap0_s0_clk = {
2017 .halt_reg = 0x17030,
2018 .halt_check = BRANCH_HALT_VOTED,
2019 .clkr = {
2020 .enable_reg = 0x5200c,
2021 .enable_mask = BIT(10),
2022 .hw.init = &(struct clk_init_data){
2023 .name = "gcc_qupv3_wrap0_s0_clk",
2024 .parent_names = (const char *[]){
2025 "gcc_qupv3_wrap0_s0_clk_src",
2026 },
2027 .num_parents = 1,
2028 .flags = CLK_SET_RATE_PARENT,
2029 .ops = &clk_branch2_ops,
2030 },
2031 },
2032 };
2033
2034 static struct clk_branch gcc_qupv3_wrap0_s1_clk = {
2035 .halt_reg = 0x17160,
2036 .halt_check = BRANCH_HALT_VOTED,
2037 .clkr = {
2038 .enable_reg = 0x5200c,
2039 .enable_mask = BIT(11),
2040 .hw.init = &(struct clk_init_data){
2041 .name = "gcc_qupv3_wrap0_s1_clk",
2042 .parent_names = (const char *[]){
2043 "gcc_qupv3_wrap0_s1_clk_src",
2044 },
2045 .num_parents = 1,
2046 .flags = CLK_SET_RATE_PARENT,
2047 .ops = &clk_branch2_ops,
2048 },
2049 },
2050 };
2051
2052 static struct clk_branch gcc_qupv3_wrap0_s2_clk = {
2053 .halt_reg = 0x17290,
2054 .halt_check = BRANCH_HALT_VOTED,
2055 .clkr = {
2056 .enable_reg = 0x5200c,
2057 .enable_mask = BIT(12),
2058 .hw.init = &(struct clk_init_data){
2059 .name = "gcc_qupv3_wrap0_s2_clk",
2060 .parent_names = (const char *[]){
2061 "gcc_qupv3_wrap0_s2_clk_src",
2062 },
2063 .num_parents = 1,
2064 .flags = CLK_SET_RATE_PARENT,
2065 .ops = &clk_branch2_ops,
2066 },
2067 },
2068 };
2069
2070 static struct clk_branch gcc_qupv3_wrap0_s3_clk = {
2071 .halt_reg = 0x173c0,
2072 .halt_check = BRANCH_HALT_VOTED,
2073 .clkr = {
2074 .enable_reg = 0x5200c,
2075 .enable_mask = BIT(13),
2076 .hw.init = &(struct clk_init_data){
2077 .name = "gcc_qupv3_wrap0_s3_clk",
2078 .parent_names = (const char *[]){
2079 "gcc_qupv3_wrap0_s3_clk_src",
2080 },
2081 .num_parents = 1,
2082 .flags = CLK_SET_RATE_PARENT,
2083 .ops = &clk_branch2_ops,
2084 },
2085 },
2086 };
2087
2088 static struct clk_branch gcc_qupv3_wrap0_s4_clk = {
2089 .halt_reg = 0x174f0,
2090 .halt_check = BRANCH_HALT_VOTED,
2091 .clkr = {
2092 .enable_reg = 0x5200c,
2093 .enable_mask = BIT(14),
2094 .hw.init = &(struct clk_init_data){
2095 .name = "gcc_qupv3_wrap0_s4_clk",
2096 .parent_names = (const char *[]){
2097 "gcc_qupv3_wrap0_s4_clk_src",
2098 },
2099 .num_parents = 1,
2100 .flags = CLK_SET_RATE_PARENT,
2101 .ops = &clk_branch2_ops,
2102 },
2103 },
2104 };
2105
2106 static struct clk_branch gcc_qupv3_wrap0_s5_clk = {
2107 .halt_reg = 0x17620,
2108 .halt_check = BRANCH_HALT_VOTED,
2109 .clkr = {
2110 .enable_reg = 0x5200c,
2111 .enable_mask = BIT(15),
2112 .hw.init = &(struct clk_init_data){
2113 .name = "gcc_qupv3_wrap0_s5_clk",
2114 .parent_names = (const char *[]){
2115 "gcc_qupv3_wrap0_s5_clk_src",
2116 },
2117 .num_parents = 1,
2118 .flags = CLK_SET_RATE_PARENT,
2119 .ops = &clk_branch2_ops,
2120 },
2121 },
2122 };
2123
2124 static struct clk_branch gcc_qupv3_wrap0_s6_clk = {
2125 .halt_reg = 0x17750,
2126 .halt_check = BRANCH_HALT_VOTED,
2127 .clkr = {
2128 .enable_reg = 0x5200c,
2129 .enable_mask = BIT(16),
2130 .hw.init = &(struct clk_init_data){
2131 .name = "gcc_qupv3_wrap0_s6_clk",
2132 .parent_names = (const char *[]){
2133 "gcc_qupv3_wrap0_s6_clk_src",
2134 },
2135 .num_parents = 1,
2136 .flags = CLK_SET_RATE_PARENT,
2137 .ops = &clk_branch2_ops,
2138 },
2139 },
2140 };
2141
2142 static struct clk_branch gcc_qupv3_wrap0_s7_clk = {
2143 .halt_reg = 0x17880,
2144 .halt_check = BRANCH_HALT_VOTED,
2145 .clkr = {
2146 .enable_reg = 0x5200c,
2147 .enable_mask = BIT(17),
2148 .hw.init = &(struct clk_init_data){
2149 .name = "gcc_qupv3_wrap0_s7_clk",
2150 .parent_names = (const char *[]){
2151 "gcc_qupv3_wrap0_s7_clk_src",
2152 },
2153 .num_parents = 1,
2154 .flags = CLK_SET_RATE_PARENT,
2155 .ops = &clk_branch2_ops,
2156 },
2157 },
2158 };
2159
2160 static struct clk_branch gcc_qupv3_wrap1_s0_clk = {
2161 .halt_reg = 0x18014,
2162 .halt_check = BRANCH_HALT_VOTED,
2163 .clkr = {
2164 .enable_reg = 0x5200c,
2165 .enable_mask = BIT(22),
2166 .hw.init = &(struct clk_init_data){
2167 .name = "gcc_qupv3_wrap1_s0_clk",
2168 .parent_names = (const char *[]){
2169 "gcc_qupv3_wrap1_s0_clk_src",
2170 },
2171 .num_parents = 1,
2172 .flags = CLK_SET_RATE_PARENT,
2173 .ops = &clk_branch2_ops,
2174 },
2175 },
2176 };
2177
2178 static struct clk_branch gcc_qupv3_wrap1_s1_clk = {
2179 .halt_reg = 0x18144,
2180 .halt_check = BRANCH_HALT_VOTED,
2181 .clkr = {
2182 .enable_reg = 0x5200c,
2183 .enable_mask = BIT(23),
2184 .hw.init = &(struct clk_init_data){
2185 .name = "gcc_qupv3_wrap1_s1_clk",
2186 .parent_names = (const char *[]){
2187 "gcc_qupv3_wrap1_s1_clk_src",
2188 },
2189 .num_parents = 1,
2190 .flags = CLK_SET_RATE_PARENT,
2191 .ops = &clk_branch2_ops,
2192 },
2193 },
2194 };
2195
2196 static struct clk_branch gcc_qupv3_wrap1_s2_clk = {
2197 .halt_reg = 0x18274,
2198 .halt_check = BRANCH_HALT_VOTED,
2199 .clkr = {
2200 .enable_reg = 0x5200c,
2201 .enable_mask = BIT(24),
2202 .hw.init = &(struct clk_init_data){
2203 .name = "gcc_qupv3_wrap1_s2_clk",
2204 .parent_names = (const char *[]){
2205 "gcc_qupv3_wrap1_s2_clk_src",
2206 },
2207 .num_parents = 1,
2208 .flags = CLK_SET_RATE_PARENT,
2209 .ops = &clk_branch2_ops,
2210 },
2211 },
2212 };
2213
2214 static struct clk_branch gcc_qupv3_wrap1_s3_clk = {
2215 .halt_reg = 0x183a4,
2216 .halt_check = BRANCH_HALT_VOTED,
2217 .clkr = {
2218 .enable_reg = 0x5200c,
2219 .enable_mask = BIT(25),
2220 .hw.init = &(struct clk_init_data){
2221 .name = "gcc_qupv3_wrap1_s3_clk",
2222 .parent_names = (const char *[]){
2223 "gcc_qupv3_wrap1_s3_clk_src",
2224 },
2225 .num_parents = 1,
2226 .flags = CLK_SET_RATE_PARENT,
2227 .ops = &clk_branch2_ops,
2228 },
2229 },
2230 };
2231
2232 static struct clk_branch gcc_qupv3_wrap1_s4_clk = {
2233 .halt_reg = 0x184d4,
2234 .halt_check = BRANCH_HALT_VOTED,
2235 .clkr = {
2236 .enable_reg = 0x5200c,
2237 .enable_mask = BIT(26),
2238 .hw.init = &(struct clk_init_data){
2239 .name = "gcc_qupv3_wrap1_s4_clk",
2240 .parent_names = (const char *[]){
2241 "gcc_qupv3_wrap1_s4_clk_src",
2242 },
2243 .num_parents = 1,
2244 .flags = CLK_SET_RATE_PARENT,
2245 .ops = &clk_branch2_ops,
2246 },
2247 },
2248 };
2249
2250 static struct clk_branch gcc_qupv3_wrap1_s5_clk = {
2251 .halt_reg = 0x18604,
2252 .halt_check = BRANCH_HALT_VOTED,
2253 .clkr = {
2254 .enable_reg = 0x5200c,
2255 .enable_mask = BIT(27),
2256 .hw.init = &(struct clk_init_data){
2257 .name = "gcc_qupv3_wrap1_s5_clk",
2258 .parent_names = (const char *[]){
2259 "gcc_qupv3_wrap1_s5_clk_src",
2260 },
2261 .num_parents = 1,
2262 .flags = CLK_SET_RATE_PARENT,
2263 .ops = &clk_branch2_ops,
2264 },
2265 },
2266 };
2267
2268 static struct clk_branch gcc_qupv3_wrap1_s6_clk = {
2269 .halt_reg = 0x18734,
2270 .halt_check = BRANCH_HALT_VOTED,
2271 .clkr = {
2272 .enable_reg = 0x5200c,
2273 .enable_mask = BIT(28),
2274 .hw.init = &(struct clk_init_data){
2275 .name = "gcc_qupv3_wrap1_s6_clk",
2276 .parent_names = (const char *[]){
2277 "gcc_qupv3_wrap1_s6_clk_src",
2278 },
2279 .num_parents = 1,
2280 .flags = CLK_SET_RATE_PARENT,
2281 .ops = &clk_branch2_ops,
2282 },
2283 },
2284 };
2285
2286 static struct clk_branch gcc_qupv3_wrap1_s7_clk = {
2287 .halt_reg = 0x18864,
2288 .halt_check = BRANCH_HALT_VOTED,
2289 .clkr = {
2290 .enable_reg = 0x5200c,
2291 .enable_mask = BIT(29),
2292 .hw.init = &(struct clk_init_data){
2293 .name = "gcc_qupv3_wrap1_s7_clk",
2294 .parent_names = (const char *[]){
2295 "gcc_qupv3_wrap1_s7_clk_src",
2296 },
2297 .num_parents = 1,
2298 .flags = CLK_SET_RATE_PARENT,
2299 .ops = &clk_branch2_ops,
2300 },
2301 },
2302 };
2303
2304 static struct clk_branch gcc_qupv3_wrap_0_m_ahb_clk = {
2305 .halt_reg = 0x17004,
2306 .halt_check = BRANCH_HALT_VOTED,
2307 .clkr = {
2308 .enable_reg = 0x5200c,
2309 .enable_mask = BIT(6),
2310 .hw.init = &(struct clk_init_data){
2311 .name = "gcc_qupv3_wrap_0_m_ahb_clk",
2312 .ops = &clk_branch2_ops,
2313 },
2314 },
2315 };
2316
2317 static struct clk_branch gcc_qupv3_wrap_0_s_ahb_clk = {
2318 .halt_reg = 0x17008,
2319 .halt_check = BRANCH_HALT_VOTED,
2320 .hwcg_reg = 0x17008,
2321 .hwcg_bit = 1,
2322 .clkr = {
2323 .enable_reg = 0x5200c,
2324 .enable_mask = BIT(7),
2325 .hw.init = &(struct clk_init_data){
2326 .name = "gcc_qupv3_wrap_0_s_ahb_clk",
2327 .ops = &clk_branch2_ops,
2328 },
2329 },
2330 };
2331
2332 static struct clk_branch gcc_qupv3_wrap_1_m_ahb_clk = {
2333 .halt_reg = 0x1800c,
2334 .halt_check = BRANCH_HALT_VOTED,
2335 .clkr = {
2336 .enable_reg = 0x5200c,
2337 .enable_mask = BIT(20),
2338 .hw.init = &(struct clk_init_data){
2339 .name = "gcc_qupv3_wrap_1_m_ahb_clk",
2340 .ops = &clk_branch2_ops,
2341 },
2342 },
2343 };
2344
2345 static struct clk_branch gcc_qupv3_wrap_1_s_ahb_clk = {
2346 .halt_reg = 0x18010,
2347 .halt_check = BRANCH_HALT_VOTED,
2348 .hwcg_reg = 0x18010,
2349 .hwcg_bit = 1,
2350 .clkr = {
2351 .enable_reg = 0x5200c,
2352 .enable_mask = BIT(21),
2353 .hw.init = &(struct clk_init_data){
2354 .name = "gcc_qupv3_wrap_1_s_ahb_clk",
2355 .ops = &clk_branch2_ops,
2356 },
2357 },
2358 };
2359
2360 static struct clk_branch gcc_sdcc2_ahb_clk = {
2361 .halt_reg = 0x14008,
2362 .halt_check = BRANCH_HALT,
2363 .clkr = {
2364 .enable_reg = 0x14008,
2365 .enable_mask = BIT(0),
2366 .hw.init = &(struct clk_init_data){
2367 .name = "gcc_sdcc2_ahb_clk",
2368 .ops = &clk_branch2_ops,
2369 },
2370 },
2371 };
2372
2373 static struct clk_branch gcc_sdcc2_apps_clk = {
2374 .halt_reg = 0x14004,
2375 .halt_check = BRANCH_HALT,
2376 .clkr = {
2377 .enable_reg = 0x14004,
2378 .enable_mask = BIT(0),
2379 .hw.init = &(struct clk_init_data){
2380 .name = "gcc_sdcc2_apps_clk",
2381 .parent_names = (const char *[]){
2382 "gcc_sdcc2_apps_clk_src",
2383 },
2384 .num_parents = 1,
2385 .flags = CLK_SET_RATE_PARENT,
2386 .ops = &clk_branch2_ops,
2387 },
2388 },
2389 };
2390
2391 static struct clk_branch gcc_sdcc4_ahb_clk = {
2392 .halt_reg = 0x16008,
2393 .halt_check = BRANCH_HALT,
2394 .clkr = {
2395 .enable_reg = 0x16008,
2396 .enable_mask = BIT(0),
2397 .hw.init = &(struct clk_init_data){
2398 .name = "gcc_sdcc4_ahb_clk",
2399 .ops = &clk_branch2_ops,
2400 },
2401 },
2402 };
2403
2404 static struct clk_branch gcc_sdcc4_apps_clk = {
2405 .halt_reg = 0x16004,
2406 .halt_check = BRANCH_HALT,
2407 .clkr = {
2408 .enable_reg = 0x16004,
2409 .enable_mask = BIT(0),
2410 .hw.init = &(struct clk_init_data){
2411 .name = "gcc_sdcc4_apps_clk",
2412 .parent_names = (const char *[]){
2413 "gcc_sdcc4_apps_clk_src",
2414 },
2415 .num_parents = 1,
2416 .flags = CLK_SET_RATE_PARENT,
2417 .ops = &clk_branch2_ops,
2418 },
2419 },
2420 };
2421
2422 static struct clk_branch gcc_sys_noc_cpuss_ahb_clk = {
2423 .halt_reg = 0x414c,
2424 .halt_check = BRANCH_HALT_VOTED,
2425 .clkr = {
2426 .enable_reg = 0x52004,
2427 .enable_mask = BIT(0),
2428 .hw.init = &(struct clk_init_data){
2429 .name = "gcc_sys_noc_cpuss_ahb_clk",
2430 .parent_names = (const char *[]){
2431 "gcc_cpuss_ahb_clk_src",
2432 },
2433 .num_parents = 1,
2434 .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
2435 .ops = &clk_branch2_ops,
2436 },
2437 },
2438 };
2439
2440 static struct clk_branch gcc_tsif_ahb_clk = {
2441 .halt_reg = 0x36004,
2442 .halt_check = BRANCH_HALT,
2443 .clkr = {
2444 .enable_reg = 0x36004,
2445 .enable_mask = BIT(0),
2446 .hw.init = &(struct clk_init_data){
2447 .name = "gcc_tsif_ahb_clk",
2448 .ops = &clk_branch2_ops,
2449 },
2450 },
2451 };
2452
2453 static struct clk_branch gcc_tsif_inactivity_timers_clk = {
2454 .halt_reg = 0x3600c,
2455 .halt_check = BRANCH_HALT,
2456 .clkr = {
2457 .enable_reg = 0x3600c,
2458 .enable_mask = BIT(0),
2459 .hw.init = &(struct clk_init_data){
2460 .name = "gcc_tsif_inactivity_timers_clk",
2461 .ops = &clk_branch2_ops,
2462 },
2463 },
2464 };
2465
2466 static struct clk_branch gcc_tsif_ref_clk = {
2467 .halt_reg = 0x36008,
2468 .halt_check = BRANCH_HALT,
2469 .clkr = {
2470 .enable_reg = 0x36008,
2471 .enable_mask = BIT(0),
2472 .hw.init = &(struct clk_init_data){
2473 .name = "gcc_tsif_ref_clk",
2474 .parent_names = (const char *[]){
2475 "gcc_tsif_ref_clk_src",
2476 },
2477 .num_parents = 1,
2478 .flags = CLK_SET_RATE_PARENT,
2479 .ops = &clk_branch2_ops,
2480 },
2481 },
2482 };
2483
2484 static struct clk_branch gcc_ufs_card_ahb_clk = {
2485 .halt_reg = 0x75010,
2486 .halt_check = BRANCH_HALT,
2487 .hwcg_reg = 0x75010,
2488 .hwcg_bit = 1,
2489 .clkr = {
2490 .enable_reg = 0x75010,
2491 .enable_mask = BIT(0),
2492 .hw.init = &(struct clk_init_data){
2493 .name = "gcc_ufs_card_ahb_clk",
2494 .ops = &clk_branch2_ops,
2495 },
2496 },
2497 };
2498
2499 static struct clk_branch gcc_ufs_card_axi_clk = {
2500 .halt_reg = 0x7500c,
2501 .halt_check = BRANCH_HALT,
2502 .hwcg_reg = 0x7500c,
2503 .hwcg_bit = 1,
2504 .clkr = {
2505 .enable_reg = 0x7500c,
2506 .enable_mask = BIT(0),
2507 .hw.init = &(struct clk_init_data){
2508 .name = "gcc_ufs_card_axi_clk",
2509 .parent_names = (const char *[]){
2510 "gcc_ufs_card_axi_clk_src",
2511 },
2512 .num_parents = 1,
2513 .flags = CLK_SET_RATE_PARENT,
2514 .ops = &clk_branch2_ops,
2515 },
2516 },
2517 };
2518
2519 static struct clk_branch gcc_ufs_card_clkref_clk = {
2520 .halt_reg = 0x8c004,
2521 .halt_check = BRANCH_HALT,
2522 .clkr = {
2523 .enable_reg = 0x8c004,
2524 .enable_mask = BIT(0),
2525 .hw.init = &(struct clk_init_data){
2526 .name = "gcc_ufs_card_clkref_clk",
2527 .ops = &clk_branch2_ops,
2528 },
2529 },
2530 };
2531
2532 static struct clk_branch gcc_ufs_card_ice_core_clk = {
2533 .halt_reg = 0x75058,
2534 .halt_check = BRANCH_HALT,
2535 .hwcg_reg = 0x75058,
2536 .hwcg_bit = 1,
2537 .clkr = {
2538 .enable_reg = 0x75058,
2539 .enable_mask = BIT(0),
2540 .hw.init = &(struct clk_init_data){
2541 .name = "gcc_ufs_card_ice_core_clk",
2542 .parent_names = (const char *[]){
2543 "gcc_ufs_card_ice_core_clk_src",
2544 },
2545 .num_parents = 1,
2546 .flags = CLK_SET_RATE_PARENT,
2547 .ops = &clk_branch2_ops,
2548 },
2549 },
2550 };
2551
2552 static struct clk_branch gcc_ufs_card_phy_aux_clk = {
2553 .halt_reg = 0x7508c,
2554 .halt_check = BRANCH_HALT,
2555 .hwcg_reg = 0x7508c,
2556 .hwcg_bit = 1,
2557 .clkr = {
2558 .enable_reg = 0x7508c,
2559 .enable_mask = BIT(0),
2560 .hw.init = &(struct clk_init_data){
2561 .name = "gcc_ufs_card_phy_aux_clk",
2562 .parent_names = (const char *[]){
2563 "gcc_ufs_card_phy_aux_clk_src",
2564 },
2565 .num_parents = 1,
2566 .flags = CLK_SET_RATE_PARENT,
2567 .ops = &clk_branch2_ops,
2568 },
2569 },
2570 };
2571
2572 static struct clk_branch gcc_ufs_card_rx_symbol_0_clk = {
2573 .halt_check = BRANCH_HALT_SKIP,
2574 .clkr = {
2575 .enable_reg = 0x75018,
2576 .enable_mask = BIT(0),
2577 .hw.init = &(struct clk_init_data){
2578 .name = "gcc_ufs_card_rx_symbol_0_clk",
2579 .ops = &clk_branch2_ops,
2580 },
2581 },
2582 };
2583
2584 static struct clk_branch gcc_ufs_card_rx_symbol_1_clk = {
2585 .halt_check = BRANCH_HALT_SKIP,
2586 .clkr = {
2587 .enable_reg = 0x750a8,
2588 .enable_mask = BIT(0),
2589 .hw.init = &(struct clk_init_data){
2590 .name = "gcc_ufs_card_rx_symbol_1_clk",
2591 .ops = &clk_branch2_ops,
2592 },
2593 },
2594 };
2595
2596 static struct clk_branch gcc_ufs_card_tx_symbol_0_clk = {
2597 .halt_check = BRANCH_HALT_SKIP,
2598 .clkr = {
2599 .enable_reg = 0x75014,
2600 .enable_mask = BIT(0),
2601 .hw.init = &(struct clk_init_data){
2602 .name = "gcc_ufs_card_tx_symbol_0_clk",
2603 .ops = &clk_branch2_ops,
2604 },
2605 },
2606 };
2607
2608 static struct clk_branch gcc_ufs_card_unipro_core_clk = {
2609 .halt_reg = 0x75054,
2610 .halt_check = BRANCH_HALT,
2611 .hwcg_reg = 0x75054,
2612 .hwcg_bit = 1,
2613 .clkr = {
2614 .enable_reg = 0x75054,
2615 .enable_mask = BIT(0),
2616 .hw.init = &(struct clk_init_data){
2617 .name = "gcc_ufs_card_unipro_core_clk",
2618 .parent_names = (const char *[]){
2619 "gcc_ufs_card_unipro_core_clk_src",
2620 },
2621 .num_parents = 1,
2622 .flags = CLK_SET_RATE_PARENT,
2623 .ops = &clk_branch2_ops,
2624 },
2625 },
2626 };
2627
2628 static struct clk_branch gcc_ufs_mem_clkref_clk = {
2629 .halt_reg = 0x8c000,
2630 .halt_check = BRANCH_HALT,
2631 .clkr = {
2632 .enable_reg = 0x8c000,
2633 .enable_mask = BIT(0),
2634 .hw.init = &(struct clk_init_data){
2635 .name = "gcc_ufs_mem_clkref_clk",
2636 .ops = &clk_branch2_ops,
2637 },
2638 },
2639 };
2640
2641 static struct clk_branch gcc_ufs_phy_ahb_clk = {
2642 .halt_reg = 0x77010,
2643 .halt_check = BRANCH_HALT,
2644 .hwcg_reg = 0x77010,
2645 .hwcg_bit = 1,
2646 .clkr = {
2647 .enable_reg = 0x77010,
2648 .enable_mask = BIT(0),
2649 .hw.init = &(struct clk_init_data){
2650 .name = "gcc_ufs_phy_ahb_clk",
2651 .ops = &clk_branch2_ops,
2652 },
2653 },
2654 };
2655
2656 static struct clk_branch gcc_ufs_phy_axi_clk = {
2657 .halt_reg = 0x7700c,
2658 .halt_check = BRANCH_HALT,
2659 .hwcg_reg = 0x7700c,
2660 .hwcg_bit = 1,
2661 .clkr = {
2662 .enable_reg = 0x7700c,
2663 .enable_mask = BIT(0),
2664 .hw.init = &(struct clk_init_data){
2665 .name = "gcc_ufs_phy_axi_clk",
2666 .parent_names = (const char *[]){
2667 "gcc_ufs_phy_axi_clk_src",
2668 },
2669 .num_parents = 1,
2670 .flags = CLK_SET_RATE_PARENT,
2671 .ops = &clk_branch2_ops,
2672 },
2673 },
2674 };
2675
2676 static struct clk_branch gcc_ufs_phy_ice_core_clk = {
2677 .halt_reg = 0x77058,
2678 .halt_check = BRANCH_HALT,
2679 .hwcg_reg = 0x77058,
2680 .hwcg_bit = 1,
2681 .clkr = {
2682 .enable_reg = 0x77058,
2683 .enable_mask = BIT(0),
2684 .hw.init = &(struct clk_init_data){
2685 .name = "gcc_ufs_phy_ice_core_clk",
2686 .parent_names = (const char *[]){
2687 "gcc_ufs_phy_ice_core_clk_src",
2688 },
2689 .num_parents = 1,
2690 .flags = CLK_SET_RATE_PARENT,
2691 .ops = &clk_branch2_ops,
2692 },
2693 },
2694 };
2695
2696 static struct clk_branch gcc_ufs_phy_phy_aux_clk = {
2697 .halt_reg = 0x7708c,
2698 .halt_check = BRANCH_HALT,
2699 .hwcg_reg = 0x7708c,
2700 .hwcg_bit = 1,
2701 .clkr = {
2702 .enable_reg = 0x7708c,
2703 .enable_mask = BIT(0),
2704 .hw.init = &(struct clk_init_data){
2705 .name = "gcc_ufs_phy_phy_aux_clk",
2706 .parent_names = (const char *[]){
2707 "gcc_ufs_phy_phy_aux_clk_src",
2708 },
2709 .num_parents = 1,
2710 .flags = CLK_SET_RATE_PARENT,
2711 .ops = &clk_branch2_ops,
2712 },
2713 },
2714 };
2715
2716 static struct clk_branch gcc_ufs_phy_rx_symbol_0_clk = {
2717 .halt_check = BRANCH_HALT_SKIP,
2718 .clkr = {
2719 .enable_reg = 0x77018,
2720 .enable_mask = BIT(0),
2721 .hw.init = &(struct clk_init_data){
2722 .name = "gcc_ufs_phy_rx_symbol_0_clk",
2723 .ops = &clk_branch2_ops,
2724 },
2725 },
2726 };
2727
2728 static struct clk_branch gcc_ufs_phy_rx_symbol_1_clk = {
2729 .halt_check = BRANCH_HALT_SKIP,
2730 .clkr = {
2731 .enable_reg = 0x770a8,
2732 .enable_mask = BIT(0),
2733 .hw.init = &(struct clk_init_data){
2734 .name = "gcc_ufs_phy_rx_symbol_1_clk",
2735 .ops = &clk_branch2_ops,
2736 },
2737 },
2738 };
2739
2740 static struct clk_branch gcc_ufs_phy_tx_symbol_0_clk = {
2741 .halt_check = BRANCH_HALT_SKIP,
2742 .clkr = {
2743 .enable_reg = 0x77014,
2744 .enable_mask = BIT(0),
2745 .hw.init = &(struct clk_init_data){
2746 .name = "gcc_ufs_phy_tx_symbol_0_clk",
2747 .ops = &clk_branch2_ops,
2748 },
2749 },
2750 };
2751
2752 static struct clk_branch gcc_ufs_phy_unipro_core_clk = {
2753 .halt_reg = 0x77054,
2754 .halt_check = BRANCH_HALT,
2755 .hwcg_reg = 0x77054,
2756 .hwcg_bit = 1,
2757 .clkr = {
2758 .enable_reg = 0x77054,
2759 .enable_mask = BIT(0),
2760 .hw.init = &(struct clk_init_data){
2761 .name = "gcc_ufs_phy_unipro_core_clk",
2762 .parent_names = (const char *[]){
2763 "gcc_ufs_phy_unipro_core_clk_src",
2764 },
2765 .num_parents = 1,
2766 .flags = CLK_SET_RATE_PARENT,
2767 .ops = &clk_branch2_ops,
2768 },
2769 },
2770 };
2771
2772 static struct clk_branch gcc_usb30_prim_master_clk = {
2773 .halt_reg = 0xf00c,
2774 .halt_check = BRANCH_HALT,
2775 .clkr = {
2776 .enable_reg = 0xf00c,
2777 .enable_mask = BIT(0),
2778 .hw.init = &(struct clk_init_data){
2779 .name = "gcc_usb30_prim_master_clk",
2780 .parent_names = (const char *[]){
2781 "gcc_usb30_prim_master_clk_src",
2782 },
2783 .num_parents = 1,
2784 .flags = CLK_SET_RATE_PARENT,
2785 .ops = &clk_branch2_ops,
2786 },
2787 },
2788 };
2789
2790 static struct clk_branch gcc_usb30_prim_mock_utmi_clk = {
2791 .halt_reg = 0xf014,
2792 .halt_check = BRANCH_HALT,
2793 .clkr = {
2794 .enable_reg = 0xf014,
2795 .enable_mask = BIT(0),
2796 .hw.init = &(struct clk_init_data){
2797 .name = "gcc_usb30_prim_mock_utmi_clk",
2798 .parent_names = (const char *[]){
2799 "gcc_usb30_prim_mock_utmi_clk_src",
2800 },
2801 .num_parents = 1,
2802 .flags = CLK_SET_RATE_PARENT,
2803 .ops = &clk_branch2_ops,
2804 },
2805 },
2806 };
2807
2808 static struct clk_branch gcc_usb30_prim_sleep_clk = {
2809 .halt_reg = 0xf010,
2810 .halt_check = BRANCH_HALT,
2811 .clkr = {
2812 .enable_reg = 0xf010,
2813 .enable_mask = BIT(0),
2814 .hw.init = &(struct clk_init_data){
2815 .name = "gcc_usb30_prim_sleep_clk",
2816 .ops = &clk_branch2_ops,
2817 },
2818 },
2819 };
2820
2821 static struct clk_branch gcc_usb30_sec_master_clk = {
2822 .halt_reg = 0x1000c,
2823 .halt_check = BRANCH_HALT,
2824 .clkr = {
2825 .enable_reg = 0x1000c,
2826 .enable_mask = BIT(0),
2827 .hw.init = &(struct clk_init_data){
2828 .name = "gcc_usb30_sec_master_clk",
2829 .parent_names = (const char *[]){
2830 "gcc_usb30_sec_master_clk_src",
2831 },
2832 .num_parents = 1,
2833 .flags = CLK_SET_RATE_PARENT,
2834 .ops = &clk_branch2_ops,
2835 },
2836 },
2837 };
2838
2839 static struct clk_branch gcc_usb30_sec_mock_utmi_clk = {
2840 .halt_reg = 0x10014,
2841 .halt_check = BRANCH_HALT,
2842 .clkr = {
2843 .enable_reg = 0x10014,
2844 .enable_mask = BIT(0),
2845 .hw.init = &(struct clk_init_data){
2846 .name = "gcc_usb30_sec_mock_utmi_clk",
2847 .parent_names = (const char *[]){
2848 "gcc_usb30_sec_mock_utmi_clk_src",
2849 },
2850 .num_parents = 1,
2851 .flags = CLK_SET_RATE_PARENT,
2852 .ops = &clk_branch2_ops,
2853 },
2854 },
2855 };
2856
2857 static struct clk_branch gcc_usb30_sec_sleep_clk = {
2858 .halt_reg = 0x10010,
2859 .halt_check = BRANCH_HALT,
2860 .clkr = {
2861 .enable_reg = 0x10010,
2862 .enable_mask = BIT(0),
2863 .hw.init = &(struct clk_init_data){
2864 .name = "gcc_usb30_sec_sleep_clk",
2865 .ops = &clk_branch2_ops,
2866 },
2867 },
2868 };
2869
2870 static struct clk_branch gcc_usb3_prim_clkref_clk = {
2871 .halt_reg = 0x8c008,
2872 .halt_check = BRANCH_HALT,
2873 .clkr = {
2874 .enable_reg = 0x8c008,
2875 .enable_mask = BIT(0),
2876 .hw.init = &(struct clk_init_data){
2877 .name = "gcc_usb3_prim_clkref_clk",
2878 .ops = &clk_branch2_ops,
2879 },
2880 },
2881 };
2882
2883 static struct clk_branch gcc_usb3_prim_phy_aux_clk = {
2884 .halt_reg = 0xf04c,
2885 .halt_check = BRANCH_HALT,
2886 .clkr = {
2887 .enable_reg = 0xf04c,
2888 .enable_mask = BIT(0),
2889 .hw.init = &(struct clk_init_data){
2890 .name = "gcc_usb3_prim_phy_aux_clk",
2891 .parent_names = (const char *[]){
2892 "gcc_usb3_prim_phy_aux_clk_src",
2893 },
2894 .num_parents = 1,
2895 .flags = CLK_SET_RATE_PARENT,
2896 .ops = &clk_branch2_ops,
2897 },
2898 },
2899 };
2900
2901 static struct clk_branch gcc_usb3_prim_phy_com_aux_clk = {
2902 .halt_reg = 0xf050,
2903 .halt_check = BRANCH_HALT,
2904 .clkr = {
2905 .enable_reg = 0xf050,
2906 .enable_mask = BIT(0),
2907 .hw.init = &(struct clk_init_data){
2908 .name = "gcc_usb3_prim_phy_com_aux_clk",
2909 .parent_names = (const char *[]){
2910 "gcc_usb3_prim_phy_aux_clk_src",
2911 },
2912 .num_parents = 1,
2913 .flags = CLK_SET_RATE_PARENT,
2914 .ops = &clk_branch2_ops,
2915 },
2916 },
2917 };
2918
2919 static struct clk_branch gcc_usb3_prim_phy_pipe_clk = {
2920 .halt_check = BRANCH_HALT_SKIP,
2921 .clkr = {
2922 .enable_reg = 0xf054,
2923 .enable_mask = BIT(0),
2924 .hw.init = &(struct clk_init_data){
2925 .name = "gcc_usb3_prim_phy_pipe_clk",
2926 .ops = &clk_branch2_ops,
2927 },
2928 },
2929 };
2930
2931 static struct clk_branch gcc_usb3_sec_clkref_clk = {
2932 .halt_reg = 0x8c028,
2933 .halt_check = BRANCH_HALT,
2934 .clkr = {
2935 .enable_reg = 0x8c028,
2936 .enable_mask = BIT(0),
2937 .hw.init = &(struct clk_init_data){
2938 .name = "gcc_usb3_sec_clkref_clk",
2939 .ops = &clk_branch2_ops,
2940 },
2941 },
2942 };
2943
2944 static struct clk_branch gcc_usb3_sec_phy_aux_clk = {
2945 .halt_reg = 0x1004c,
2946 .halt_check = BRANCH_HALT,
2947 .clkr = {
2948 .enable_reg = 0x1004c,
2949 .enable_mask = BIT(0),
2950 .hw.init = &(struct clk_init_data){
2951 .name = "gcc_usb3_sec_phy_aux_clk",
2952 .parent_names = (const char *[]){
2953 "gcc_usb3_sec_phy_aux_clk_src",
2954 },
2955 .num_parents = 1,
2956 .flags = CLK_SET_RATE_PARENT,
2957 .ops = &clk_branch2_ops,
2958 },
2959 },
2960 };
2961
2962 static struct clk_branch gcc_usb3_sec_phy_com_aux_clk = {
2963 .halt_reg = 0x10050,
2964 .halt_check = BRANCH_HALT,
2965 .clkr = {
2966 .enable_reg = 0x10050,
2967 .enable_mask = BIT(0),
2968 .hw.init = &(struct clk_init_data){
2969 .name = "gcc_usb3_sec_phy_com_aux_clk",
2970 .parent_names = (const char *[]){
2971 "gcc_usb3_sec_phy_aux_clk_src",
2972 },
2973 .num_parents = 1,
2974 .flags = CLK_SET_RATE_PARENT,
2975 .ops = &clk_branch2_ops,
2976 },
2977 },
2978 };
2979
2980 static struct clk_branch gcc_usb3_sec_phy_pipe_clk = {
2981 .halt_check = BRANCH_HALT_SKIP,
2982 .clkr = {
2983 .enable_reg = 0x10054,
2984 .enable_mask = BIT(0),
2985 .hw.init = &(struct clk_init_data){
2986 .name = "gcc_usb3_sec_phy_pipe_clk",
2987 .ops = &clk_branch2_ops,
2988 },
2989 },
2990 };
2991
2992 static struct clk_branch gcc_usb_phy_cfg_ahb2phy_clk = {
2993 .halt_reg = 0x6a004,
2994 .halt_check = BRANCH_HALT,
2995 .hwcg_reg = 0x6a004,
2996 .hwcg_bit = 1,
2997 .clkr = {
2998 .enable_reg = 0x6a004,
2999 .enable_mask = BIT(0),
3000 .hw.init = &(struct clk_init_data){
3001 .name = "gcc_usb_phy_cfg_ahb2phy_clk",
3002 .ops = &clk_branch2_ops,
3003 },
3004 },
3005 };
3006
3007 static struct clk_branch gcc_vdda_vs_clk = {
3008 .halt_reg = 0x7a00c,
3009 .halt_check = BRANCH_HALT,
3010 .clkr = {
3011 .enable_reg = 0x7a00c,
3012 .enable_mask = BIT(0),
3013 .hw.init = &(struct clk_init_data){
3014 .name = "gcc_vdda_vs_clk",
3015 .parent_names = (const char *[]){
3016 "gcc_vsensor_clk_src",
3017 },
3018 .num_parents = 1,
3019 .flags = CLK_SET_RATE_PARENT,
3020 .ops = &clk_branch2_ops,
3021 },
3022 },
3023 };
3024
3025 static struct clk_branch gcc_vddcx_vs_clk = {
3026 .halt_reg = 0x7a004,
3027 .halt_check = BRANCH_HALT,
3028 .clkr = {
3029 .enable_reg = 0x7a004,
3030 .enable_mask = BIT(0),
3031 .hw.init = &(struct clk_init_data){
3032 .name = "gcc_vddcx_vs_clk",
3033 .parent_names = (const char *[]){
3034 "gcc_vsensor_clk_src",
3035 },
3036 .num_parents = 1,
3037 .flags = CLK_SET_RATE_PARENT,
3038 .ops = &clk_branch2_ops,
3039 },
3040 },
3041 };
3042
3043 static struct clk_branch gcc_vddmx_vs_clk = {
3044 .halt_reg = 0x7a008,
3045 .halt_check = BRANCH_HALT,
3046 .clkr = {
3047 .enable_reg = 0x7a008,
3048 .enable_mask = BIT(0),
3049 .hw.init = &(struct clk_init_data){
3050 .name = "gcc_vddmx_vs_clk",
3051 .parent_names = (const char *[]){
3052 "gcc_vsensor_clk_src",
3053 },
3054 .num_parents = 1,
3055 .flags = CLK_SET_RATE_PARENT,
3056 .ops = &clk_branch2_ops,
3057 },
3058 },
3059 };
3060
3061 static struct clk_branch gcc_video_ahb_clk = {
3062 .halt_reg = 0xb004,
3063 .halt_check = BRANCH_HALT,
3064 .hwcg_reg = 0xb004,
3065 .hwcg_bit = 1,
3066 .clkr = {
3067 .enable_reg = 0xb004,
3068 .enable_mask = BIT(0),
3069 .hw.init = &(struct clk_init_data){
3070 .name = "gcc_video_ahb_clk",
3071 .flags = CLK_IS_CRITICAL,
3072 .ops = &clk_branch2_ops,
3073 },
3074 },
3075 };
3076
3077 static struct clk_branch gcc_video_axi_clk = {
3078 .halt_reg = 0xb01c,
3079 .halt_check = BRANCH_VOTED,
3080 .clkr = {
3081 .enable_reg = 0xb01c,
3082 .enable_mask = BIT(0),
3083 .hw.init = &(struct clk_init_data){
3084 .name = "gcc_video_axi_clk",
3085 .ops = &clk_branch2_ops,
3086 },
3087 },
3088 };
3089
3090 static struct clk_branch gcc_video_xo_clk = {
3091 .halt_reg = 0xb028,
3092 .halt_check = BRANCH_HALT,
3093 .clkr = {
3094 .enable_reg = 0xb028,
3095 .enable_mask = BIT(0),
3096 .hw.init = &(struct clk_init_data){
3097 .name = "gcc_video_xo_clk",
3098 .flags = CLK_IS_CRITICAL,
3099 .ops = &clk_branch2_ops,
3100 },
3101 },
3102 };
3103
3104 static struct clk_branch gcc_vs_ctrl_ahb_clk = {
3105 .halt_reg = 0x7a014,
3106 .halt_check = BRANCH_HALT,
3107 .hwcg_reg = 0x7a014,
3108 .hwcg_bit = 1,
3109 .clkr = {
3110 .enable_reg = 0x7a014,
3111 .enable_mask = BIT(0),
3112 .hw.init = &(struct clk_init_data){
3113 .name = "gcc_vs_ctrl_ahb_clk",
3114 .ops = &clk_branch2_ops,
3115 },
3116 },
3117 };
3118
3119 static struct clk_branch gcc_vs_ctrl_clk = {
3120 .halt_reg = 0x7a010,
3121 .halt_check = BRANCH_HALT,
3122 .clkr = {
3123 .enable_reg = 0x7a010,
3124 .enable_mask = BIT(0),
3125 .hw.init = &(struct clk_init_data){
3126 .name = "gcc_vs_ctrl_clk",
3127 .parent_names = (const char *[]){
3128 "gcc_vs_ctrl_clk_src",
3129 },
3130 .num_parents = 1,
3131 .flags = CLK_SET_RATE_PARENT,
3132 .ops = &clk_branch2_ops,
3133 },
3134 },
3135 };
3136
3137 static struct clk_branch gcc_cpuss_dvm_bus_clk = {
3138 .halt_reg = 0x48190,
3139 .halt_check = BRANCH_HALT,
3140 .clkr = {
3141 .enable_reg = 0x48190,
3142 .enable_mask = BIT(0),
3143 .hw.init = &(struct clk_init_data){
3144 .name = "gcc_cpuss_dvm_bus_clk",
3145 .flags = CLK_IS_CRITICAL,
3146 .ops = &clk_branch2_ops,
3147 },
3148 },
3149 };
3150
3151 static struct clk_branch gcc_cpuss_gnoc_clk = {
3152 .halt_reg = 0x48004,
3153 .halt_check = BRANCH_HALT_VOTED,
3154 .hwcg_reg = 0x48004,
3155 .hwcg_bit = 1,
3156 .clkr = {
3157 .enable_reg = 0x52004,
3158 .enable_mask = BIT(22),
3159 .hw.init = &(struct clk_init_data){
3160 .name = "gcc_cpuss_gnoc_clk",
3161 .flags = CLK_IS_CRITICAL,
3162 .ops = &clk_branch2_ops,
3163 },
3164 },
3165 };
3166
3167 /* TODO: Remove after DTS updated to protect these */
3168 #ifdef CONFIG_SDM_LPASSCC_845
3169 static struct clk_branch gcc_lpass_q6_axi_clk = {
3170 .halt_reg = 0x47000,
3171 .halt_check = BRANCH_HALT,
3172 .clkr = {
3173 .enable_reg = 0x47000,
3174 .enable_mask = BIT(0),
3175 .hw.init = &(struct clk_init_data){
3176 .name = "gcc_lpass_q6_axi_clk",
3177 .flags = CLK_IS_CRITICAL,
3178 .ops = &clk_branch2_ops,
3179 },
3180 },
3181 };
3182
3183 static struct clk_branch gcc_lpass_sway_clk = {
3184 .halt_reg = 0x47008,
3185 .halt_check = BRANCH_HALT,
3186 .clkr = {
3187 .enable_reg = 0x47008,
3188 .enable_mask = BIT(0),
3189 .hw.init = &(struct clk_init_data){
3190 .name = "gcc_lpass_sway_clk",
3191 .flags = CLK_IS_CRITICAL,
3192 .ops = &clk_branch2_ops,
3193 },
3194 },
3195 };
3196 #endif
3197
3198 static struct gdsc pcie_0_gdsc = {
3199 .gdscr = 0x6b004,
3200 .pd = {
3201 .name = "pcie_0_gdsc",
3202 },
3203 .pwrsts = PWRSTS_OFF_ON,
3204 .flags = POLL_CFG_GDSCR,
3205 };
3206
3207 static struct gdsc pcie_1_gdsc = {
3208 .gdscr = 0x8d004,
3209 .pd = {
3210 .name = "pcie_1_gdsc",
3211 },
3212 .pwrsts = PWRSTS_OFF_ON,
3213 .flags = POLL_CFG_GDSCR,
3214 };
3215
3216 static struct gdsc ufs_card_gdsc = {
3217 .gdscr = 0x75004,
3218 .pd = {
3219 .name = "ufs_card_gdsc",
3220 },
3221 .pwrsts = PWRSTS_OFF_ON,
3222 .flags = POLL_CFG_GDSCR,
3223 };
3224
3225 static struct gdsc ufs_phy_gdsc = {
3226 .gdscr = 0x77004,
3227 .pd = {
3228 .name = "ufs_phy_gdsc",
3229 },
3230 .pwrsts = PWRSTS_OFF_ON,
3231 .flags = POLL_CFG_GDSCR,
3232 };
3233
3234 static struct gdsc usb30_prim_gdsc = {
3235 .gdscr = 0xf004,
3236 .pd = {
3237 .name = "usb30_prim_gdsc",
3238 },
3239 .pwrsts = PWRSTS_OFF_ON,
3240 .flags = POLL_CFG_GDSCR,
3241 };
3242
3243 static struct gdsc usb30_sec_gdsc = {
3244 .gdscr = 0x10004,
3245 .pd = {
3246 .name = "usb30_sec_gdsc",
3247 },
3248 .pwrsts = PWRSTS_OFF_ON,
3249 .flags = POLL_CFG_GDSCR,
3250 };
3251
3252 static struct gdsc hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc = {
3253 .gdscr = 0x7d030,
3254 .pd = {
3255 .name = "hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc",
3256 },
3257 .pwrsts = PWRSTS_OFF_ON,
3258 };
3259
3260 static struct gdsc hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc = {
3261 .gdscr = 0x7d03c,
3262 .pd = {
3263 .name = "hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc",
3264 },
3265 .pwrsts = PWRSTS_OFF_ON,
3266 };
3267
3268 static struct gdsc hlos1_vote_aggre_noc_mmu_tbu1_gdsc = {
3269 .gdscr = 0x7d034,
3270 .pd = {
3271 .name = "hlos1_vote_aggre_noc_mmu_tbu1_gdsc",
3272 },
3273 .pwrsts = PWRSTS_OFF_ON,
3274 };
3275
3276 static struct gdsc hlos1_vote_aggre_noc_mmu_tbu2_gdsc = {
3277 .gdscr = 0x7d038,
3278 .pd = {
3279 .name = "hlos1_vote_aggre_noc_mmu_tbu2_gdsc",
3280 },
3281 .pwrsts = PWRSTS_OFF_ON,
3282 };
3283
3284 static struct gdsc hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc = {
3285 .gdscr = 0x7d040,
3286 .pd = {
3287 .name = "hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc",
3288 },
3289 .pwrsts = PWRSTS_OFF_ON,
3290 };
3291
3292 static struct gdsc hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc = {
3293 .gdscr = 0x7d048,
3294 .pd = {
3295 .name = "hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc",
3296 },
3297 .pwrsts = PWRSTS_OFF_ON,
3298 };
3299
3300 static struct gdsc hlos1_vote_mmnoc_mmu_tbu_sf_gdsc = {
3301 .gdscr = 0x7d044,
3302 .pd = {
3303 .name = "hlos1_vote_mmnoc_mmu_tbu_sf_gdsc",
3304 },
3305 .pwrsts = PWRSTS_OFF_ON,
3306 };
3307
3308 static struct clk_regmap *gcc_sdm845_clocks[] = {
3309 [GCC_AGGRE_NOC_PCIE_TBU_CLK] = &gcc_aggre_noc_pcie_tbu_clk.clkr,
3310 [GCC_AGGRE_UFS_CARD_AXI_CLK] = &gcc_aggre_ufs_card_axi_clk.clkr,
3311 [GCC_AGGRE_UFS_PHY_AXI_CLK] = &gcc_aggre_ufs_phy_axi_clk.clkr,
3312 [GCC_AGGRE_USB3_PRIM_AXI_CLK] = &gcc_aggre_usb3_prim_axi_clk.clkr,
3313 [GCC_AGGRE_USB3_SEC_AXI_CLK] = &gcc_aggre_usb3_sec_axi_clk.clkr,
3314 [GCC_APC_VS_CLK] = &gcc_apc_vs_clk.clkr,
3315 [GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr,
3316 [GCC_CAMERA_AHB_CLK] = &gcc_camera_ahb_clk.clkr,
3317 [GCC_CAMERA_AXI_CLK] = &gcc_camera_axi_clk.clkr,
3318 [GCC_CAMERA_XO_CLK] = &gcc_camera_xo_clk.clkr,
3319 [GCC_CE1_AHB_CLK] = &gcc_ce1_ahb_clk.clkr,
3320 [GCC_CE1_AXI_CLK] = &gcc_ce1_axi_clk.clkr,
3321 [GCC_CE1_CLK] = &gcc_ce1_clk.clkr,
3322 [GCC_CFG_NOC_USB3_PRIM_AXI_CLK] = &gcc_cfg_noc_usb3_prim_axi_clk.clkr,
3323 [GCC_CFG_NOC_USB3_SEC_AXI_CLK] = &gcc_cfg_noc_usb3_sec_axi_clk.clkr,
3324 [GCC_CPUSS_AHB_CLK] = &gcc_cpuss_ahb_clk.clkr,
3325 [GCC_CPUSS_AHB_CLK_SRC] = &gcc_cpuss_ahb_clk_src.clkr,
3326 [GCC_CPUSS_RBCPR_CLK] = &gcc_cpuss_rbcpr_clk.clkr,
3327 [GCC_CPUSS_RBCPR_CLK_SRC] = &gcc_cpuss_rbcpr_clk_src.clkr,
3328 [GCC_DDRSS_GPU_AXI_CLK] = &gcc_ddrss_gpu_axi_clk.clkr,
3329 [GCC_DISP_AHB_CLK] = &gcc_disp_ahb_clk.clkr,
3330 [GCC_DISP_AXI_CLK] = &gcc_disp_axi_clk.clkr,
3331 [GCC_DISP_GPLL0_CLK_SRC] = &gcc_disp_gpll0_clk_src.clkr,
3332 [GCC_DISP_GPLL0_DIV_CLK_SRC] = &gcc_disp_gpll0_div_clk_src.clkr,
3333 [GCC_DISP_XO_CLK] = &gcc_disp_xo_clk.clkr,
3334 [GCC_GP1_CLK] = &gcc_gp1_clk.clkr,
3335 [GCC_GP1_CLK_SRC] = &gcc_gp1_clk_src.clkr,
3336 [GCC_GP2_CLK] = &gcc_gp2_clk.clkr,
3337 [GCC_GP2_CLK_SRC] = &gcc_gp2_clk_src.clkr,
3338 [GCC_GP3_CLK] = &gcc_gp3_clk.clkr,
3339 [GCC_GP3_CLK_SRC] = &gcc_gp3_clk_src.clkr,
3340 [GCC_GPU_CFG_AHB_CLK] = &gcc_gpu_cfg_ahb_clk.clkr,
3341 [GCC_GPU_GPLL0_CLK_SRC] = &gcc_gpu_gpll0_clk_src.clkr,
3342 [GCC_GPU_GPLL0_DIV_CLK_SRC] = &gcc_gpu_gpll0_div_clk_src.clkr,
3343 [GCC_GPU_IREF_CLK] = &gcc_gpu_iref_clk.clkr,
3344 [GCC_GPU_MEMNOC_GFX_CLK] = &gcc_gpu_memnoc_gfx_clk.clkr,
3345 [GCC_GPU_SNOC_DVM_GFX_CLK] = &gcc_gpu_snoc_dvm_gfx_clk.clkr,
3346 [GCC_GPU_VS_CLK] = &gcc_gpu_vs_clk.clkr,
3347 [GCC_MSS_AXIS2_CLK] = &gcc_mss_axis2_clk.clkr,
3348 [GCC_MSS_CFG_AHB_CLK] = &gcc_mss_cfg_ahb_clk.clkr,
3349 [GCC_MSS_GPLL0_DIV_CLK_SRC] = &gcc_mss_gpll0_div_clk_src.clkr,
3350 [GCC_MSS_MFAB_AXIS_CLK] = &gcc_mss_mfab_axis_clk.clkr,
3351 [GCC_MSS_Q6_MEMNOC_AXI_CLK] = &gcc_mss_q6_memnoc_axi_clk.clkr,
3352 [GCC_MSS_SNOC_AXI_CLK] = &gcc_mss_snoc_axi_clk.clkr,
3353 [GCC_MSS_VS_CLK] = &gcc_mss_vs_clk.clkr,
3354 [GCC_PCIE_0_AUX_CLK] = &gcc_pcie_0_aux_clk.clkr,
3355 [GCC_PCIE_0_AUX_CLK_SRC] = &gcc_pcie_0_aux_clk_src.clkr,
3356 [GCC_PCIE_0_CFG_AHB_CLK] = &gcc_pcie_0_cfg_ahb_clk.clkr,
3357 [GCC_PCIE_0_CLKREF_CLK] = &gcc_pcie_0_clkref_clk.clkr,
3358 [GCC_PCIE_0_MSTR_AXI_CLK] = &gcc_pcie_0_mstr_axi_clk.clkr,
3359 [GCC_PCIE_0_PIPE_CLK] = &gcc_pcie_0_pipe_clk.clkr,
3360 [GCC_PCIE_0_SLV_AXI_CLK] = &gcc_pcie_0_slv_axi_clk.clkr,
3361 [GCC_PCIE_0_SLV_Q2A_AXI_CLK] = &gcc_pcie_0_slv_q2a_axi_clk.clkr,
3362 [GCC_PCIE_1_AUX_CLK] = &gcc_pcie_1_aux_clk.clkr,
3363 [GCC_PCIE_1_AUX_CLK_SRC] = &gcc_pcie_1_aux_clk_src.clkr,
3364 [GCC_PCIE_1_CFG_AHB_CLK] = &gcc_pcie_1_cfg_ahb_clk.clkr,
3365 [GCC_PCIE_1_CLKREF_CLK] = &gcc_pcie_1_clkref_clk.clkr,
3366 [GCC_PCIE_1_MSTR_AXI_CLK] = &gcc_pcie_1_mstr_axi_clk.clkr,
3367 [GCC_PCIE_1_PIPE_CLK] = &gcc_pcie_1_pipe_clk.clkr,
3368 [GCC_PCIE_1_SLV_AXI_CLK] = &gcc_pcie_1_slv_axi_clk.clkr,
3369 [GCC_PCIE_1_SLV_Q2A_AXI_CLK] = &gcc_pcie_1_slv_q2a_axi_clk.clkr,
3370 [GCC_PCIE_PHY_AUX_CLK] = &gcc_pcie_phy_aux_clk.clkr,
3371 [GCC_PCIE_PHY_REFGEN_CLK] = &gcc_pcie_phy_refgen_clk.clkr,
3372 [GCC_PCIE_PHY_REFGEN_CLK_SRC] = &gcc_pcie_phy_refgen_clk_src.clkr,
3373 [GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr,
3374 [GCC_PDM2_CLK_SRC] = &gcc_pdm2_clk_src.clkr,
3375 [GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr,
3376 [GCC_PDM_XO4_CLK] = &gcc_pdm_xo4_clk.clkr,
3377 [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr,
3378 [GCC_QMIP_CAMERA_AHB_CLK] = &gcc_qmip_camera_ahb_clk.clkr,
3379 [GCC_QMIP_DISP_AHB_CLK] = &gcc_qmip_disp_ahb_clk.clkr,
3380 [GCC_QMIP_VIDEO_AHB_CLK] = &gcc_qmip_video_ahb_clk.clkr,
3381 [GCC_QUPV3_WRAP0_S0_CLK] = &gcc_qupv3_wrap0_s0_clk.clkr,
3382 [GCC_QUPV3_WRAP0_S0_CLK_SRC] = &gcc_qupv3_wrap0_s0_clk_src.clkr,
3383 [GCC_QUPV3_WRAP0_S1_CLK] = &gcc_qupv3_wrap0_s1_clk.clkr,
3384 [GCC_QUPV3_WRAP0_S1_CLK_SRC] = &gcc_qupv3_wrap0_s1_clk_src.clkr,
3385 [GCC_QUPV3_WRAP0_S2_CLK] = &gcc_qupv3_wrap0_s2_clk.clkr,
3386 [GCC_QUPV3_WRAP0_S2_CLK_SRC] = &gcc_qupv3_wrap0_s2_clk_src.clkr,
3387 [GCC_QUPV3_WRAP0_S3_CLK] = &gcc_qupv3_wrap0_s3_clk.clkr,
3388 [GCC_QUPV3_WRAP0_S3_CLK_SRC] = &gcc_qupv3_wrap0_s3_clk_src.clkr,
3389 [GCC_QUPV3_WRAP0_S4_CLK] = &gcc_qupv3_wrap0_s4_clk.clkr,
3390 [GCC_QUPV3_WRAP0_S4_CLK_SRC] = &gcc_qupv3_wrap0_s4_clk_src.clkr,
3391 [GCC_QUPV3_WRAP0_S5_CLK] = &gcc_qupv3_wrap0_s5_clk.clkr,
3392 [GCC_QUPV3_WRAP0_S5_CLK_SRC] = &gcc_qupv3_wrap0_s5_clk_src.clkr,
3393 [GCC_QUPV3_WRAP0_S6_CLK] = &gcc_qupv3_wrap0_s6_clk.clkr,
3394 [GCC_QUPV3_WRAP0_S6_CLK_SRC] = &gcc_qupv3_wrap0_s6_clk_src.clkr,
3395 [GCC_QUPV3_WRAP0_S7_CLK] = &gcc_qupv3_wrap0_s7_clk.clkr,
3396 [GCC_QUPV3_WRAP0_S7_CLK_SRC] = &gcc_qupv3_wrap0_s7_clk_src.clkr,
3397 [GCC_QUPV3_WRAP1_S0_CLK] = &gcc_qupv3_wrap1_s0_clk.clkr,
3398 [GCC_QUPV3_WRAP1_S0_CLK_SRC] = &gcc_qupv3_wrap1_s0_clk_src.clkr,
3399 [GCC_QUPV3_WRAP1_S1_CLK] = &gcc_qupv3_wrap1_s1_clk.clkr,
3400 [GCC_QUPV3_WRAP1_S1_CLK_SRC] = &gcc_qupv3_wrap1_s1_clk_src.clkr,
3401 [GCC_QUPV3_WRAP1_S2_CLK] = &gcc_qupv3_wrap1_s2_clk.clkr,
3402 [GCC_QUPV3_WRAP1_S2_CLK_SRC] = &gcc_qupv3_wrap1_s2_clk_src.clkr,
3403 [GCC_QUPV3_WRAP1_S3_CLK] = &gcc_qupv3_wrap1_s3_clk.clkr,
3404 [GCC_QUPV3_WRAP1_S3_CLK_SRC] = &gcc_qupv3_wrap1_s3_clk_src.clkr,
3405 [GCC_QUPV3_WRAP1_S4_CLK] = &gcc_qupv3_wrap1_s4_clk.clkr,
3406 [GCC_QUPV3_WRAP1_S4_CLK_SRC] = &gcc_qupv3_wrap1_s4_clk_src.clkr,
3407 [GCC_QUPV3_WRAP1_S5_CLK] = &gcc_qupv3_wrap1_s5_clk.clkr,
3408 [GCC_QUPV3_WRAP1_S5_CLK_SRC] = &gcc_qupv3_wrap1_s5_clk_src.clkr,
3409 [GCC_QUPV3_WRAP1_S6_CLK] = &gcc_qupv3_wrap1_s6_clk.clkr,
3410 [GCC_QUPV3_WRAP1_S6_CLK_SRC] = &gcc_qupv3_wrap1_s6_clk_src.clkr,
3411 [GCC_QUPV3_WRAP1_S7_CLK] = &gcc_qupv3_wrap1_s7_clk.clkr,
3412 [GCC_QUPV3_WRAP1_S7_CLK_SRC] = &gcc_qupv3_wrap1_s7_clk_src.clkr,
3413 [GCC_QUPV3_WRAP_0_M_AHB_CLK] = &gcc_qupv3_wrap_0_m_ahb_clk.clkr,
3414 [GCC_QUPV3_WRAP_0_S_AHB_CLK] = &gcc_qupv3_wrap_0_s_ahb_clk.clkr,
3415 [GCC_QUPV3_WRAP_1_M_AHB_CLK] = &gcc_qupv3_wrap_1_m_ahb_clk.clkr,
3416 [GCC_QUPV3_WRAP_1_S_AHB_CLK] = &gcc_qupv3_wrap_1_s_ahb_clk.clkr,
3417 [GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr,
3418 [GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr,
3419 [GCC_SDCC2_APPS_CLK_SRC] = &gcc_sdcc2_apps_clk_src.clkr,
3420 [GCC_SDCC4_AHB_CLK] = &gcc_sdcc4_ahb_clk.clkr,
3421 [GCC_SDCC4_APPS_CLK] = &gcc_sdcc4_apps_clk.clkr,
3422 [GCC_SDCC4_APPS_CLK_SRC] = &gcc_sdcc4_apps_clk_src.clkr,
3423 [GCC_SYS_NOC_CPUSS_AHB_CLK] = &gcc_sys_noc_cpuss_ahb_clk.clkr,
3424 [GCC_TSIF_AHB_CLK] = &gcc_tsif_ahb_clk.clkr,
3425 [GCC_TSIF_INACTIVITY_TIMERS_CLK] =
3426 &gcc_tsif_inactivity_timers_clk.clkr,
3427 [GCC_TSIF_REF_CLK] = &gcc_tsif_ref_clk.clkr,
3428 [GCC_TSIF_REF_CLK_SRC] = &gcc_tsif_ref_clk_src.clkr,
3429 [GCC_UFS_CARD_AHB_CLK] = &gcc_ufs_card_ahb_clk.clkr,
3430 [GCC_UFS_CARD_AXI_CLK] = &gcc_ufs_card_axi_clk.clkr,
3431 [GCC_UFS_CARD_AXI_CLK_SRC] = &gcc_ufs_card_axi_clk_src.clkr,
3432 [GCC_UFS_CARD_CLKREF_CLK] = &gcc_ufs_card_clkref_clk.clkr,
3433 [GCC_UFS_CARD_ICE_CORE_CLK] = &gcc_ufs_card_ice_core_clk.clkr,
3434 [GCC_UFS_CARD_ICE_CORE_CLK_SRC] = &gcc_ufs_card_ice_core_clk_src.clkr,
3435 [GCC_UFS_CARD_PHY_AUX_CLK] = &gcc_ufs_card_phy_aux_clk.clkr,
3436 [GCC_UFS_CARD_PHY_AUX_CLK_SRC] = &gcc_ufs_card_phy_aux_clk_src.clkr,
3437 [GCC_UFS_CARD_RX_SYMBOL_0_CLK] = &gcc_ufs_card_rx_symbol_0_clk.clkr,
3438 [GCC_UFS_CARD_RX_SYMBOL_1_CLK] = &gcc_ufs_card_rx_symbol_1_clk.clkr,
3439 [GCC_UFS_CARD_TX_SYMBOL_0_CLK] = &gcc_ufs_card_tx_symbol_0_clk.clkr,
3440 [GCC_UFS_CARD_UNIPRO_CORE_CLK] = &gcc_ufs_card_unipro_core_clk.clkr,
3441 [GCC_UFS_CARD_UNIPRO_CORE_CLK_SRC] =
3442 &gcc_ufs_card_unipro_core_clk_src.clkr,
3443 [GCC_UFS_MEM_CLKREF_CLK] = &gcc_ufs_mem_clkref_clk.clkr,
3444 [GCC_UFS_PHY_AHB_CLK] = &gcc_ufs_phy_ahb_clk.clkr,
3445 [GCC_UFS_PHY_AXI_CLK] = &gcc_ufs_phy_axi_clk.clkr,
3446 [GCC_UFS_PHY_AXI_CLK_SRC] = &gcc_ufs_phy_axi_clk_src.clkr,
3447 [GCC_UFS_PHY_ICE_CORE_CLK] = &gcc_ufs_phy_ice_core_clk.clkr,
3448 [GCC_UFS_PHY_ICE_CORE_CLK_SRC] = &gcc_ufs_phy_ice_core_clk_src.clkr,
3449 [GCC_UFS_PHY_PHY_AUX_CLK] = &gcc_ufs_phy_phy_aux_clk.clkr,
3450 [GCC_UFS_PHY_PHY_AUX_CLK_SRC] = &gcc_ufs_phy_phy_aux_clk_src.clkr,
3451 [GCC_UFS_PHY_RX_SYMBOL_0_CLK] = &gcc_ufs_phy_rx_symbol_0_clk.clkr,
3452 [GCC_UFS_PHY_RX_SYMBOL_1_CLK] = &gcc_ufs_phy_rx_symbol_1_clk.clkr,
3453 [GCC_UFS_PHY_TX_SYMBOL_0_CLK] = &gcc_ufs_phy_tx_symbol_0_clk.clkr,
3454 [GCC_UFS_PHY_UNIPRO_CORE_CLK] = &gcc_ufs_phy_unipro_core_clk.clkr,
3455 [GCC_UFS_PHY_UNIPRO_CORE_CLK_SRC] =
3456 &gcc_ufs_phy_unipro_core_clk_src.clkr,
3457 [GCC_USB30_PRIM_MASTER_CLK] = &gcc_usb30_prim_master_clk.clkr,
3458 [GCC_USB30_PRIM_MASTER_CLK_SRC] = &gcc_usb30_prim_master_clk_src.clkr,
3459 [GCC_USB30_PRIM_MOCK_UTMI_CLK] = &gcc_usb30_prim_mock_utmi_clk.clkr,
3460 [GCC_USB30_PRIM_MOCK_UTMI_CLK_SRC] =
3461 &gcc_usb30_prim_mock_utmi_clk_src.clkr,
3462 [GCC_USB30_PRIM_SLEEP_CLK] = &gcc_usb30_prim_sleep_clk.clkr,
3463 [GCC_USB30_SEC_MASTER_CLK] = &gcc_usb30_sec_master_clk.clkr,
3464 [GCC_USB30_SEC_MASTER_CLK_SRC] = &gcc_usb30_sec_master_clk_src.clkr,
3465 [GCC_USB30_SEC_MOCK_UTMI_CLK] = &gcc_usb30_sec_mock_utmi_clk.clkr,
3466 [GCC_USB30_SEC_MOCK_UTMI_CLK_SRC] =
3467 &gcc_usb30_sec_mock_utmi_clk_src.clkr,
3468 [GCC_USB30_SEC_SLEEP_CLK] = &gcc_usb30_sec_sleep_clk.clkr,
3469 [GCC_USB3_PRIM_CLKREF_CLK] = &gcc_usb3_prim_clkref_clk.clkr,
3470 [GCC_USB3_PRIM_PHY_AUX_CLK] = &gcc_usb3_prim_phy_aux_clk.clkr,
3471 [GCC_USB3_PRIM_PHY_AUX_CLK_SRC] = &gcc_usb3_prim_phy_aux_clk_src.clkr,
3472 [GCC_USB3_PRIM_PHY_COM_AUX_CLK] = &gcc_usb3_prim_phy_com_aux_clk.clkr,
3473 [GCC_USB3_PRIM_PHY_PIPE_CLK] = &gcc_usb3_prim_phy_pipe_clk.clkr,
3474 [GCC_USB3_SEC_CLKREF_CLK] = &gcc_usb3_sec_clkref_clk.clkr,
3475 [GCC_USB3_SEC_PHY_AUX_CLK] = &gcc_usb3_sec_phy_aux_clk.clkr,
3476 [GCC_USB3_SEC_PHY_AUX_CLK_SRC] = &gcc_usb3_sec_phy_aux_clk_src.clkr,
3477 [GCC_USB3_SEC_PHY_COM_AUX_CLK] = &gcc_usb3_sec_phy_com_aux_clk.clkr,
3478 [GCC_USB3_SEC_PHY_PIPE_CLK] = &gcc_usb3_sec_phy_pipe_clk.clkr,
3479 [GCC_USB_PHY_CFG_AHB2PHY_CLK] = &gcc_usb_phy_cfg_ahb2phy_clk.clkr,
3480 [GCC_VDDA_VS_CLK] = &gcc_vdda_vs_clk.clkr,
3481 [GCC_VDDCX_VS_CLK] = &gcc_vddcx_vs_clk.clkr,
3482 [GCC_VDDMX_VS_CLK] = &gcc_vddmx_vs_clk.clkr,
3483 [GCC_VIDEO_AHB_CLK] = &gcc_video_ahb_clk.clkr,
3484 [GCC_VIDEO_AXI_CLK] = &gcc_video_axi_clk.clkr,
3485 [GCC_VIDEO_XO_CLK] = &gcc_video_xo_clk.clkr,
3486 [GCC_VS_CTRL_AHB_CLK] = &gcc_vs_ctrl_ahb_clk.clkr,
3487 [GCC_VS_CTRL_CLK] = &gcc_vs_ctrl_clk.clkr,
3488 [GCC_VS_CTRL_CLK_SRC] = &gcc_vs_ctrl_clk_src.clkr,
3489 [GCC_VSENSOR_CLK_SRC] = &gcc_vsensor_clk_src.clkr,
3490 [GPLL0] = &gpll0.clkr,
3491 [GPLL0_OUT_EVEN] = &gpll0_out_even.clkr,
3492 [GPLL4] = &gpll4.clkr,
3493 [GCC_CPUSS_DVM_BUS_CLK] = &gcc_cpuss_dvm_bus_clk.clkr,
3494 [GCC_CPUSS_GNOC_CLK] = &gcc_cpuss_gnoc_clk.clkr,
3495 [GCC_QSPI_CORE_CLK_SRC] = &gcc_qspi_core_clk_src.clkr,
3496 [GCC_QSPI_CORE_CLK] = &gcc_qspi_core_clk.clkr,
3497 [GCC_QSPI_CNOC_PERIPH_AHB_CLK] = &gcc_qspi_cnoc_periph_ahb_clk.clkr,
3498 #ifdef CONFIG_SDM_LPASSCC_845
3499 [GCC_LPASS_Q6_AXI_CLK] = &gcc_lpass_q6_axi_clk.clkr,
3500 [GCC_LPASS_SWAY_CLK] = &gcc_lpass_sway_clk.clkr,
3501 #endif
3502 };
3503
3504 static const struct qcom_reset_map gcc_sdm845_resets[] = {
3505 [GCC_MMSS_BCR] = { 0xb000 },
3506 [GCC_PCIE_0_BCR] = { 0x6b000 },
3507 [GCC_PCIE_1_BCR] = { 0x8d000 },
3508 [GCC_PCIE_PHY_BCR] = { 0x6f000 },
3509 [GCC_PDM_BCR] = { 0x33000 },
3510 [GCC_PRNG_BCR] = { 0x34000 },
3511 [GCC_QUPV3_WRAPPER_0_BCR] = { 0x17000 },
3512 [GCC_QUPV3_WRAPPER_1_BCR] = { 0x18000 },
3513 [GCC_QUSB2PHY_PRIM_BCR] = { 0x12000 },
3514 [GCC_QUSB2PHY_SEC_BCR] = { 0x12004 },
3515 [GCC_SDCC2_BCR] = { 0x14000 },
3516 [GCC_SDCC4_BCR] = { 0x16000 },
3517 [GCC_TSIF_BCR] = { 0x36000 },
3518 [GCC_UFS_CARD_BCR] = { 0x75000 },
3519 [GCC_UFS_PHY_BCR] = { 0x77000 },
3520 [GCC_USB30_PRIM_BCR] = { 0xf000 },
3521 [GCC_USB30_SEC_BCR] = { 0x10000 },
3522 [GCC_USB3_PHY_PRIM_BCR] = { 0x50000 },
3523 [GCC_USB3PHY_PHY_PRIM_BCR] = { 0x50004 },
3524 [GCC_USB3_DP_PHY_PRIM_BCR] = { 0x50008 },
3525 [GCC_USB3_PHY_SEC_BCR] = { 0x5000c },
3526 [GCC_USB3PHY_PHY_SEC_BCR] = { 0x50010 },
3527 [GCC_USB3_DP_PHY_SEC_BCR] = { 0x50014 },
3528 [GCC_USB_PHY_CFG_AHB2PHY_BCR] = { 0x6a000 },
3529 [GCC_PCIE_0_PHY_BCR] = { 0x6c01c },
3530 [GCC_PCIE_1_PHY_BCR] = { 0x8e01c },
3531 };
3532
3533 static struct gdsc *gcc_sdm845_gdscs[] = {
3534 [PCIE_0_GDSC] = &pcie_0_gdsc,
3535 [PCIE_1_GDSC] = &pcie_1_gdsc,
3536 [UFS_CARD_GDSC] = &ufs_card_gdsc,
3537 [UFS_PHY_GDSC] = &ufs_phy_gdsc,
3538 [USB30_PRIM_GDSC] = &usb30_prim_gdsc,
3539 [USB30_SEC_GDSC] = &usb30_sec_gdsc,
3540 [HLOS1_VOTE_AGGRE_NOC_MMU_AUDIO_TBU_GDSC] =
3541 &hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc,
3542 [HLOS1_VOTE_AGGRE_NOC_MMU_PCIE_TBU_GDSC] =
3543 &hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc,
3544 [HLOS1_VOTE_AGGRE_NOC_MMU_TBU1_GDSC] =
3545 &hlos1_vote_aggre_noc_mmu_tbu1_gdsc,
3546 [HLOS1_VOTE_AGGRE_NOC_MMU_TBU2_GDSC] =
3547 &hlos1_vote_aggre_noc_mmu_tbu2_gdsc,
3548 [HLOS1_VOTE_MMNOC_MMU_TBU_HF0_GDSC] =
3549 &hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc,
3550 [HLOS1_VOTE_MMNOC_MMU_TBU_HF1_GDSC] =
3551 &hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc,
3552 [HLOS1_VOTE_MMNOC_MMU_TBU_SF_GDSC] = &hlos1_vote_mmnoc_mmu_tbu_sf_gdsc,
3553 };
3554
3555 static const struct regmap_config gcc_sdm845_regmap_config = {
3556 .reg_bits = 32,
3557 .reg_stride = 4,
3558 .val_bits = 32,
3559 .max_register = 0x182090,
3560 .fast_io = true,
3561 };
3562
3563 static const struct qcom_cc_desc gcc_sdm845_desc = {
3564 .config = &gcc_sdm845_regmap_config,
3565 .clks = gcc_sdm845_clocks,
3566 .num_clks = ARRAY_SIZE(gcc_sdm845_clocks),
3567 .resets = gcc_sdm845_resets,
3568 .num_resets = ARRAY_SIZE(gcc_sdm845_resets),
3569 .gdscs = gcc_sdm845_gdscs,
3570 .num_gdscs = ARRAY_SIZE(gcc_sdm845_gdscs),
3571 };
3572
3573 static const struct of_device_id gcc_sdm845_match_table[] = {
3574 { .compatible = "qcom,gcc-sdm845" },
3575 { }
3576 };
3577 MODULE_DEVICE_TABLE(of, gcc_sdm845_match_table);
3578
3579 static const struct clk_rcg_dfs_data gcc_dfs_clocks[] = {
3580 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s0_clk),
3581 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s1_clk),
3582 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s2_clk),
3583 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s3_clk),
3584 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s4_clk),
3585 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s5_clk),
3586 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s6_clk),
3587 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s7_clk),
3588 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s0_clk),
3589 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s1_clk),
3590 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s2_clk),
3591 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s3_clk),
3592 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s4_clk),
3593 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s5_clk),
3594 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s6_clk),
3595 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s7_clk),
3596 };
3597
3598 static int gcc_sdm845_probe(struct platform_device *pdev)
3599 {
3600 struct regmap *regmap;
3601 int ret;
3602
3603 regmap = qcom_cc_map(pdev, &gcc_sdm845_desc);
3604 if (IS_ERR(regmap))
3605 return PTR_ERR(regmap);
3606
3607 /* Disable the GPLL0 active input to MMSS and GPU via MISC registers */
3608 regmap_update_bits(regmap, 0x09ffc, 0x3, 0x3);
3609 regmap_update_bits(regmap, 0x71028, 0x3, 0x3);
3610
3611 ret = qcom_cc_register_rcg_dfs(regmap, gcc_dfs_clocks,
3612 ARRAY_SIZE(gcc_dfs_clocks));
3613 if (ret)
3614 return ret;
3615
3616 return qcom_cc_really_probe(pdev, &gcc_sdm845_desc, regmap);
3617 }
3618
3619 static struct platform_driver gcc_sdm845_driver = {
3620 .probe = gcc_sdm845_probe,
3621 .driver = {
3622 .name = "gcc-sdm845",
3623 .of_match_table = gcc_sdm845_match_table,
3624 },
3625 };
3626
3627 static int __init gcc_sdm845_init(void)
3628 {
3629 return platform_driver_register(&gcc_sdm845_driver);
3630 }
3631 subsys_initcall(gcc_sdm845_init);
3632
3633 static void __exit gcc_sdm845_exit(void)
3634 {
3635 platform_driver_unregister(&gcc_sdm845_driver);
3636 }
3637 module_exit(gcc_sdm845_exit);
3638
3639 MODULE_DESCRIPTION("QTI GCC SDM845 Driver");
3640 MODULE_LICENSE("GPL v2");
3641 MODULE_ALIAS("platform:gcc-sdm845");