xref: /linux/drivers/clk/qcom/gcc-sm6125.c (revision 4d5e3b06e1fc1428be14cd4ebe3b37c1bb34f95d)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (c) 2021, Konrad Dybcio <konrad.dybcio@somainline.org>
4  */
5 
6 #include <linux/kernel.h>
7 #include <linux/err.h>
8 #include <linux/module.h>
9 #include <linux/platform_device.h>
10 #include <linux/of.h>
11 #include <linux/of_device.h>
12 #include <linux/clk-provider.h>
13 #include <linux/regmap.h>
14 #include <linux/reset-controller.h>
15 
16 #include <dt-bindings/clock/qcom,gcc-sm6125.h>
17 
18 #include "clk-alpha-pll.h"
19 #include "clk-branch.h"
20 #include "clk-rcg.h"
21 #include "clk-regmap.h"
22 #include "common.h"
23 #include "gdsc.h"
24 #include "reset.h"
25 
26 enum {
27 	P_BI_TCXO,
28 	P_GPLL0_OUT_AUX2,
29 	P_GPLL0_OUT_EARLY,
30 	P_GPLL3_OUT_EARLY,
31 	P_GPLL4_OUT_MAIN,
32 	P_GPLL5_OUT_MAIN,
33 	P_GPLL6_OUT_EARLY,
34 	P_GPLL6_OUT_MAIN,
35 	P_GPLL7_OUT_MAIN,
36 	P_GPLL8_OUT_EARLY,
37 	P_GPLL8_OUT_MAIN,
38 	P_GPLL9_OUT_MAIN,
39 	P_SLEEP_CLK,
40 };
41 
42 static struct clk_alpha_pll gpll0_out_early = {
43 	.offset = 0x0,
44 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
45 	.clkr = {
46 		.enable_reg = 0x79000,
47 		.enable_mask = BIT(0),
48 		.hw.init = &(struct clk_init_data){
49 			.name = "gpll0_out_early",
50 			.parent_data = &(const struct clk_parent_data){
51 				.fw_name = "bi_tcxo",
52 			},
53 			.num_parents = 1,
54 			.ops = &clk_alpha_pll_ops,
55 		},
56 	},
57 };
58 
59 static struct clk_fixed_factor gpll0_out_aux2 = {
60 	.mult = 1,
61 	.div = 2,
62 	.hw.init = &(struct clk_init_data){
63 		.name = "gpll0_out_aux2",
64 		.parent_hws = (const struct clk_hw*[]){
65 			&gpll0_out_early.clkr.hw,
66 		},
67 		.num_parents = 1,
68 		.ops = &clk_fixed_factor_ops,
69 	},
70 };
71 
72 static struct clk_fixed_factor gpll0_out_main = {
73 	.mult = 1,
74 	.div = 2,
75 	.hw.init = &(struct clk_init_data){
76 		.name = "gpll0_out_main",
77 		.parent_hws = (const struct clk_hw*[]){
78 			&gpll0_out_early.clkr.hw,
79 		},
80 		.num_parents = 1,
81 		.ops = &clk_fixed_factor_ops,
82 	},
83 };
84 
85 static struct clk_alpha_pll gpll3_out_early = {
86 	.offset = 0x3000,
87 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
88 	.clkr = {
89 		.enable_reg = 0x79000,
90 		.enable_mask = BIT(3),
91 		.hw.init = &(struct clk_init_data){
92 			.name = "gpll3_out_early",
93 			.parent_data = &(const struct clk_parent_data){
94 				.fw_name = "bi_tcxo",
95 			},
96 			.num_parents = 1,
97 			.ops = &clk_alpha_pll_ops,
98 		},
99 	},
100 };
101 
102 static struct clk_alpha_pll gpll4_out_main = {
103 	.offset = 0x4000,
104 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
105 	.clkr = {
106 		.enable_reg = 0x79000,
107 		.enable_mask = BIT(4),
108 		.hw.init = &(struct clk_init_data){
109 			.name = "gpll4_out_main",
110 			.parent_data = &(const struct clk_parent_data){
111 				.fw_name = "bi_tcxo",
112 			},
113 			.num_parents = 1,
114 			.ops = &clk_alpha_pll_ops,
115 		},
116 	},
117 };
118 
119 static struct clk_alpha_pll gpll5_out_main = {
120 	.offset = 0x5000,
121 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
122 	.clkr = {
123 		.enable_reg = 0x79000,
124 		.enable_mask = BIT(5),
125 		.hw.init = &(struct clk_init_data){
126 			.name = "gpll5_out_main",
127 			.parent_data = &(const struct clk_parent_data){
128 				.fw_name = "bi_tcxo",
129 			},
130 			.num_parents = 1,
131 			.ops = &clk_alpha_pll_ops,
132 		},
133 	},
134 };
135 
136 static struct clk_alpha_pll gpll6_out_early = {
137 	.offset = 0x6000,
138 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
139 	.clkr = {
140 		.enable_reg = 0x79000,
141 		.enable_mask = BIT(6),
142 		.hw.init = &(struct clk_init_data){
143 			.name = "gpll6_out_early",
144 			.parent_data = &(const struct clk_parent_data){
145 				.fw_name = "bi_tcxo",
146 			},
147 			.num_parents = 1,
148 			.ops = &clk_alpha_pll_ops,
149 		},
150 	},
151 };
152 
153 static struct clk_fixed_factor gpll6_out_main = {
154 	.mult = 1,
155 	.div = 2,
156 	.hw.init = &(struct clk_init_data){
157 		.name = "gpll6_out_main",
158 		.parent_hws = (const struct clk_hw*[]){
159 			&gpll6_out_early.clkr.hw,
160 		},
161 		.num_parents = 1,
162 		.ops = &clk_fixed_factor_ops,
163 	},
164 };
165 
166 static struct clk_alpha_pll gpll7_out_early = {
167 	.offset = 0x7000,
168 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
169 	.clkr = {
170 		.enable_reg = 0x79000,
171 		.enable_mask = BIT(7),
172 		.hw.init = &(struct clk_init_data){
173 			.name = "gpll7_out_early",
174 			.parent_data = &(const struct clk_parent_data){
175 				.fw_name = "bi_tcxo",
176 			},
177 			.num_parents = 1,
178 			.ops = &clk_alpha_pll_ops,
179 		},
180 	},
181 };
182 
183 static struct clk_fixed_factor gpll7_out_main = {
184 	.mult = 1,
185 	.div = 2,
186 	.hw.init = &(struct clk_init_data){
187 		.name = "gpll7_out_main",
188 		.parent_hws = (const struct clk_hw*[]){
189 			&gpll7_out_early.clkr.hw,
190 		},
191 		.num_parents = 1,
192 		.ops = &clk_fixed_factor_ops,
193 	},
194 };
195 
196 static struct clk_alpha_pll gpll8_out_early = {
197 	.offset = 0x8000,
198 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
199 	.clkr = {
200 		.enable_reg = 0x79000,
201 		.enable_mask = BIT(8),
202 		.hw.init = &(struct clk_init_data){
203 			.name = "gpll8_out_early",
204 			.parent_data = &(const struct clk_parent_data){
205 				.fw_name = "bi_tcxo",
206 			},
207 			.num_parents = 1,
208 			.ops = &clk_alpha_pll_ops,
209 		},
210 	},
211 };
212 
213 static struct clk_fixed_factor gpll8_out_main = {
214 	.mult = 1,
215 	.div = 2,
216 	.hw.init = &(struct clk_init_data){
217 		.name = "gpll8_out_main",
218 		.parent_hws = (const struct clk_hw*[]){
219 			&gpll8_out_early.clkr.hw,
220 		},
221 		.num_parents = 1,
222 		.ops = &clk_fixed_factor_ops,
223 	},
224 };
225 
226 static struct clk_alpha_pll gpll9_out_early = {
227 	.offset = 0x9000,
228 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
229 	.clkr = {
230 		.enable_reg = 0x79000,
231 		.enable_mask = BIT(9),
232 		.hw.init = &(struct clk_init_data){
233 			.name = "gpll9_out_early",
234 			.parent_data = &(const struct clk_parent_data){
235 				.fw_name = "bi_tcxo",
236 			},
237 			.num_parents = 1,
238 			.ops = &clk_alpha_pll_ops,
239 		},
240 	},
241 };
242 
243 static struct clk_fixed_factor gpll9_out_main = {
244 	.mult = 1,
245 	.div = 2,
246 	.hw.init = &(struct clk_init_data){
247 		.name = "gpll9_out_main",
248 		.parent_hws = (const struct clk_hw*[]){
249 			&gpll9_out_early.clkr.hw,
250 		},
251 		.num_parents = 1,
252 		.ops = &clk_fixed_factor_ops,
253 	},
254 };
255 
256 static const struct parent_map gcc_parent_map_0[] = {
257 	{ P_BI_TCXO, 0 },
258 	{ P_GPLL0_OUT_EARLY, 1 },
259 	{ P_GPLL0_OUT_AUX2, 2 },
260 };
261 
262 static const struct clk_parent_data gcc_parent_data_0[] = {
263 	{ .fw_name = "bi_tcxo" },
264 	{ .hw = &gpll0_out_early.clkr.hw },
265 	{ .hw = &gpll0_out_aux2.hw },
266 };
267 
268 static const struct parent_map gcc_parent_map_1[] = {
269 	{ P_BI_TCXO, 0 },
270 	{ P_GPLL0_OUT_EARLY, 1 },
271 	{ P_GPLL0_OUT_AUX2, 2 },
272 	{ P_GPLL6_OUT_MAIN, 4 },
273 };
274 
275 static const struct clk_parent_data gcc_parent_data_1[] = {
276 	{ .fw_name = "bi_tcxo" },
277 	{ .hw = &gpll0_out_early.clkr.hw },
278 	{ .hw = &gpll0_out_aux2.hw },
279 	{ .hw = &gpll6_out_main.hw },
280 };
281 
282 static const struct parent_map gcc_parent_map_2[] = {
283 	{ P_BI_TCXO, 0 },
284 	{ P_GPLL0_OUT_EARLY, 1 },
285 	{ P_GPLL0_OUT_AUX2, 2 },
286 	{ P_SLEEP_CLK, 5 },
287 };
288 
289 static const struct clk_parent_data gcc_parent_data_2[] = {
290 	{ .fw_name = "bi_tcxo" },
291 	{ .hw = &gpll0_out_early.clkr.hw },
292 	{ .hw = &gpll0_out_aux2.hw },
293 	{ .fw_name = "sleep_clk" },
294 };
295 
296 static const struct parent_map gcc_parent_map_3[] = {
297 	{ P_BI_TCXO, 0 },
298 	{ P_GPLL0_OUT_EARLY, 1 },
299 	{ P_GPLL5_OUT_MAIN, 3 },
300 	{ P_GPLL4_OUT_MAIN, 5 },
301 };
302 
303 static const struct clk_parent_data gcc_parent_data_3[] = {
304 	{ .fw_name = "bi_tcxo" },
305 	{ .hw = &gpll0_out_early.clkr.hw },
306 	{ .hw = &gpll5_out_main.clkr.hw },
307 	{ .hw = &gpll4_out_main.clkr.hw },
308 };
309 
310 static const struct parent_map gcc_parent_map_4[] = {
311 	{ P_BI_TCXO, 0 },
312 	{ P_GPLL0_OUT_EARLY, 1 },
313 	{ P_GPLL9_OUT_MAIN, 2 },
314 };
315 
316 static const struct clk_parent_data gcc_parent_data_4[] = {
317 	{ .fw_name = "bi_tcxo" },
318 	{ .hw = &gpll0_out_early.clkr.hw },
319 	{ .hw = &gpll9_out_main.hw },
320 };
321 
322 static const struct parent_map gcc_parent_map_5[] = {
323 	{ P_BI_TCXO, 0 },
324 	{ P_GPLL0_OUT_EARLY, 1 },
325 };
326 
327 static const struct clk_parent_data gcc_parent_data_5[] = {
328 	{ .fw_name = "bi_tcxo" },
329 	{ .hw = &gpll0_out_early.clkr.hw },
330 };
331 
332 static const struct parent_map gcc_parent_map_6[] = {
333 	{ P_BI_TCXO, 0 },
334 	{ P_GPLL0_OUT_EARLY, 1 },
335 	{ P_GPLL4_OUT_MAIN, 5 },
336 };
337 
338 static const struct clk_parent_data gcc_parent_data_6[] = {
339 	{ .fw_name = "bi_tcxo" },
340 	{ .hw = &gpll0_out_early.clkr.hw },
341 	{ .hw = &gpll4_out_main.clkr.hw },
342 };
343 
344 static const struct parent_map gcc_parent_map_7[] = {
345 	{ P_BI_TCXO, 0 },
346 	{ P_GPLL0_OUT_EARLY, 1 },
347 	{ P_SLEEP_CLK, 5 },
348 };
349 
350 static const struct clk_parent_data gcc_parent_data_7[] = {
351 	{ .fw_name = "bi_tcxo" },
352 	{ .hw = &gpll0_out_early.clkr.hw },
353 	{ .fw_name = "sleep_clk" },
354 };
355 
356 static const struct parent_map gcc_parent_map_8[] = {
357 	{ P_BI_TCXO, 0 },
358 	{ P_GPLL0_OUT_EARLY, 1 },
359 	{ P_GPLL9_OUT_MAIN, 2 },
360 	{ P_GPLL6_OUT_EARLY, 3 },
361 	{ P_GPLL8_OUT_MAIN, 4 },
362 	{ P_GPLL4_OUT_MAIN, 5 },
363 	{ P_GPLL3_OUT_EARLY, 6 },
364 };
365 
366 static const struct clk_parent_data gcc_parent_data_8[] = {
367 	{ .fw_name = "bi_tcxo" },
368 	{ .hw = &gpll0_out_early.clkr.hw },
369 	{ .hw = &gpll9_out_main.hw },
370 	{ .hw = &gpll6_out_early.clkr.hw },
371 	{ .hw = &gpll8_out_main.hw },
372 	{ .hw = &gpll4_out_main.clkr.hw },
373 	{ .hw = &gpll3_out_early.clkr.hw },
374 };
375 
376 static const struct parent_map gcc_parent_map_9[] = {
377 	{ P_BI_TCXO, 0 },
378 	{ P_GPLL0_OUT_EARLY, 1 },
379 	{ P_GPLL8_OUT_MAIN, 4 },
380 };
381 
382 static const struct clk_parent_data gcc_parent_data_9[] = {
383 	{ .fw_name = "bi_tcxo" },
384 	{ .hw = &gpll0_out_early.clkr.hw },
385 	{ .hw = &gpll8_out_main.hw },
386 };
387 
388 static const struct parent_map gcc_parent_map_10[] = {
389 	{ P_BI_TCXO, 0 },
390 	{ P_GPLL0_OUT_EARLY, 1 },
391 	{ P_GPLL9_OUT_MAIN, 2 },
392 	{ P_GPLL6_OUT_EARLY, 3 },
393 	{ P_GPLL8_OUT_MAIN, 4 },
394 	{ P_GPLL3_OUT_EARLY, 6 },
395 };
396 
397 static const struct clk_parent_data gcc_parent_data_10[] = {
398 	{ .fw_name = "bi_tcxo" },
399 	{ .hw = &gpll0_out_early.clkr.hw },
400 	{ .hw = &gpll9_out_main.hw },
401 	{ .hw = &gpll6_out_early.clkr.hw },
402 	{ .hw = &gpll8_out_main.hw },
403 	{ .hw = &gpll3_out_early.clkr.hw },
404 };
405 
406 static const struct parent_map gcc_parent_map_11[] = {
407 	{ P_BI_TCXO, 0 },
408 	{ P_GPLL0_OUT_EARLY, 1 },
409 	{ P_GPLL8_OUT_EARLY, 4 },
410 	{ P_GPLL4_OUT_MAIN, 5 },
411 };
412 
413 static const struct clk_parent_data gcc_parent_data_11[] = {
414 	{ .fw_name = "bi_tcxo" },
415 	{ .hw = &gpll0_out_early.clkr.hw },
416 	{ .hw = &gpll8_out_early.clkr.hw },
417 	{ .hw = &gpll4_out_main.clkr.hw },
418 };
419 
420 static const struct parent_map gcc_parent_map_12[] = {
421 	{ P_BI_TCXO, 0 },
422 	{ P_GPLL0_OUT_EARLY, 1 },
423 	{ P_GPLL6_OUT_EARLY, 3 },
424 	{ P_GPLL8_OUT_EARLY, 4 },
425 };
426 
427 static const struct clk_parent_data gcc_parent_data_12[] = {
428 	{ .fw_name = "bi_tcxo" },
429 	{ .hw = &gpll0_out_early.clkr.hw },
430 	{ .hw = &gpll6_out_early.clkr.hw },
431 	{ .hw = &gpll8_out_early.clkr.hw },
432 };
433 
434 static const struct parent_map gcc_parent_map_13[] = {
435 	{ P_BI_TCXO, 0 },
436 	{ P_GPLL0_OUT_EARLY, 1 },
437 	{ P_GPLL0_OUT_AUX2, 2 },
438 	{ P_GPLL7_OUT_MAIN, 3 },
439 	{ P_GPLL4_OUT_MAIN, 5 },
440 };
441 
442 static const struct clk_parent_data gcc_parent_data_13[] = {
443 	{ .fw_name = "bi_tcxo" },
444 	{ .hw = &gpll0_out_early.clkr.hw },
445 	{ .hw = &gpll0_out_aux2.hw },
446 	{ .hw = &gpll7_out_main.hw },
447 	{ .hw = &gpll4_out_main.clkr.hw },
448 };
449 
450 static const struct parent_map gcc_parent_map_14[] = {
451 	{ P_BI_TCXO, 0 },
452 	{ P_SLEEP_CLK, 5 },
453 };
454 
455 static const struct clk_parent_data gcc_parent_data_14[] = {
456 	{ .fw_name = "bi_tcxo" },
457 	{ .fw_name = "sleep_clk" },
458 };
459 
460 static const struct freq_tbl ftbl_gcc_camss_ahb_clk_src[] = {
461 	F(19200000, P_BI_TCXO, 1, 0, 0),
462 	F(40000000, P_GPLL8_OUT_MAIN, 12, 0, 0),
463 	F(80000000, P_GPLL8_OUT_MAIN, 6, 0, 0),
464 	{ }
465 };
466 
467 static struct clk_rcg2 gcc_camss_ahb_clk_src = {
468 	.cmd_rcgr = 0x56088,
469 	.mnd_width = 0,
470 	.hid_width = 5,
471 	.parent_map = gcc_parent_map_9,
472 	.freq_tbl = ftbl_gcc_camss_ahb_clk_src,
473 	.clkr.hw.init = &(struct clk_init_data){
474 		.name = "gcc_camss_ahb_clk_src",
475 		.parent_data = gcc_parent_data_9,
476 		.num_parents = ARRAY_SIZE(gcc_parent_data_9),
477 		.ops = &clk_rcg2_ops,
478 	},
479 };
480 
481 static const struct freq_tbl ftbl_gcc_camss_cci_clk_src[] = {
482 	F(37500000, P_GPLL0_OUT_EARLY, 16, 0, 0),
483 	F(50000000, P_GPLL0_OUT_EARLY, 12, 0, 0),
484 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
485 	{ }
486 };
487 
488 static struct clk_rcg2 gcc_camss_cci_clk_src = {
489 	.cmd_rcgr = 0x52004,
490 	.mnd_width = 8,
491 	.hid_width = 5,
492 	.parent_map = gcc_parent_map_5,
493 	.freq_tbl = ftbl_gcc_camss_cci_clk_src,
494 	.clkr.hw.init = &(struct clk_init_data){
495 		.name = "gcc_camss_cci_clk_src",
496 		.parent_data = gcc_parent_data_5,
497 		.num_parents = ARRAY_SIZE(gcc_parent_data_5),
498 		.ops = &clk_rcg2_ops,
499 	},
500 };
501 
502 static const struct freq_tbl ftbl_gcc_camss_cpp_clk_src[] = {
503 	F(120000000, P_GPLL8_OUT_MAIN, 4, 0, 0),
504 	F(240000000, P_GPLL8_OUT_MAIN, 2, 0, 0),
505 	F(320000000, P_GPLL8_OUT_MAIN, 1.5, 0, 0),
506 	F(480000000, P_GPLL8_OUT_MAIN, 1, 0, 0),
507 	F(576000000, P_GPLL9_OUT_MAIN, 1, 0, 0),
508 	{ }
509 };
510 
511 static struct clk_rcg2 gcc_camss_cpp_clk_src = {
512 	.cmd_rcgr = 0x560c8,
513 	.mnd_width = 0,
514 	.hid_width = 5,
515 	.parent_map = gcc_parent_map_10,
516 	.freq_tbl = ftbl_gcc_camss_cpp_clk_src,
517 	.clkr.hw.init = &(struct clk_init_data){
518 		.name = "gcc_camss_cpp_clk_src",
519 		.parent_data = gcc_parent_data_10,
520 		.num_parents = ARRAY_SIZE(gcc_parent_data_10),
521 		.ops = &clk_rcg2_ops,
522 	},
523 };
524 
525 static const struct freq_tbl ftbl_gcc_camss_csi0_clk_src[] = {
526 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
527 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
528 	F(311000000, P_GPLL5_OUT_MAIN, 3, 0, 0),
529 	F(403200000, P_GPLL4_OUT_MAIN, 2, 0, 0),
530 	F(466500000, P_GPLL5_OUT_MAIN, 2, 0, 0),
531 	{ }
532 };
533 
534 static struct clk_rcg2 gcc_camss_csi0_clk_src = {
535 	.cmd_rcgr = 0x55030,
536 	.mnd_width = 0,
537 	.hid_width = 5,
538 	.parent_map = gcc_parent_map_3,
539 	.freq_tbl = ftbl_gcc_camss_csi0_clk_src,
540 	.clkr.hw.init = &(struct clk_init_data){
541 		.name = "gcc_camss_csi0_clk_src",
542 		.parent_data = gcc_parent_data_3,
543 		.num_parents = ARRAY_SIZE(gcc_parent_data_3),
544 		.ops = &clk_rcg2_ops,
545 	},
546 };
547 
548 static const struct freq_tbl ftbl_gcc_camss_csi0phytimer_clk_src[] = {
549 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
550 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
551 	F(268800000, P_GPLL4_OUT_MAIN, 3, 0, 0),
552 	{ }
553 };
554 
555 static struct clk_rcg2 gcc_camss_csi0phytimer_clk_src = {
556 	.cmd_rcgr = 0x53004,
557 	.mnd_width = 0,
558 	.hid_width = 5,
559 	.parent_map = gcc_parent_map_6,
560 	.freq_tbl = ftbl_gcc_camss_csi0phytimer_clk_src,
561 	.clkr.hw.init = &(struct clk_init_data){
562 		.name = "gcc_camss_csi0phytimer_clk_src",
563 		.parent_data = gcc_parent_data_6,
564 		.num_parents = ARRAY_SIZE(gcc_parent_data_6),
565 		.ops = &clk_rcg2_ops,
566 	},
567 };
568 
569 static struct clk_rcg2 gcc_camss_csi1_clk_src = {
570 	.cmd_rcgr = 0x5506c,
571 	.mnd_width = 0,
572 	.hid_width = 5,
573 	.parent_map = gcc_parent_map_3,
574 	.freq_tbl = ftbl_gcc_camss_csi0_clk_src,
575 	.clkr.hw.init = &(struct clk_init_data){
576 		.name = "gcc_camss_csi1_clk_src",
577 		.parent_data = gcc_parent_data_3,
578 		.num_parents = ARRAY_SIZE(gcc_parent_data_3),
579 		.ops = &clk_rcg2_ops,
580 	},
581 };
582 
583 static struct clk_rcg2 gcc_camss_csi1phytimer_clk_src = {
584 	.cmd_rcgr = 0x53024,
585 	.mnd_width = 0,
586 	.hid_width = 5,
587 	.parent_map = gcc_parent_map_6,
588 	.freq_tbl = ftbl_gcc_camss_csi0phytimer_clk_src,
589 	.clkr.hw.init = &(struct clk_init_data){
590 		.name = "gcc_camss_csi1phytimer_clk_src",
591 		.parent_data = gcc_parent_data_6,
592 		.num_parents = ARRAY_SIZE(gcc_parent_data_6),
593 		.ops = &clk_rcg2_ops,
594 	},
595 };
596 
597 static struct clk_rcg2 gcc_camss_csi2_clk_src = {
598 	.cmd_rcgr = 0x550a4,
599 	.mnd_width = 0,
600 	.hid_width = 5,
601 	.parent_map = gcc_parent_map_3,
602 	.freq_tbl = ftbl_gcc_camss_csi0_clk_src,
603 	.clkr.hw.init = &(struct clk_init_data){
604 		.name = "gcc_camss_csi2_clk_src",
605 		.parent_data = gcc_parent_data_3,
606 		.num_parents = ARRAY_SIZE(gcc_parent_data_3),
607 		.ops = &clk_rcg2_ops,
608 	},
609 };
610 
611 static struct clk_rcg2 gcc_camss_csi2phytimer_clk_src = {
612 	.cmd_rcgr = 0x53044,
613 	.mnd_width = 0,
614 	.hid_width = 5,
615 	.parent_map = gcc_parent_map_6,
616 	.freq_tbl = ftbl_gcc_camss_csi0phytimer_clk_src,
617 	.clkr.hw.init = &(struct clk_init_data){
618 		.name = "gcc_camss_csi2phytimer_clk_src",
619 		.parent_data = gcc_parent_data_6,
620 		.num_parents = ARRAY_SIZE(gcc_parent_data_6),
621 		.ops = &clk_rcg2_ops,
622 	},
623 };
624 
625 static struct clk_rcg2 gcc_camss_csi3_clk_src = {
626 	.cmd_rcgr = 0x550e0,
627 	.mnd_width = 0,
628 	.hid_width = 5,
629 	.parent_map = gcc_parent_map_3,
630 	.freq_tbl = ftbl_gcc_camss_csi0_clk_src,
631 	.clkr.hw.init = &(struct clk_init_data){
632 		.name = "gcc_camss_csi3_clk_src",
633 		.parent_data = gcc_parent_data_3,
634 		.num_parents = ARRAY_SIZE(gcc_parent_data_3),
635 		.ops = &clk_rcg2_ops,
636 	},
637 };
638 
639 static const struct freq_tbl ftbl_gcc_camss_csiphy_clk_src[] = {
640 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
641 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
642 	F(268800000, P_GPLL4_OUT_MAIN, 3, 0, 0),
643 	F(320000000, P_GPLL8_OUT_EARLY, 3, 0, 0),
644 	{ }
645 };
646 
647 static struct clk_rcg2 gcc_camss_csiphy_clk_src = {
648 	.cmd_rcgr = 0x55000,
649 	.mnd_width = 0,
650 	.hid_width = 5,
651 	.parent_map = gcc_parent_map_11,
652 	.freq_tbl = ftbl_gcc_camss_csiphy_clk_src,
653 	.clkr.hw.init = &(struct clk_init_data){
654 		.name = "gcc_camss_csiphy_clk_src",
655 		.parent_data = gcc_parent_data_11,
656 		.num_parents = ARRAY_SIZE(gcc_parent_data_11),
657 		.ops = &clk_rcg2_ops,
658 	},
659 };
660 
661 static const struct freq_tbl ftbl_gcc_camss_gp0_clk_src[] = {
662 	F(50000000, P_GPLL0_OUT_EARLY, 12, 0, 0),
663 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
664 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
665 	{ }
666 };
667 
668 static struct clk_rcg2 gcc_camss_gp0_clk_src = {
669 	.cmd_rcgr = 0x50000,
670 	.mnd_width = 8,
671 	.hid_width = 5,
672 	.parent_map = gcc_parent_map_7,
673 	.freq_tbl = ftbl_gcc_camss_gp0_clk_src,
674 	.clkr.hw.init = &(struct clk_init_data){
675 		.name = "gcc_camss_gp0_clk_src",
676 		.parent_data = gcc_parent_data_7,
677 		.num_parents = ARRAY_SIZE(gcc_parent_data_7),
678 		.ops = &clk_rcg2_ops,
679 	},
680 };
681 
682 static struct clk_rcg2 gcc_camss_gp1_clk_src = {
683 	.cmd_rcgr = 0x5001c,
684 	.mnd_width = 8,
685 	.hid_width = 5,
686 	.parent_map = gcc_parent_map_7,
687 	.freq_tbl = ftbl_gcc_camss_gp0_clk_src,
688 	.clkr.hw.init = &(struct clk_init_data){
689 		.name = "gcc_camss_gp1_clk_src",
690 		.parent_data = gcc_parent_data_7,
691 		.num_parents = ARRAY_SIZE(gcc_parent_data_7),
692 		.ops = &clk_rcg2_ops,
693 	},
694 };
695 
696 static const struct freq_tbl ftbl_gcc_camss_jpeg_clk_src[] = {
697 	F(66666667, P_GPLL0_OUT_EARLY, 9, 0, 0),
698 	F(133333333, P_GPLL0_OUT_EARLY, 4.5, 0, 0),
699 	F(219428571, P_GPLL6_OUT_EARLY, 3.5, 0, 0),
700 	F(320000000, P_GPLL8_OUT_EARLY, 3, 0, 0),
701 	F(480000000, P_GPLL8_OUT_EARLY, 2, 0, 0),
702 	{ }
703 };
704 
705 static struct clk_rcg2 gcc_camss_jpeg_clk_src = {
706 	.cmd_rcgr = 0x52028,
707 	.mnd_width = 0,
708 	.hid_width = 5,
709 	.parent_map = gcc_parent_map_12,
710 	.freq_tbl = ftbl_gcc_camss_jpeg_clk_src,
711 	.clkr.hw.init = &(struct clk_init_data){
712 		.name = "gcc_camss_jpeg_clk_src",
713 		.parent_data = gcc_parent_data_12,
714 		.num_parents = ARRAY_SIZE(gcc_parent_data_12),
715 		.ops = &clk_rcg2_ops,
716 	},
717 };
718 
719 static const struct freq_tbl ftbl_gcc_camss_mclk0_clk_src[] = {
720 	F(19200000, P_BI_TCXO, 1, 0, 0),
721 	F(24000000, P_GPLL9_OUT_MAIN, 1, 1, 24),
722 	F(64000000, P_GPLL9_OUT_MAIN, 1, 1, 9),
723 	{ }
724 };
725 
726 static struct clk_rcg2 gcc_camss_mclk0_clk_src = {
727 	.cmd_rcgr = 0x51000,
728 	.mnd_width = 8,
729 	.hid_width = 5,
730 	.parent_map = gcc_parent_map_4,
731 	.freq_tbl = ftbl_gcc_camss_mclk0_clk_src,
732 	.clkr.hw.init = &(struct clk_init_data){
733 		.name = "gcc_camss_mclk0_clk_src",
734 		.parent_data = gcc_parent_data_4,
735 		.num_parents = ARRAY_SIZE(gcc_parent_data_4),
736 		.ops = &clk_rcg2_ops,
737 	},
738 };
739 
740 static struct clk_rcg2 gcc_camss_mclk1_clk_src = {
741 	.cmd_rcgr = 0x5101c,
742 	.mnd_width = 8,
743 	.hid_width = 5,
744 	.parent_map = gcc_parent_map_4,
745 	.freq_tbl = ftbl_gcc_camss_mclk0_clk_src,
746 	.clkr.hw.init = &(struct clk_init_data){
747 		.name = "gcc_camss_mclk1_clk_src",
748 		.parent_data = gcc_parent_data_4,
749 		.num_parents = ARRAY_SIZE(gcc_parent_data_4),
750 		.ops = &clk_rcg2_ops,
751 	},
752 };
753 
754 static struct clk_rcg2 gcc_camss_mclk2_clk_src = {
755 	.cmd_rcgr = 0x51038,
756 	.mnd_width = 8,
757 	.hid_width = 5,
758 	.parent_map = gcc_parent_map_4,
759 	.freq_tbl = ftbl_gcc_camss_mclk0_clk_src,
760 	.clkr.hw.init = &(struct clk_init_data){
761 		.name = "gcc_camss_mclk2_clk_src",
762 		.parent_data = gcc_parent_data_4,
763 		.num_parents = ARRAY_SIZE(gcc_parent_data_4),
764 		.ops = &clk_rcg2_ops,
765 	},
766 };
767 
768 static struct clk_rcg2 gcc_camss_mclk3_clk_src = {
769 	.cmd_rcgr = 0x51054,
770 	.mnd_width = 8,
771 	.hid_width = 5,
772 	.parent_map = gcc_parent_map_4,
773 	.freq_tbl = ftbl_gcc_camss_mclk0_clk_src,
774 	.clkr.hw.init = &(struct clk_init_data){
775 		.name = "gcc_camss_mclk3_clk_src",
776 		.parent_data = gcc_parent_data_4,
777 		.num_parents = ARRAY_SIZE(gcc_parent_data_4),
778 		.ops = &clk_rcg2_ops,
779 	},
780 };
781 
782 static const struct freq_tbl ftbl_gcc_camss_vfe0_clk_src[] = {
783 	F(120000000, P_GPLL8_OUT_MAIN, 4, 0, 0),
784 	F(256000000, P_GPLL6_OUT_EARLY, 3, 0, 0),
785 	F(403200000, P_GPLL4_OUT_MAIN, 2, 0, 0),
786 	F(480000000, P_GPLL8_OUT_MAIN, 1, 0, 0),
787 	F(533000000, P_GPLL3_OUT_EARLY, 2, 0, 0),
788 	F(576000000, P_GPLL9_OUT_MAIN, 1, 0, 0),
789 	{ }
790 };
791 
792 static struct clk_rcg2 gcc_camss_vfe0_clk_src = {
793 	.cmd_rcgr = 0x54010,
794 	.mnd_width = 0,
795 	.hid_width = 5,
796 	.parent_map = gcc_parent_map_8,
797 	.freq_tbl = ftbl_gcc_camss_vfe0_clk_src,
798 	.clkr.hw.init = &(struct clk_init_data){
799 		.name = "gcc_camss_vfe0_clk_src",
800 		.parent_data = gcc_parent_data_8,
801 		.num_parents = ARRAY_SIZE(gcc_parent_data_8),
802 		.ops = &clk_rcg2_ops,
803 	},
804 };
805 
806 static struct clk_rcg2 gcc_camss_vfe1_clk_src = {
807 	.cmd_rcgr = 0x54048,
808 	.mnd_width = 0,
809 	.hid_width = 5,
810 	.parent_map = gcc_parent_map_8,
811 	.freq_tbl = ftbl_gcc_camss_vfe0_clk_src,
812 	.clkr.hw.init = &(struct clk_init_data){
813 		.name = "gcc_camss_vfe1_clk_src",
814 		.parent_data = gcc_parent_data_8,
815 		.num_parents = ARRAY_SIZE(gcc_parent_data_8),
816 		.ops = &clk_rcg2_ops,
817 	},
818 };
819 
820 static const struct freq_tbl ftbl_gcc_gp1_clk_src[] = {
821 	F(25000000, P_GPLL0_OUT_AUX2, 12, 0, 0),
822 	F(50000000, P_GPLL0_OUT_AUX2, 6, 0, 0),
823 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
824 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
825 	{ }
826 };
827 
828 static struct clk_rcg2 gcc_gp1_clk_src = {
829 	.cmd_rcgr = 0x4d004,
830 	.mnd_width = 8,
831 	.hid_width = 5,
832 	.parent_map = gcc_parent_map_2,
833 	.freq_tbl = ftbl_gcc_gp1_clk_src,
834 	.clkr.hw.init = &(struct clk_init_data){
835 		.name = "gcc_gp1_clk_src",
836 		.parent_data = gcc_parent_data_2,
837 		.num_parents = ARRAY_SIZE(gcc_parent_data_2),
838 		.ops = &clk_rcg2_ops,
839 	},
840 };
841 
842 static struct clk_rcg2 gcc_gp2_clk_src = {
843 	.cmd_rcgr = 0x4e004,
844 	.mnd_width = 8,
845 	.hid_width = 5,
846 	.parent_map = gcc_parent_map_2,
847 	.freq_tbl = ftbl_gcc_gp1_clk_src,
848 	.clkr.hw.init = &(struct clk_init_data){
849 		.name = "gcc_gp2_clk_src",
850 		.parent_data = gcc_parent_data_2,
851 		.num_parents = ARRAY_SIZE(gcc_parent_data_2),
852 		.ops = &clk_rcg2_ops,
853 	},
854 };
855 
856 static struct clk_rcg2 gcc_gp3_clk_src = {
857 	.cmd_rcgr = 0x4f004,
858 	.mnd_width = 8,
859 	.hid_width = 5,
860 	.parent_map = gcc_parent_map_2,
861 	.freq_tbl = ftbl_gcc_gp1_clk_src,
862 	.clkr.hw.init = &(struct clk_init_data){
863 		.name = "gcc_gp3_clk_src",
864 		.parent_data = gcc_parent_data_2,
865 		.num_parents = ARRAY_SIZE(gcc_parent_data_2),
866 		.ops = &clk_rcg2_ops,
867 	},
868 };
869 
870 static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = {
871 	F(19200000, P_BI_TCXO, 1, 0, 0),
872 	F(60000000, P_GPLL0_OUT_EARLY, 10, 0, 0),
873 	{ }
874 };
875 
876 static struct clk_rcg2 gcc_pdm2_clk_src = {
877 	.cmd_rcgr = 0x20010,
878 	.mnd_width = 0,
879 	.hid_width = 5,
880 	.parent_map = gcc_parent_map_0,
881 	.freq_tbl = ftbl_gcc_pdm2_clk_src,
882 	.clkr.hw.init = &(struct clk_init_data){
883 		.name = "gcc_pdm2_clk_src",
884 		.parent_data = gcc_parent_data_0,
885 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
886 		.ops = &clk_rcg2_ops,
887 	},
888 };
889 
890 static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s0_clk_src[] = {
891 	F(7372800, P_GPLL0_OUT_AUX2, 1, 384, 15625),
892 	F(14745600, P_GPLL0_OUT_AUX2, 1, 768, 15625),
893 	F(19200000, P_BI_TCXO, 1, 0, 0),
894 	F(29491200, P_GPLL0_OUT_AUX2, 1, 1536, 15625),
895 	F(32000000, P_GPLL0_OUT_AUX2, 1, 8, 75),
896 	F(48000000, P_GPLL0_OUT_AUX2, 1, 4, 25),
897 	F(64000000, P_GPLL0_OUT_AUX2, 1, 16, 75),
898 	F(75000000, P_GPLL0_OUT_AUX2, 4, 0, 0),
899 	F(80000000, P_GPLL0_OUT_AUX2, 1, 4, 15),
900 	F(96000000, P_GPLL0_OUT_AUX2, 1, 8, 25),
901 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
902 	F(102400000, P_GPLL0_OUT_AUX2, 1, 128, 375),
903 	F(112000000, P_GPLL0_OUT_AUX2, 1, 28, 75),
904 	F(117964800, P_GPLL0_OUT_AUX2, 1, 6144, 15625),
905 	F(120000000, P_GPLL0_OUT_AUX2, 2.5, 0, 0),
906 	F(128000000, P_GPLL6_OUT_MAIN, 3, 0, 0),
907 	{ }
908 };
909 
910 static struct clk_init_data gcc_qupv3_wrap0_s0_clk_src_init = {
911 	.name = "gcc_qupv3_wrap0_s0_clk_src",
912 	.parent_data = gcc_parent_data_1,
913 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
914 	.ops = &clk_rcg2_ops,
915 };
916 
917 static struct clk_rcg2 gcc_qupv3_wrap0_s0_clk_src = {
918 	.cmd_rcgr = 0x1f148,
919 	.mnd_width = 16,
920 	.hid_width = 5,
921 	.parent_map = gcc_parent_map_1,
922 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
923 	.clkr.hw.init = &gcc_qupv3_wrap0_s0_clk_src_init,
924 };
925 
926 static struct clk_init_data gcc_qupv3_wrap0_s1_clk_src_init = {
927 	.name = "gcc_qupv3_wrap0_s1_clk_src",
928 	.parent_data = gcc_parent_data_1,
929 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
930 	.ops = &clk_rcg2_ops,
931 };
932 
933 static struct clk_rcg2 gcc_qupv3_wrap0_s1_clk_src = {
934 	.cmd_rcgr = 0x1f278,
935 	.mnd_width = 16,
936 	.hid_width = 5,
937 	.parent_map = gcc_parent_map_1,
938 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
939 	.clkr.hw.init = &gcc_qupv3_wrap0_s1_clk_src_init,
940 };
941 
942 static struct clk_init_data gcc_qupv3_wrap0_s2_clk_src_init = {
943 	.name = "gcc_qupv3_wrap0_s2_clk_src",
944 	.parent_data = gcc_parent_data_1,
945 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
946 	.ops = &clk_rcg2_ops,
947 };
948 
949 static struct clk_rcg2 gcc_qupv3_wrap0_s2_clk_src = {
950 	.cmd_rcgr = 0x1f3a8,
951 	.mnd_width = 16,
952 	.hid_width = 5,
953 	.parent_map = gcc_parent_map_1,
954 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
955 	.clkr.hw.init = &gcc_qupv3_wrap0_s2_clk_src_init,
956 };
957 
958 static struct clk_init_data gcc_qupv3_wrap0_s3_clk_src_init = {
959 	.name = "gcc_qupv3_wrap0_s3_clk_src",
960 	.parent_data = gcc_parent_data_1,
961 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
962 	.ops = &clk_rcg2_ops,
963 };
964 
965 static struct clk_rcg2 gcc_qupv3_wrap0_s3_clk_src = {
966 	.cmd_rcgr = 0x1f4d8,
967 	.mnd_width = 16,
968 	.hid_width = 5,
969 	.parent_map = gcc_parent_map_1,
970 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
971 	.clkr.hw.init = &gcc_qupv3_wrap0_s3_clk_src_init,
972 };
973 
974 static struct clk_init_data gcc_qupv3_wrap0_s4_clk_src_init = {
975 	.name = "gcc_qupv3_wrap0_s4_clk_src",
976 	.parent_data = gcc_parent_data_1,
977 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
978 	.ops = &clk_rcg2_ops,
979 };
980 
981 static struct clk_rcg2 gcc_qupv3_wrap0_s4_clk_src = {
982 	.cmd_rcgr = 0x1f608,
983 	.mnd_width = 16,
984 	.hid_width = 5,
985 	.parent_map = gcc_parent_map_1,
986 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
987 	.clkr.hw.init = &gcc_qupv3_wrap0_s4_clk_src_init,
988 };
989 
990 static struct clk_init_data gcc_qupv3_wrap0_s5_clk_src_init = {
991 	.name = "gcc_qupv3_wrap0_s5_clk_src",
992 	.parent_data = gcc_parent_data_1,
993 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
994 	.ops = &clk_rcg2_ops,
995 };
996 
997 static struct clk_rcg2 gcc_qupv3_wrap0_s5_clk_src = {
998 	.cmd_rcgr = 0x1f738,
999 	.mnd_width = 16,
1000 	.hid_width = 5,
1001 	.parent_map = gcc_parent_map_1,
1002 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
1003 	.clkr.hw.init = &gcc_qupv3_wrap0_s5_clk_src_init,
1004 };
1005 
1006 static struct clk_init_data gcc_qupv3_wrap1_s0_clk_src_init = {
1007 	.name = "gcc_qupv3_wrap1_s0_clk_src",
1008 	.parent_data = gcc_parent_data_1,
1009 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
1010 	.ops = &clk_rcg2_ops,
1011 };
1012 
1013 static struct clk_rcg2 gcc_qupv3_wrap1_s0_clk_src = {
1014 	.cmd_rcgr = 0x39148,
1015 	.mnd_width = 16,
1016 	.hid_width = 5,
1017 	.parent_map = gcc_parent_map_1,
1018 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
1019 	.clkr.hw.init = &gcc_qupv3_wrap1_s0_clk_src_init,
1020 };
1021 
1022 static struct clk_init_data gcc_qupv3_wrap1_s1_clk_src_init = {
1023 	.name = "gcc_qupv3_wrap1_s1_clk_src",
1024 	.parent_data = gcc_parent_data_1,
1025 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
1026 	.ops = &clk_rcg2_ops,
1027 };
1028 
1029 static struct clk_rcg2 gcc_qupv3_wrap1_s1_clk_src = {
1030 	.cmd_rcgr = 0x39278,
1031 	.mnd_width = 16,
1032 	.hid_width = 5,
1033 	.parent_map = gcc_parent_map_1,
1034 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
1035 	.clkr.hw.init = &gcc_qupv3_wrap1_s1_clk_src_init,
1036 };
1037 
1038 static struct clk_init_data gcc_qupv3_wrap1_s2_clk_src_init = {
1039 	.name = "gcc_qupv3_wrap1_s2_clk_src",
1040 	.parent_data = gcc_parent_data_1,
1041 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
1042 	.ops = &clk_rcg2_ops,
1043 };
1044 
1045 static struct clk_rcg2 gcc_qupv3_wrap1_s2_clk_src = {
1046 	.cmd_rcgr = 0x393a8,
1047 	.mnd_width = 16,
1048 	.hid_width = 5,
1049 	.parent_map = gcc_parent_map_1,
1050 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
1051 	.clkr.hw.init = &gcc_qupv3_wrap1_s2_clk_src_init,
1052 };
1053 
1054 static struct clk_init_data gcc_qupv3_wrap1_s3_clk_src_init = {
1055 	.name = "gcc_qupv3_wrap1_s3_clk_src",
1056 	.parent_data = gcc_parent_data_1,
1057 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
1058 	.ops = &clk_rcg2_ops,
1059 };
1060 
1061 static struct clk_rcg2 gcc_qupv3_wrap1_s3_clk_src = {
1062 	.cmd_rcgr = 0x394d8,
1063 	.mnd_width = 16,
1064 	.hid_width = 5,
1065 	.parent_map = gcc_parent_map_1,
1066 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
1067 	.clkr.hw.init = &gcc_qupv3_wrap1_s3_clk_src_init,
1068 };
1069 
1070 static struct clk_init_data gcc_qupv3_wrap1_s4_clk_src_init = {
1071 	.name = "gcc_qupv3_wrap1_s4_clk_src",
1072 	.parent_data = gcc_parent_data_1,
1073 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
1074 	.ops = &clk_rcg2_ops,
1075 };
1076 
1077 static struct clk_rcg2 gcc_qupv3_wrap1_s4_clk_src = {
1078 	.cmd_rcgr = 0x39608,
1079 	.mnd_width = 16,
1080 	.hid_width = 5,
1081 	.parent_map = gcc_parent_map_1,
1082 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
1083 	.clkr.hw.init = &gcc_qupv3_wrap1_s4_clk_src_init,
1084 };
1085 
1086 static struct clk_init_data gcc_qupv3_wrap1_s5_clk_src_init = {
1087 	.name = "gcc_qupv3_wrap1_s5_clk_src",
1088 	.parent_data = gcc_parent_data_1,
1089 	.num_parents = ARRAY_SIZE(gcc_parent_data_1),
1090 	.ops = &clk_rcg2_ops,
1091 };
1092 
1093 static struct clk_rcg2 gcc_qupv3_wrap1_s5_clk_src = {
1094 	.cmd_rcgr = 0x39738,
1095 	.mnd_width = 16,
1096 	.hid_width = 5,
1097 	.parent_map = gcc_parent_map_1,
1098 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
1099 	.clkr.hw.init = &gcc_qupv3_wrap1_s5_clk_src_init,
1100 };
1101 
1102 static const struct freq_tbl ftbl_gcc_sdcc1_apps_clk_src[] = {
1103 	F(144000, P_BI_TCXO, 16, 3, 25),
1104 	F(400000, P_BI_TCXO, 12, 1, 4),
1105 	F(20000000, P_GPLL0_OUT_AUX2, 5, 1, 3),
1106 	F(25000000, P_GPLL0_OUT_AUX2, 6, 1, 2),
1107 	F(50000000, P_GPLL0_OUT_AUX2, 6, 0, 0),
1108 	F(100000000, P_GPLL0_OUT_AUX2, 3, 0, 0),
1109 	F(192000000, P_GPLL6_OUT_MAIN, 2, 0, 0),
1110 	F(384000000, P_GPLL6_OUT_MAIN, 1, 0, 0),
1111 	{ }
1112 };
1113 
1114 static struct clk_rcg2 gcc_sdcc1_apps_clk_src = {
1115 	.cmd_rcgr = 0x38028,
1116 	.mnd_width = 8,
1117 	.hid_width = 5,
1118 	.parent_map = gcc_parent_map_1,
1119 	.freq_tbl = ftbl_gcc_sdcc1_apps_clk_src,
1120 	.clkr.hw.init = &(struct clk_init_data){
1121 		.name = "gcc_sdcc1_apps_clk_src",
1122 		.parent_data = gcc_parent_data_1,
1123 		.num_parents = ARRAY_SIZE(gcc_parent_data_1),
1124 		.ops = &clk_rcg2_floor_ops,
1125 	},
1126 };
1127 
1128 static const struct freq_tbl ftbl_gcc_sdcc1_ice_core_clk_src[] = {
1129 	F(75000000, P_GPLL0_OUT_AUX2, 4, 0, 0),
1130 	F(150000000, P_GPLL0_OUT_EARLY, 4, 0, 0),
1131 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
1132 	F(300000000, P_GPLL0_OUT_EARLY, 2, 0, 0),
1133 	{ }
1134 };
1135 
1136 static struct clk_rcg2 gcc_sdcc1_ice_core_clk_src = {
1137 	.cmd_rcgr = 0x38010,
1138 	.mnd_width = 0,
1139 	.hid_width = 5,
1140 	.parent_map = gcc_parent_map_0,
1141 	.freq_tbl = ftbl_gcc_sdcc1_ice_core_clk_src,
1142 	.clkr.hw.init = &(struct clk_init_data){
1143 		.name = "gcc_sdcc1_ice_core_clk_src",
1144 		.parent_data = gcc_parent_data_0,
1145 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
1146 		.ops = &clk_rcg2_ops,
1147 	},
1148 };
1149 
1150 static const struct freq_tbl ftbl_gcc_sdcc2_apps_clk_src[] = {
1151 	F(400000, P_BI_TCXO, 12, 1, 4),
1152 	F(19200000, P_BI_TCXO, 1, 0, 0),
1153 	F(25000000, P_GPLL0_OUT_AUX2, 12, 0, 0),
1154 	F(50000000, P_GPLL0_OUT_AUX2, 6, 0, 0),
1155 	F(100000000, P_GPLL0_OUT_AUX2, 3, 0, 0),
1156 	F(202000000, P_GPLL7_OUT_MAIN, 2, 0, 0),
1157 	{ }
1158 };
1159 
1160 static struct clk_rcg2 gcc_sdcc2_apps_clk_src = {
1161 	.cmd_rcgr = 0x1e00c,
1162 	.mnd_width = 8,
1163 	.hid_width = 5,
1164 	.parent_map = gcc_parent_map_13,
1165 	.freq_tbl = ftbl_gcc_sdcc2_apps_clk_src,
1166 	.clkr.hw.init = &(struct clk_init_data){
1167 		.name = "gcc_sdcc2_apps_clk_src",
1168 		.parent_data = gcc_parent_data_13,
1169 		.num_parents = ARRAY_SIZE(gcc_parent_data_13),
1170 		.ops = &clk_rcg2_floor_ops,
1171 	},
1172 };
1173 
1174 static const struct freq_tbl ftbl_gcc_ufs_phy_axi_clk_src[] = {
1175 	F(25000000, P_GPLL0_OUT_AUX2, 12, 0, 0),
1176 	F(50000000, P_GPLL0_OUT_AUX2, 6, 0, 0),
1177 	F(100000000, P_GPLL0_OUT_EARLY, 6, 0, 0),
1178 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
1179 	F(240000000, P_GPLL0_OUT_EARLY, 2.5, 0, 0),
1180 	{ }
1181 };
1182 
1183 static struct clk_rcg2 gcc_ufs_phy_axi_clk_src = {
1184 	.cmd_rcgr = 0x45020,
1185 	.mnd_width = 8,
1186 	.hid_width = 5,
1187 	.parent_map = gcc_parent_map_0,
1188 	.freq_tbl = ftbl_gcc_ufs_phy_axi_clk_src,
1189 	.clkr.hw.init = &(struct clk_init_data){
1190 		.name = "gcc_ufs_phy_axi_clk_src",
1191 		.parent_data = gcc_parent_data_0,
1192 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
1193 		.ops = &clk_rcg2_ops,
1194 	},
1195 };
1196 
1197 static const struct freq_tbl ftbl_gcc_ufs_phy_ice_core_clk_src[] = {
1198 	F(37500000, P_GPLL0_OUT_AUX2, 8, 0, 0),
1199 	F(75000000, P_GPLL0_OUT_AUX2, 4, 0, 0),
1200 	F(150000000, P_GPLL0_OUT_EARLY, 4, 0, 0),
1201 	F(300000000, P_GPLL0_OUT_EARLY, 2, 0, 0),
1202 	{ }
1203 };
1204 
1205 static struct clk_rcg2 gcc_ufs_phy_ice_core_clk_src = {
1206 	.cmd_rcgr = 0x45048,
1207 	.mnd_width = 0,
1208 	.hid_width = 5,
1209 	.parent_map = gcc_parent_map_0,
1210 	.freq_tbl = ftbl_gcc_ufs_phy_ice_core_clk_src,
1211 	.clkr.hw.init = &(struct clk_init_data){
1212 		.name = "gcc_ufs_phy_ice_core_clk_src",
1213 		.parent_data = gcc_parent_data_0,
1214 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
1215 		.ops = &clk_rcg2_ops,
1216 	},
1217 };
1218 
1219 static const struct freq_tbl ftbl_gcc_ufs_phy_phy_aux_clk_src[] = {
1220 	F(9600000, P_BI_TCXO, 2, 0, 0),
1221 	F(19200000, P_BI_TCXO, 1, 0, 0),
1222 	{ }
1223 };
1224 
1225 static struct clk_rcg2 gcc_ufs_phy_phy_aux_clk_src = {
1226 	.cmd_rcgr = 0x4507c,
1227 	.mnd_width = 0,
1228 	.hid_width = 5,
1229 	.parent_map = gcc_parent_map_0,
1230 	.freq_tbl = ftbl_gcc_ufs_phy_phy_aux_clk_src,
1231 	.clkr.hw.init = &(struct clk_init_data){
1232 		.name = "gcc_ufs_phy_phy_aux_clk_src",
1233 		.parent_data = gcc_parent_data_0,
1234 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
1235 		.ops = &clk_rcg2_ops,
1236 	},
1237 };
1238 
1239 static const struct freq_tbl ftbl_gcc_ufs_phy_unipro_core_clk_src[] = {
1240 	F(37500000, P_GPLL0_OUT_AUX2, 8, 0, 0),
1241 	F(75000000, P_GPLL0_OUT_EARLY, 8, 0, 0),
1242 	F(150000000, P_GPLL0_OUT_EARLY, 4, 0, 0),
1243 	{ }
1244 };
1245 
1246 static struct clk_rcg2 gcc_ufs_phy_unipro_core_clk_src = {
1247 	.cmd_rcgr = 0x45060,
1248 	.mnd_width = 0,
1249 	.hid_width = 5,
1250 	.parent_map = gcc_parent_map_0,
1251 	.freq_tbl = ftbl_gcc_ufs_phy_unipro_core_clk_src,
1252 	.clkr.hw.init = &(struct clk_init_data){
1253 		.name = "gcc_ufs_phy_unipro_core_clk_src",
1254 		.parent_data = gcc_parent_data_0,
1255 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
1256 		.ops = &clk_rcg2_ops,
1257 	},
1258 };
1259 
1260 static const struct freq_tbl ftbl_gcc_usb30_prim_master_clk_src[] = {
1261 	F(66666667, P_GPLL0_OUT_AUX2, 4.5, 0, 0),
1262 	F(133333333, P_GPLL0_OUT_EARLY, 4.5, 0, 0),
1263 	F(200000000, P_GPLL0_OUT_EARLY, 3, 0, 0),
1264 	F(240000000, P_GPLL0_OUT_EARLY, 2.5, 0, 0),
1265 	{ }
1266 };
1267 
1268 static struct clk_rcg2 gcc_usb30_prim_master_clk_src = {
1269 	.cmd_rcgr = 0x1a01c,
1270 	.mnd_width = 8,
1271 	.hid_width = 5,
1272 	.parent_map = gcc_parent_map_0,
1273 	.freq_tbl = ftbl_gcc_usb30_prim_master_clk_src,
1274 	.clkr.hw.init = &(struct clk_init_data){
1275 		.name = "gcc_usb30_prim_master_clk_src",
1276 		.parent_data = gcc_parent_data_0,
1277 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
1278 		.ops = &clk_rcg2_ops,
1279 	},
1280 };
1281 
1282 static const struct freq_tbl ftbl_gcc_usb30_prim_mock_utmi_clk_src[] = {
1283 	F(19200000, P_BI_TCXO, 1, 0, 0),
1284 	F(20000000, P_GPLL0_OUT_AUX2, 15, 0, 0),
1285 	F(40000000, P_GPLL0_OUT_AUX2, 7.5, 0, 0),
1286 	F(60000000, P_GPLL0_OUT_EARLY, 10, 0, 0),
1287 	{ }
1288 };
1289 
1290 static struct clk_rcg2 gcc_usb30_prim_mock_utmi_clk_src = {
1291 	.cmd_rcgr = 0x1a034,
1292 	.mnd_width = 0,
1293 	.hid_width = 5,
1294 	.parent_map = gcc_parent_map_0,
1295 	.freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src,
1296 	.clkr.hw.init = &(struct clk_init_data){
1297 		.name = "gcc_usb30_prim_mock_utmi_clk_src",
1298 		.parent_data = gcc_parent_data_0,
1299 		.num_parents = ARRAY_SIZE(gcc_parent_data_0),
1300 		.ops = &clk_rcg2_ops,
1301 	},
1302 };
1303 
1304 static const struct freq_tbl ftbl_gcc_usb3_prim_phy_aux_clk_src[] = {
1305 	F(19200000, P_BI_TCXO, 1, 0, 0),
1306 	{ }
1307 };
1308 
1309 static struct clk_rcg2 gcc_usb3_prim_phy_aux_clk_src = {
1310 	.cmd_rcgr = 0x1a060,
1311 	.mnd_width = 0,
1312 	.hid_width = 5,
1313 	.parent_map = gcc_parent_map_14,
1314 	.freq_tbl = ftbl_gcc_usb3_prim_phy_aux_clk_src,
1315 	.clkr.hw.init = &(struct clk_init_data){
1316 		.name = "gcc_usb3_prim_phy_aux_clk_src",
1317 		.parent_data = gcc_parent_data_14,
1318 		.num_parents = ARRAY_SIZE(gcc_parent_data_14),
1319 		.ops = &clk_rcg2_ops,
1320 	},
1321 };
1322 
1323 static struct clk_rcg2 gcc_vs_ctrl_clk_src = {
1324 	.cmd_rcgr = 0x42030,
1325 	.mnd_width = 0,
1326 	.hid_width = 5,
1327 	.parent_map = gcc_parent_map_5,
1328 	.freq_tbl = ftbl_gcc_usb3_prim_phy_aux_clk_src,
1329 	.clkr.hw.init = &(struct clk_init_data){
1330 		.name = "gcc_vs_ctrl_clk_src",
1331 		.parent_data = gcc_parent_data_5,
1332 		.num_parents = ARRAY_SIZE(gcc_parent_data_5),
1333 		.ops = &clk_rcg2_ops,
1334 	},
1335 };
1336 
1337 static const struct freq_tbl ftbl_gcc_vsensor_clk_src[] = {
1338 	F(19200000, P_BI_TCXO, 1, 0, 0),
1339 	F(400000000, P_GPLL0_OUT_EARLY, 1.5, 0, 0),
1340 	F(600000000, P_GPLL0_OUT_EARLY, 1, 0, 0),
1341 	{ }
1342 };
1343 
1344 static struct clk_rcg2 gcc_vsensor_clk_src = {
1345 	.cmd_rcgr = 0x42018,
1346 	.mnd_width = 0,
1347 	.hid_width = 5,
1348 	.parent_map = gcc_parent_map_5,
1349 	.freq_tbl = ftbl_gcc_vsensor_clk_src,
1350 	.clkr.hw.init = &(struct clk_init_data){
1351 		.name = "gcc_vsensor_clk_src",
1352 		.parent_data = gcc_parent_data_5,
1353 		.num_parents = ARRAY_SIZE(gcc_parent_data_5),
1354 		.ops = &clk_rcg2_ops,
1355 	},
1356 };
1357 
1358 static struct clk_branch gcc_ahb2phy_csi_clk = {
1359 	.halt_reg = 0x1d004,
1360 	.halt_check = BRANCH_HALT,
1361 	.hwcg_reg = 0x1d004,
1362 	.hwcg_bit = 1,
1363 	.clkr = {
1364 		.enable_reg = 0x1d004,
1365 		.enable_mask = BIT(0),
1366 		.hw.init = &(struct clk_init_data){
1367 			.name = "gcc_ahb2phy_csi_clk",
1368 			.ops = &clk_branch2_ops,
1369 		},
1370 	},
1371 };
1372 
1373 static struct clk_branch gcc_ahb2phy_usb_clk = {
1374 	.halt_reg = 0x1d008,
1375 	.halt_check = BRANCH_HALT,
1376 	.hwcg_reg = 0x1d008,
1377 	.hwcg_bit = 1,
1378 	.clkr = {
1379 		.enable_reg = 0x1d008,
1380 		.enable_mask = BIT(0),
1381 		.hw.init = &(struct clk_init_data){
1382 			.name = "gcc_ahb2phy_usb_clk",
1383 			.ops = &clk_branch2_ops,
1384 		},
1385 	},
1386 };
1387 
1388 static struct clk_branch gcc_apc_vs_clk = {
1389 	.halt_reg = 0x4204c,
1390 	.halt_check = BRANCH_HALT,
1391 	.clkr = {
1392 		.enable_reg = 0x4204c,
1393 		.enable_mask = BIT(0),
1394 		.hw.init = &(struct clk_init_data){
1395 			.name = "gcc_apc_vs_clk",
1396 			.parent_hws = (const struct clk_hw*[]){
1397 				&gcc_vsensor_clk_src.clkr.hw,
1398 			},
1399 			.num_parents = 1,
1400 			.flags = CLK_SET_RATE_PARENT,
1401 			.ops = &clk_branch2_ops,
1402 		},
1403 	},
1404 };
1405 
1406 static struct clk_branch gcc_bimc_gpu_axi_clk = {
1407 	.halt_reg = 0x71154,
1408 	.halt_check = BRANCH_HALT_DELAY,
1409 	.clkr = {
1410 		.enable_reg = 0x71154,
1411 		.enable_mask = BIT(0),
1412 		.hw.init = &(struct clk_init_data){
1413 			.name = "gcc_bimc_gpu_axi_clk",
1414 			.ops = &clk_branch2_ops,
1415 		},
1416 	},
1417 };
1418 
1419 static struct clk_branch gcc_boot_rom_ahb_clk = {
1420 	.halt_reg = 0x23004,
1421 	.halt_check = BRANCH_HALT_VOTED,
1422 	.hwcg_reg = 0x23004,
1423 	.hwcg_bit = 1,
1424 	.clkr = {
1425 		.enable_reg = 0x79004,
1426 		.enable_mask = BIT(10),
1427 		.hw.init = &(struct clk_init_data){
1428 			.name = "gcc_boot_rom_ahb_clk",
1429 			.ops = &clk_branch2_ops,
1430 		},
1431 	},
1432 };
1433 
1434 static struct clk_branch gcc_camera_ahb_clk = {
1435 	.halt_reg = 0x17008,
1436 	.halt_check = BRANCH_HALT_DELAY,
1437 	.hwcg_reg = 0x17008,
1438 	.hwcg_bit = 1,
1439 	.clkr = {
1440 		.enable_reg = 0x17008,
1441 		.enable_mask = BIT(0),
1442 		.hw.init = &(struct clk_init_data){
1443 			.name = "gcc_camera_ahb_clk",
1444 			.flags = CLK_IS_CRITICAL,
1445 			.ops = &clk_branch2_ops,
1446 		},
1447 	},
1448 };
1449 
1450 static struct clk_branch gcc_camera_xo_clk = {
1451 	.halt_reg = 0x17028,
1452 	.halt_check = BRANCH_HALT,
1453 	.clkr = {
1454 		.enable_reg = 0x17028,
1455 		.enable_mask = BIT(0),
1456 		.hw.init = &(struct clk_init_data){
1457 			.name = "gcc_camera_xo_clk",
1458 			.flags = CLK_IS_CRITICAL,
1459 			.ops = &clk_branch2_ops,
1460 		},
1461 	},
1462 };
1463 
1464 static struct clk_branch gcc_camss_cci_ahb_clk = {
1465 	.halt_reg = 0x52020,
1466 	.halt_check = BRANCH_HALT,
1467 	.clkr = {
1468 		.enable_reg = 0x52020,
1469 		.enable_mask = BIT(0),
1470 		.hw.init = &(struct clk_init_data){
1471 			.name = "gcc_camss_cci_ahb_clk",
1472 			.parent_hws = (const struct clk_hw*[]){
1473 				&gcc_camss_ahb_clk_src.clkr.hw,
1474 			},
1475 			.num_parents = 1,
1476 			.flags = CLK_SET_RATE_PARENT,
1477 			.ops = &clk_branch2_ops,
1478 		},
1479 	},
1480 };
1481 
1482 static struct clk_branch gcc_camss_cci_clk = {
1483 	.halt_reg = 0x5201c,
1484 	.halt_check = BRANCH_HALT,
1485 	.clkr = {
1486 		.enable_reg = 0x5201c,
1487 		.enable_mask = BIT(0),
1488 		.hw.init = &(struct clk_init_data){
1489 			.name = "gcc_camss_cci_clk",
1490 			.parent_hws = (const struct clk_hw*[]){
1491 				&gcc_camss_cci_clk_src.clkr.hw,
1492 			},
1493 			.num_parents = 1,
1494 			.flags = CLK_SET_RATE_PARENT,
1495 			.ops = &clk_branch2_ops,
1496 		},
1497 	},
1498 };
1499 
1500 static struct clk_branch gcc_camss_cphy_csid0_clk = {
1501 	.halt_reg = 0x5504c,
1502 	.halt_check = BRANCH_HALT,
1503 	.clkr = {
1504 		.enable_reg = 0x5504c,
1505 		.enable_mask = BIT(0),
1506 		.hw.init = &(struct clk_init_data){
1507 			.name = "gcc_camss_cphy_csid0_clk",
1508 			.parent_hws = (const struct clk_hw*[]){
1509 				&gcc_camss_csiphy_clk_src.clkr.hw,
1510 			},
1511 			.num_parents = 1,
1512 			.flags = CLK_SET_RATE_PARENT,
1513 			.ops = &clk_branch2_ops,
1514 		},
1515 	},
1516 };
1517 
1518 static struct clk_branch gcc_camss_cphy_csid1_clk = {
1519 	.halt_reg = 0x55088,
1520 	.halt_check = BRANCH_HALT,
1521 	.clkr = {
1522 		.enable_reg = 0x55088,
1523 		.enable_mask = BIT(0),
1524 		.hw.init = &(struct clk_init_data){
1525 			.name = "gcc_camss_cphy_csid1_clk",
1526 			.parent_hws = (const struct clk_hw*[]){
1527 				&gcc_camss_csiphy_clk_src.clkr.hw,
1528 			},
1529 			.num_parents = 1,
1530 			.flags = CLK_SET_RATE_PARENT,
1531 			.ops = &clk_branch2_ops,
1532 		},
1533 	},
1534 };
1535 
1536 static struct clk_branch gcc_camss_cphy_csid2_clk = {
1537 	.halt_reg = 0x550c0,
1538 	.halt_check = BRANCH_HALT,
1539 	.clkr = {
1540 		.enable_reg = 0x550c0,
1541 		.enable_mask = BIT(0),
1542 		.hw.init = &(struct clk_init_data){
1543 			.name = "gcc_camss_cphy_csid2_clk",
1544 			.parent_hws = (const struct clk_hw*[]){
1545 				&gcc_camss_csiphy_clk_src.clkr.hw,
1546 			},
1547 			.num_parents = 1,
1548 			.flags = CLK_SET_RATE_PARENT,
1549 			.ops = &clk_branch2_ops,
1550 		},
1551 	},
1552 };
1553 
1554 static struct clk_branch gcc_camss_cphy_csid3_clk = {
1555 	.halt_reg = 0x550fc,
1556 	.halt_check = BRANCH_HALT,
1557 	.clkr = {
1558 		.enable_reg = 0x550fc,
1559 		.enable_mask = BIT(0),
1560 		.hw.init = &(struct clk_init_data){
1561 			.name = "gcc_camss_cphy_csid3_clk",
1562 			.parent_hws = (const struct clk_hw*[]){
1563 				&gcc_camss_csiphy_clk_src.clkr.hw,
1564 			},
1565 			.num_parents = 1,
1566 			.flags = CLK_SET_RATE_PARENT,
1567 			.ops = &clk_branch2_ops,
1568 		},
1569 	},
1570 };
1571 
1572 static struct clk_branch gcc_camss_cpp_ahb_clk = {
1573 	.halt_reg = 0x560e8,
1574 	.halt_check = BRANCH_HALT,
1575 	.clkr = {
1576 		.enable_reg = 0x560e8,
1577 		.enable_mask = BIT(0),
1578 		.hw.init = &(struct clk_init_data){
1579 			.name = "gcc_camss_cpp_ahb_clk",
1580 			.parent_hws = (const struct clk_hw*[]){
1581 				&gcc_camss_ahb_clk_src.clkr.hw,
1582 			},
1583 			.num_parents = 1,
1584 			.flags = CLK_SET_RATE_PARENT,
1585 			.ops = &clk_branch2_ops,
1586 		},
1587 	},
1588 };
1589 
1590 static struct clk_branch gcc_camss_cpp_axi_clk = {
1591 	.halt_reg = 0x560f4,
1592 	.halt_check = BRANCH_HALT,
1593 	.clkr = {
1594 		.enable_reg = 0x560f4,
1595 		.enable_mask = BIT(0),
1596 		.hw.init = &(struct clk_init_data){
1597 			.name = "gcc_camss_cpp_axi_clk",
1598 			.ops = &clk_branch2_ops,
1599 		},
1600 	},
1601 };
1602 
1603 static struct clk_branch gcc_camss_cpp_clk = {
1604 	.halt_reg = 0x560e0,
1605 	.halt_check = BRANCH_HALT,
1606 	.clkr = {
1607 		.enable_reg = 0x560e0,
1608 		.enable_mask = BIT(0),
1609 		.hw.init = &(struct clk_init_data){
1610 			.name = "gcc_camss_cpp_clk",
1611 			.parent_hws = (const struct clk_hw*[]){
1612 				&gcc_camss_cpp_clk_src.clkr.hw,
1613 			},
1614 			.num_parents = 1,
1615 			.flags = CLK_SET_RATE_PARENT,
1616 			.ops = &clk_branch2_ops,
1617 		},
1618 	},
1619 };
1620 
1621 static struct clk_branch gcc_camss_cpp_vbif_ahb_clk = {
1622 	.halt_reg = 0x560f0,
1623 	.halt_check = BRANCH_HALT,
1624 	.clkr = {
1625 		.enable_reg = 0x560f0,
1626 		.enable_mask = BIT(0),
1627 		.hw.init = &(struct clk_init_data){
1628 			.name = "gcc_camss_cpp_vbif_ahb_clk",
1629 			.parent_hws = (const struct clk_hw*[]){
1630 				&gcc_camss_ahb_clk_src.clkr.hw,
1631 			},
1632 			.num_parents = 1,
1633 			.flags = CLK_SET_RATE_PARENT,
1634 			.ops = &clk_branch2_ops,
1635 		},
1636 	},
1637 };
1638 
1639 static struct clk_branch gcc_camss_csi0_ahb_clk = {
1640 	.halt_reg = 0x55050,
1641 	.halt_check = BRANCH_HALT,
1642 	.clkr = {
1643 		.enable_reg = 0x55050,
1644 		.enable_mask = BIT(0),
1645 		.hw.init = &(struct clk_init_data){
1646 			.name = "gcc_camss_csi0_ahb_clk",
1647 			.parent_hws = (const struct clk_hw*[]){
1648 				&gcc_camss_ahb_clk_src.clkr.hw,
1649 			},
1650 			.num_parents = 1,
1651 			.flags = CLK_SET_RATE_PARENT,
1652 			.ops = &clk_branch2_ops,
1653 		},
1654 	},
1655 };
1656 
1657 static struct clk_branch gcc_camss_csi0_clk = {
1658 	.halt_reg = 0x55048,
1659 	.halt_check = BRANCH_HALT,
1660 	.clkr = {
1661 		.enable_reg = 0x55048,
1662 		.enable_mask = BIT(0),
1663 		.hw.init = &(struct clk_init_data){
1664 			.name = "gcc_camss_csi0_clk",
1665 			.parent_hws = (const struct clk_hw*[]){
1666 				&gcc_camss_csi0_clk_src.clkr.hw,
1667 			},
1668 			.num_parents = 1,
1669 			.flags = CLK_SET_RATE_PARENT,
1670 			.ops = &clk_branch2_ops,
1671 		},
1672 	},
1673 };
1674 
1675 static struct clk_branch gcc_camss_csi0phytimer_clk = {
1676 	.halt_reg = 0x5301c,
1677 	.halt_check = BRANCH_HALT,
1678 	.clkr = {
1679 		.enable_reg = 0x5301c,
1680 		.enable_mask = BIT(0),
1681 		.hw.init = &(struct clk_init_data){
1682 			.name = "gcc_camss_csi0phytimer_clk",
1683 			.parent_hws = (const struct clk_hw*[]){
1684 				&gcc_camss_csi0phytimer_clk_src.clkr.hw,
1685 			},
1686 			.num_parents = 1,
1687 			.flags = CLK_SET_RATE_PARENT,
1688 			.ops = &clk_branch2_ops,
1689 		},
1690 	},
1691 };
1692 
1693 static struct clk_branch gcc_camss_csi0pix_clk = {
1694 	.halt_reg = 0x55060,
1695 	.halt_check = BRANCH_HALT,
1696 	.clkr = {
1697 		.enable_reg = 0x55060,
1698 		.enable_mask = BIT(0),
1699 		.hw.init = &(struct clk_init_data){
1700 			.name = "gcc_camss_csi0pix_clk",
1701 			.parent_hws = (const struct clk_hw*[]){
1702 				&gcc_camss_csi0_clk_src.clkr.hw,
1703 			},
1704 			.num_parents = 1,
1705 			.flags = CLK_SET_RATE_PARENT,
1706 			.ops = &clk_branch2_ops,
1707 		},
1708 	},
1709 };
1710 
1711 static struct clk_branch gcc_camss_csi0rdi_clk = {
1712 	.halt_reg = 0x55058,
1713 	.halt_check = BRANCH_HALT,
1714 	.clkr = {
1715 		.enable_reg = 0x55058,
1716 		.enable_mask = BIT(0),
1717 		.hw.init = &(struct clk_init_data){
1718 			.name = "gcc_camss_csi0rdi_clk",
1719 			.parent_hws = (const struct clk_hw*[]){
1720 				&gcc_camss_csi0_clk_src.clkr.hw,
1721 			},
1722 			.num_parents = 1,
1723 			.flags = CLK_SET_RATE_PARENT,
1724 			.ops = &clk_branch2_ops,
1725 		},
1726 	},
1727 };
1728 
1729 static struct clk_branch gcc_camss_csi1_ahb_clk = {
1730 	.halt_reg = 0x5508c,
1731 	.halt_check = BRANCH_HALT,
1732 	.clkr = {
1733 		.enable_reg = 0x5508c,
1734 		.enable_mask = BIT(0),
1735 		.hw.init = &(struct clk_init_data){
1736 			.name = "gcc_camss_csi1_ahb_clk",
1737 			.parent_hws = (const struct clk_hw*[]){
1738 				&gcc_camss_ahb_clk_src.clkr.hw,
1739 			},
1740 			.num_parents = 1,
1741 			.flags = CLK_SET_RATE_PARENT,
1742 			.ops = &clk_branch2_ops,
1743 		},
1744 	},
1745 };
1746 
1747 static struct clk_branch gcc_camss_csi1_clk = {
1748 	.halt_reg = 0x55084,
1749 	.halt_check = BRANCH_HALT,
1750 	.clkr = {
1751 		.enable_reg = 0x55084,
1752 		.enable_mask = BIT(0),
1753 		.hw.init = &(struct clk_init_data){
1754 			.name = "gcc_camss_csi1_clk",
1755 			.parent_hws = (const struct clk_hw*[]){
1756 				&gcc_camss_csi1_clk_src.clkr.hw,
1757 			},
1758 			.num_parents = 1,
1759 			.flags = CLK_SET_RATE_PARENT,
1760 			.ops = &clk_branch2_ops,
1761 		},
1762 	},
1763 };
1764 
1765 static struct clk_branch gcc_camss_csi1phytimer_clk = {
1766 	.halt_reg = 0x5303c,
1767 	.halt_check = BRANCH_HALT,
1768 	.clkr = {
1769 		.enable_reg = 0x5303c,
1770 		.enable_mask = BIT(0),
1771 		.hw.init = &(struct clk_init_data){
1772 			.name = "gcc_camss_csi1phytimer_clk",
1773 			.parent_hws = (const struct clk_hw*[]){
1774 				&gcc_camss_csi1phytimer_clk_src.clkr.hw,
1775 			},
1776 			.num_parents = 1,
1777 			.flags = CLK_SET_RATE_PARENT,
1778 			.ops = &clk_branch2_ops,
1779 		},
1780 	},
1781 };
1782 
1783 static struct clk_branch gcc_camss_csi1pix_clk = {
1784 	.halt_reg = 0x5509c,
1785 	.halt_check = BRANCH_HALT,
1786 	.clkr = {
1787 		.enable_reg = 0x5509c,
1788 		.enable_mask = BIT(0),
1789 		.hw.init = &(struct clk_init_data){
1790 			.name = "gcc_camss_csi1pix_clk",
1791 			.parent_hws = (const struct clk_hw*[]){
1792 				&gcc_camss_csi1_clk_src.clkr.hw,
1793 			},
1794 			.num_parents = 1,
1795 			.flags = CLK_SET_RATE_PARENT,
1796 			.ops = &clk_branch2_ops,
1797 		},
1798 	},
1799 };
1800 
1801 static struct clk_branch gcc_camss_csi1rdi_clk = {
1802 	.halt_reg = 0x55094,
1803 	.halt_check = BRANCH_HALT,
1804 	.clkr = {
1805 		.enable_reg = 0x55094,
1806 		.enable_mask = BIT(0),
1807 		.hw.init = &(struct clk_init_data){
1808 			.name = "gcc_camss_csi1rdi_clk",
1809 			.parent_hws = (const struct clk_hw*[]){
1810 				&gcc_camss_csi1_clk_src.clkr.hw,
1811 			},
1812 			.num_parents = 1,
1813 			.flags = CLK_SET_RATE_PARENT,
1814 			.ops = &clk_branch2_ops,
1815 		},
1816 	},
1817 };
1818 
1819 static struct clk_branch gcc_camss_csi2_ahb_clk = {
1820 	.halt_reg = 0x550c4,
1821 	.halt_check = BRANCH_HALT,
1822 	.clkr = {
1823 		.enable_reg = 0x550c4,
1824 		.enable_mask = BIT(0),
1825 		.hw.init = &(struct clk_init_data){
1826 			.name = "gcc_camss_csi2_ahb_clk",
1827 			.parent_hws = (const struct clk_hw*[]){
1828 				&gcc_camss_ahb_clk_src.clkr.hw,
1829 			},
1830 			.num_parents = 1,
1831 			.flags = CLK_SET_RATE_PARENT,
1832 			.ops = &clk_branch2_ops,
1833 		},
1834 	},
1835 };
1836 
1837 static struct clk_branch gcc_camss_csi2_clk = {
1838 	.halt_reg = 0x550bc,
1839 	.halt_check = BRANCH_HALT,
1840 	.clkr = {
1841 		.enable_reg = 0x550bc,
1842 		.enable_mask = BIT(0),
1843 		.hw.init = &(struct clk_init_data){
1844 			.name = "gcc_camss_csi2_clk",
1845 			.parent_hws = (const struct clk_hw*[]){
1846 				&gcc_camss_csi2_clk_src.clkr.hw,
1847 			},
1848 			.num_parents = 1,
1849 			.flags = CLK_SET_RATE_PARENT,
1850 			.ops = &clk_branch2_ops,
1851 		},
1852 	},
1853 };
1854 
1855 static struct clk_branch gcc_camss_csi2phytimer_clk = {
1856 	.halt_reg = 0x5305c,
1857 	.halt_check = BRANCH_HALT,
1858 	.clkr = {
1859 		.enable_reg = 0x5305c,
1860 		.enable_mask = BIT(0),
1861 		.hw.init = &(struct clk_init_data){
1862 			.name = "gcc_camss_csi2phytimer_clk",
1863 			.parent_hws = (const struct clk_hw*[]){
1864 				&gcc_camss_csi2phytimer_clk_src.clkr.hw,
1865 			},
1866 			.num_parents = 1,
1867 			.flags = CLK_SET_RATE_PARENT,
1868 			.ops = &clk_branch2_ops,
1869 		},
1870 	},
1871 };
1872 
1873 static struct clk_branch gcc_camss_csi2pix_clk = {
1874 	.halt_reg = 0x550d4,
1875 	.halt_check = BRANCH_HALT,
1876 	.clkr = {
1877 		.enable_reg = 0x550d4,
1878 		.enable_mask = BIT(0),
1879 		.hw.init = &(struct clk_init_data){
1880 			.name = "gcc_camss_csi2pix_clk",
1881 			.parent_hws = (const struct clk_hw*[]){
1882 				&gcc_camss_csi2_clk_src.clkr.hw,
1883 			},
1884 			.num_parents = 1,
1885 			.flags = CLK_SET_RATE_PARENT,
1886 			.ops = &clk_branch2_ops,
1887 		},
1888 	},
1889 };
1890 
1891 static struct clk_branch gcc_camss_csi2rdi_clk = {
1892 	.halt_reg = 0x550cc,
1893 	.halt_check = BRANCH_HALT,
1894 	.clkr = {
1895 		.enable_reg = 0x550cc,
1896 		.enable_mask = BIT(0),
1897 		.hw.init = &(struct clk_init_data){
1898 			.name = "gcc_camss_csi2rdi_clk",
1899 			.parent_hws = (const struct clk_hw*[]){
1900 				&gcc_camss_csi2_clk_src.clkr.hw,
1901 			},
1902 			.num_parents = 1,
1903 			.flags = CLK_SET_RATE_PARENT,
1904 			.ops = &clk_branch2_ops,
1905 		},
1906 	},
1907 };
1908 
1909 static struct clk_branch gcc_camss_csi3_ahb_clk = {
1910 	.halt_reg = 0x55100,
1911 	.halt_check = BRANCH_HALT,
1912 	.clkr = {
1913 		.enable_reg = 0x55100,
1914 		.enable_mask = BIT(0),
1915 		.hw.init = &(struct clk_init_data){
1916 			.name = "gcc_camss_csi3_ahb_clk",
1917 			.parent_hws = (const struct clk_hw*[]){
1918 				&gcc_camss_ahb_clk_src.clkr.hw,
1919 			},
1920 			.num_parents = 1,
1921 			.flags = CLK_SET_RATE_PARENT,
1922 			.ops = &clk_branch2_ops,
1923 		},
1924 	},
1925 };
1926 
1927 static struct clk_branch gcc_camss_csi3_clk = {
1928 	.halt_reg = 0x550f8,
1929 	.halt_check = BRANCH_HALT,
1930 	.clkr = {
1931 		.enable_reg = 0x550f8,
1932 		.enable_mask = BIT(0),
1933 		.hw.init = &(struct clk_init_data){
1934 			.name = "gcc_camss_csi3_clk",
1935 			.parent_hws = (const struct clk_hw*[]){
1936 				&gcc_camss_csi3_clk_src.clkr.hw,
1937 			},
1938 			.num_parents = 1,
1939 			.flags = CLK_SET_RATE_PARENT,
1940 			.ops = &clk_branch2_ops,
1941 		},
1942 	},
1943 };
1944 
1945 static struct clk_branch gcc_camss_csi3pix_clk = {
1946 	.halt_reg = 0x55110,
1947 	.halt_check = BRANCH_HALT,
1948 	.clkr = {
1949 		.enable_reg = 0x55110,
1950 		.enable_mask = BIT(0),
1951 		.hw.init = &(struct clk_init_data){
1952 			.name = "gcc_camss_csi3pix_clk",
1953 			.parent_hws = (const struct clk_hw*[]){
1954 				&gcc_camss_csi3_clk_src.clkr.hw,
1955 			},
1956 			.num_parents = 1,
1957 			.flags = CLK_SET_RATE_PARENT,
1958 			.ops = &clk_branch2_ops,
1959 		},
1960 	},
1961 };
1962 
1963 static struct clk_branch gcc_camss_csi3rdi_clk = {
1964 	.halt_reg = 0x55108,
1965 	.halt_check = BRANCH_HALT,
1966 	.clkr = {
1967 		.enable_reg = 0x55108,
1968 		.enable_mask = BIT(0),
1969 		.hw.init = &(struct clk_init_data){
1970 			.name = "gcc_camss_csi3rdi_clk",
1971 			.parent_hws = (const struct clk_hw*[]){
1972 				&gcc_camss_csi3_clk_src.clkr.hw,
1973 			},
1974 			.num_parents = 1,
1975 			.flags = CLK_SET_RATE_PARENT,
1976 			.ops = &clk_branch2_ops,
1977 		},
1978 	},
1979 };
1980 
1981 static struct clk_branch gcc_camss_csi_vfe0_clk = {
1982 	.halt_reg = 0x54074,
1983 	.halt_check = BRANCH_HALT,
1984 	.clkr = {
1985 		.enable_reg = 0x54074,
1986 		.enable_mask = BIT(0),
1987 		.hw.init = &(struct clk_init_data){
1988 			.name = "gcc_camss_csi_vfe0_clk",
1989 			.parent_hws = (const struct clk_hw*[]){
1990 				&gcc_camss_vfe0_clk_src.clkr.hw,
1991 			},
1992 			.num_parents = 1,
1993 			.flags = CLK_SET_RATE_PARENT,
1994 			.ops = &clk_branch2_ops,
1995 		},
1996 	},
1997 };
1998 
1999 static struct clk_branch gcc_camss_csi_vfe1_clk = {
2000 	.halt_reg = 0x54080,
2001 	.halt_check = BRANCH_HALT,
2002 	.clkr = {
2003 		.enable_reg = 0x54080,
2004 		.enable_mask = BIT(0),
2005 		.hw.init = &(struct clk_init_data){
2006 			.name = "gcc_camss_csi_vfe1_clk",
2007 			.parent_hws = (const struct clk_hw*[]){
2008 				&gcc_camss_vfe1_clk_src.clkr.hw,
2009 			},
2010 			.num_parents = 1,
2011 			.flags = CLK_SET_RATE_PARENT,
2012 			.ops = &clk_branch2_ops,
2013 		},
2014 	},
2015 };
2016 
2017 static struct clk_branch gcc_camss_csiphy0_clk = {
2018 	.halt_reg = 0x55018,
2019 	.halt_check = BRANCH_HALT,
2020 	.clkr = {
2021 		.enable_reg = 0x55018,
2022 		.enable_mask = BIT(0),
2023 		.hw.init = &(struct clk_init_data){
2024 			.name = "gcc_camss_csiphy0_clk",
2025 			.parent_hws = (const struct clk_hw*[]){
2026 				&gcc_camss_csiphy_clk_src.clkr.hw,
2027 			},
2028 			.num_parents = 1,
2029 			.flags = CLK_SET_RATE_PARENT,
2030 			.ops = &clk_branch2_ops,
2031 		},
2032 	},
2033 };
2034 
2035 static struct clk_branch gcc_camss_csiphy1_clk = {
2036 	.halt_reg = 0x5501c,
2037 	.halt_check = BRANCH_HALT,
2038 	.clkr = {
2039 		.enable_reg = 0x5501c,
2040 		.enable_mask = BIT(0),
2041 		.hw.init = &(struct clk_init_data){
2042 			.name = "gcc_camss_csiphy1_clk",
2043 			.parent_hws = (const struct clk_hw*[]){
2044 				&gcc_camss_csiphy_clk_src.clkr.hw,
2045 			},
2046 			.num_parents = 1,
2047 			.flags = CLK_SET_RATE_PARENT,
2048 			.ops = &clk_branch2_ops,
2049 		},
2050 	},
2051 };
2052 
2053 static struct clk_branch gcc_camss_csiphy2_clk = {
2054 	.halt_reg = 0x55020,
2055 	.halt_check = BRANCH_HALT,
2056 	.clkr = {
2057 		.enable_reg = 0x55020,
2058 		.enable_mask = BIT(0),
2059 		.hw.init = &(struct clk_init_data){
2060 			.name = "gcc_camss_csiphy2_clk",
2061 			.parent_hws = (const struct clk_hw*[]){
2062 				&gcc_camss_csiphy_clk_src.clkr.hw,
2063 			},
2064 			.num_parents = 1,
2065 			.flags = CLK_SET_RATE_PARENT,
2066 			.ops = &clk_branch2_ops,
2067 		},
2068 	},
2069 };
2070 
2071 static struct clk_branch gcc_camss_gp0_clk = {
2072 	.halt_reg = 0x50018,
2073 	.halt_check = BRANCH_HALT,
2074 	.clkr = {
2075 		.enable_reg = 0x50018,
2076 		.enable_mask = BIT(0),
2077 		.hw.init = &(struct clk_init_data){
2078 			.name = "gcc_camss_gp0_clk",
2079 			.parent_hws = (const struct clk_hw*[]){
2080 				&gcc_camss_gp0_clk_src.clkr.hw,
2081 			},
2082 			.num_parents = 1,
2083 			.flags = CLK_SET_RATE_PARENT,
2084 			.ops = &clk_branch2_ops,
2085 		},
2086 	},
2087 };
2088 
2089 static struct clk_branch gcc_camss_gp1_clk = {
2090 	.halt_reg = 0x50034,
2091 	.halt_check = BRANCH_HALT,
2092 	.clkr = {
2093 		.enable_reg = 0x50034,
2094 		.enable_mask = BIT(0),
2095 		.hw.init = &(struct clk_init_data){
2096 			.name = "gcc_camss_gp1_clk",
2097 			.parent_hws = (const struct clk_hw*[]){
2098 				&gcc_camss_gp1_clk_src.clkr.hw,
2099 			},
2100 			.num_parents = 1,
2101 			.flags = CLK_SET_RATE_PARENT,
2102 			.ops = &clk_branch2_ops,
2103 		},
2104 	},
2105 };
2106 
2107 static struct clk_branch gcc_camss_ispif_ahb_clk = {
2108 	.halt_reg = 0x540a4,
2109 	.halt_check = BRANCH_HALT,
2110 	.clkr = {
2111 		.enable_reg = 0x540a4,
2112 		.enable_mask = BIT(0),
2113 		.hw.init = &(struct clk_init_data){
2114 			.name = "gcc_camss_ispif_ahb_clk",
2115 			.parent_hws = (const struct clk_hw*[]){
2116 				&gcc_camss_ahb_clk_src.clkr.hw,
2117 			},
2118 			.num_parents = 1,
2119 			.flags = CLK_SET_RATE_PARENT,
2120 			.ops = &clk_branch2_ops,
2121 		},
2122 	},
2123 };
2124 
2125 static struct clk_branch gcc_camss_jpeg_ahb_clk = {
2126 	.halt_reg = 0x52048,
2127 	.halt_check = BRANCH_HALT,
2128 	.clkr = {
2129 		.enable_reg = 0x52048,
2130 		.enable_mask = BIT(0),
2131 		.hw.init = &(struct clk_init_data){
2132 			.name = "gcc_camss_jpeg_ahb_clk",
2133 			.parent_hws = (const struct clk_hw*[]){
2134 				&gcc_camss_ahb_clk_src.clkr.hw,
2135 			},
2136 			.num_parents = 1,
2137 			.flags = CLK_SET_RATE_PARENT,
2138 			.ops = &clk_branch2_ops,
2139 		},
2140 	},
2141 };
2142 
2143 static struct clk_branch gcc_camss_jpeg_axi_clk = {
2144 	.halt_reg = 0x5204c,
2145 	.halt_check = BRANCH_HALT,
2146 	.clkr = {
2147 		.enable_reg = 0x5204c,
2148 		.enable_mask = BIT(0),
2149 		.hw.init = &(struct clk_init_data){
2150 			.name = "gcc_camss_jpeg_axi_clk",
2151 			.ops = &clk_branch2_ops,
2152 		},
2153 	},
2154 };
2155 
2156 static struct clk_branch gcc_camss_jpeg_clk = {
2157 	.halt_reg = 0x52040,
2158 	.halt_check = BRANCH_HALT,
2159 	.clkr = {
2160 		.enable_reg = 0x52040,
2161 		.enable_mask = BIT(0),
2162 		.hw.init = &(struct clk_init_data){
2163 			.name = "gcc_camss_jpeg_clk",
2164 			.parent_hws = (const struct clk_hw*[]){
2165 				&gcc_camss_jpeg_clk_src.clkr.hw,
2166 			},
2167 			.num_parents = 1,
2168 			.flags = CLK_SET_RATE_PARENT,
2169 			.ops = &clk_branch2_ops,
2170 		},
2171 	},
2172 };
2173 
2174 static struct clk_branch gcc_camss_mclk0_clk = {
2175 	.halt_reg = 0x51018,
2176 	.halt_check = BRANCH_HALT,
2177 	.clkr = {
2178 		.enable_reg = 0x51018,
2179 		.enable_mask = BIT(0),
2180 		.hw.init = &(struct clk_init_data){
2181 			.name = "gcc_camss_mclk0_clk",
2182 			.parent_hws = (const struct clk_hw*[]){
2183 				&gcc_camss_mclk0_clk_src.clkr.hw,
2184 			},
2185 			.num_parents = 1,
2186 			.flags = CLK_SET_RATE_PARENT,
2187 			.ops = &clk_branch2_ops,
2188 		},
2189 	},
2190 };
2191 
2192 static struct clk_branch gcc_camss_mclk1_clk = {
2193 	.halt_reg = 0x51034,
2194 	.halt_check = BRANCH_HALT,
2195 	.clkr = {
2196 		.enable_reg = 0x51034,
2197 		.enable_mask = BIT(0),
2198 		.hw.init = &(struct clk_init_data){
2199 			.name = "gcc_camss_mclk1_clk",
2200 			.parent_hws = (const struct clk_hw*[]){
2201 				&gcc_camss_mclk1_clk_src.clkr.hw,
2202 			},
2203 			.num_parents = 1,
2204 			.flags = CLK_SET_RATE_PARENT,
2205 			.ops = &clk_branch2_ops,
2206 		},
2207 	},
2208 };
2209 
2210 static struct clk_branch gcc_camss_mclk2_clk = {
2211 	.halt_reg = 0x51050,
2212 	.halt_check = BRANCH_HALT,
2213 	.clkr = {
2214 		.enable_reg = 0x51050,
2215 		.enable_mask = BIT(0),
2216 		.hw.init = &(struct clk_init_data){
2217 			.name = "gcc_camss_mclk2_clk",
2218 			.parent_hws = (const struct clk_hw*[]){
2219 				&gcc_camss_mclk2_clk_src.clkr.hw,
2220 			},
2221 			.num_parents = 1,
2222 			.flags = CLK_SET_RATE_PARENT,
2223 			.ops = &clk_branch2_ops,
2224 		},
2225 	},
2226 };
2227 
2228 static struct clk_branch gcc_camss_mclk3_clk = {
2229 	.halt_reg = 0x5106c,
2230 	.halt_check = BRANCH_HALT,
2231 	.clkr = {
2232 		.enable_reg = 0x5106c,
2233 		.enable_mask = BIT(0),
2234 		.hw.init = &(struct clk_init_data){
2235 			.name = "gcc_camss_mclk3_clk",
2236 			.parent_hws = (const struct clk_hw*[]){
2237 				&gcc_camss_mclk3_clk_src.clkr.hw,
2238 			},
2239 			.num_parents = 1,
2240 			.flags = CLK_SET_RATE_PARENT,
2241 			.ops = &clk_branch2_ops,
2242 		},
2243 	},
2244 };
2245 
2246 static struct clk_branch gcc_camss_micro_ahb_clk = {
2247 	.halt_reg = 0x560b0,
2248 	.halt_check = BRANCH_HALT,
2249 	.clkr = {
2250 		.enable_reg = 0x560b0,
2251 		.enable_mask = BIT(0),
2252 		.hw.init = &(struct clk_init_data){
2253 			.name = "gcc_camss_micro_ahb_clk",
2254 			.parent_hws = (const struct clk_hw*[]){
2255 				&gcc_camss_ahb_clk_src.clkr.hw,
2256 			},
2257 			.num_parents = 1,
2258 			.flags = CLK_SET_RATE_PARENT,
2259 			.ops = &clk_branch2_ops,
2260 		},
2261 	},
2262 };
2263 
2264 static struct clk_branch gcc_camss_throttle_nrt_axi_clk = {
2265 	.halt_reg = 0x560a4,
2266 	.halt_check = BRANCH_HALT_VOTED,
2267 	.clkr = {
2268 		.enable_reg = 0x79004,
2269 		.enable_mask = BIT(27),
2270 		.hw.init = &(struct clk_init_data){
2271 			.name = "gcc_camss_throttle_nrt_axi_clk",
2272 			.ops = &clk_branch2_ops,
2273 		},
2274 	},
2275 };
2276 
2277 static struct clk_branch gcc_camss_throttle_rt_axi_clk = {
2278 	.halt_reg = 0x560a8,
2279 	.halt_check = BRANCH_HALT_VOTED,
2280 	.clkr = {
2281 		.enable_reg = 0x79004,
2282 		.enable_mask = BIT(26),
2283 		.hw.init = &(struct clk_init_data){
2284 			.name = "gcc_camss_throttle_rt_axi_clk",
2285 			.ops = &clk_branch2_ops,
2286 		},
2287 	},
2288 };
2289 
2290 static struct clk_branch gcc_camss_top_ahb_clk = {
2291 	.halt_reg = 0x560a0,
2292 	.halt_check = BRANCH_HALT,
2293 	.clkr = {
2294 		.enable_reg = 0x560a0,
2295 		.enable_mask = BIT(0),
2296 		.hw.init = &(struct clk_init_data){
2297 			.name = "gcc_camss_top_ahb_clk",
2298 			.parent_hws = (const struct clk_hw*[]){
2299 				&gcc_camss_ahb_clk_src.clkr.hw,
2300 			},
2301 			.num_parents = 1,
2302 			.flags = CLK_SET_RATE_PARENT,
2303 			.ops = &clk_branch2_ops,
2304 		},
2305 	},
2306 };
2307 
2308 static struct clk_branch gcc_camss_vfe0_ahb_clk = {
2309 	.halt_reg = 0x54034,
2310 	.halt_check = BRANCH_HALT,
2311 	.clkr = {
2312 		.enable_reg = 0x54034,
2313 		.enable_mask = BIT(0),
2314 		.hw.init = &(struct clk_init_data){
2315 			.name = "gcc_camss_vfe0_ahb_clk",
2316 			.parent_hws = (const struct clk_hw*[]){
2317 				&gcc_camss_ahb_clk_src.clkr.hw,
2318 			},
2319 			.num_parents = 1,
2320 			.flags = CLK_SET_RATE_PARENT,
2321 			.ops = &clk_branch2_ops,
2322 		},
2323 	},
2324 };
2325 
2326 static struct clk_branch gcc_camss_vfe0_clk = {
2327 	.halt_reg = 0x54028,
2328 	.halt_check = BRANCH_HALT,
2329 	.clkr = {
2330 		.enable_reg = 0x54028,
2331 		.enable_mask = BIT(0),
2332 		.hw.init = &(struct clk_init_data){
2333 			.name = "gcc_camss_vfe0_clk",
2334 			.parent_hws = (const struct clk_hw*[]){
2335 				&gcc_camss_vfe0_clk_src.clkr.hw,
2336 			},
2337 			.num_parents = 1,
2338 			.flags = CLK_SET_RATE_PARENT,
2339 			.ops = &clk_branch2_ops,
2340 		},
2341 	},
2342 };
2343 
2344 static struct clk_branch gcc_camss_vfe0_stream_clk = {
2345 	.halt_reg = 0x54030,
2346 	.halt_check = BRANCH_HALT,
2347 	.clkr = {
2348 		.enable_reg = 0x54030,
2349 		.enable_mask = BIT(0),
2350 		.hw.init = &(struct clk_init_data){
2351 			.name = "gcc_camss_vfe0_stream_clk",
2352 			.parent_hws = (const struct clk_hw*[]){
2353 				&gcc_camss_vfe0_clk_src.clkr.hw,
2354 			},
2355 			.num_parents = 1,
2356 			.flags = CLK_SET_RATE_PARENT,
2357 			.ops = &clk_branch2_ops,
2358 		},
2359 	},
2360 };
2361 
2362 static struct clk_branch gcc_camss_vfe1_ahb_clk = {
2363 	.halt_reg = 0x5406c,
2364 	.halt_check = BRANCH_HALT,
2365 	.clkr = {
2366 		.enable_reg = 0x5406c,
2367 		.enable_mask = BIT(0),
2368 		.hw.init = &(struct clk_init_data){
2369 			.name = "gcc_camss_vfe1_ahb_clk",
2370 			.parent_hws = (const struct clk_hw*[]){
2371 				&gcc_camss_ahb_clk_src.clkr.hw,
2372 			},
2373 			.num_parents = 1,
2374 			.flags = CLK_SET_RATE_PARENT,
2375 			.ops = &clk_branch2_ops,
2376 		},
2377 	},
2378 };
2379 
2380 static struct clk_branch gcc_camss_vfe1_clk = {
2381 	.halt_reg = 0x54060,
2382 	.halt_check = BRANCH_HALT,
2383 	.clkr = {
2384 		.enable_reg = 0x54060,
2385 		.enable_mask = BIT(0),
2386 		.hw.init = &(struct clk_init_data){
2387 			.name = "gcc_camss_vfe1_clk",
2388 			.parent_hws = (const struct clk_hw*[]){
2389 				&gcc_camss_vfe1_clk_src.clkr.hw,
2390 			},
2391 			.num_parents = 1,
2392 			.flags = CLK_SET_RATE_PARENT,
2393 			.ops = &clk_branch2_ops,
2394 		},
2395 	},
2396 };
2397 
2398 static struct clk_branch gcc_camss_vfe1_stream_clk = {
2399 	.halt_reg = 0x54068,
2400 	.halt_check = BRANCH_HALT,
2401 	.clkr = {
2402 		.enable_reg = 0x54068,
2403 		.enable_mask = BIT(0),
2404 		.hw.init = &(struct clk_init_data){
2405 			.name = "gcc_camss_vfe1_stream_clk",
2406 			.parent_hws = (const struct clk_hw*[]){
2407 				&gcc_camss_vfe1_clk_src.clkr.hw,
2408 			},
2409 			.num_parents = 1,
2410 			.flags = CLK_SET_RATE_PARENT,
2411 			.ops = &clk_branch2_ops,
2412 		},
2413 	},
2414 };
2415 
2416 static struct clk_branch gcc_camss_vfe_tsctr_clk = {
2417 	.halt_reg = 0x5409c,
2418 	.halt_check = BRANCH_HALT,
2419 	.clkr = {
2420 		.enable_reg = 0x5409c,
2421 		.enable_mask = BIT(0),
2422 		.hw.init = &(struct clk_init_data){
2423 			.name = "gcc_camss_vfe_tsctr_clk",
2424 			.ops = &clk_branch2_ops,
2425 		},
2426 	},
2427 };
2428 
2429 static struct clk_branch gcc_camss_vfe_vbif_ahb_clk = {
2430 	.halt_reg = 0x5408c,
2431 	.halt_check = BRANCH_HALT,
2432 	.clkr = {
2433 		.enable_reg = 0x5408c,
2434 		.enable_mask = BIT(0),
2435 		.hw.init = &(struct clk_init_data){
2436 			.name = "gcc_camss_vfe_vbif_ahb_clk",
2437 			.parent_hws = (const struct clk_hw*[]){
2438 				&gcc_camss_ahb_clk_src.clkr.hw,
2439 			},
2440 			.num_parents = 1,
2441 			.flags = CLK_SET_RATE_PARENT,
2442 			.ops = &clk_branch2_ops,
2443 		},
2444 	},
2445 };
2446 
2447 static struct clk_branch gcc_camss_vfe_vbif_axi_clk = {
2448 	.halt_reg = 0x54090,
2449 	.halt_check = BRANCH_HALT,
2450 	.clkr = {
2451 		.enable_reg = 0x54090,
2452 		.enable_mask = BIT(0),
2453 		.hw.init = &(struct clk_init_data){
2454 			.name = "gcc_camss_vfe_vbif_axi_clk",
2455 			.ops = &clk_branch2_ops,
2456 		},
2457 	},
2458 };
2459 
2460 static struct clk_branch gcc_ce1_ahb_clk = {
2461 	.halt_reg = 0x2700c,
2462 	.halt_check = BRANCH_HALT_VOTED,
2463 	.hwcg_reg = 0x2700c,
2464 	.hwcg_bit = 1,
2465 	.clkr = {
2466 		.enable_reg = 0x79004,
2467 		.enable_mask = BIT(3),
2468 		.hw.init = &(struct clk_init_data){
2469 			.name = "gcc_ce1_ahb_clk",
2470 			.ops = &clk_branch2_ops,
2471 		},
2472 	},
2473 };
2474 
2475 static struct clk_branch gcc_ce1_axi_clk = {
2476 	.halt_reg = 0x27008,
2477 	.halt_check = BRANCH_HALT_VOTED,
2478 	.clkr = {
2479 		.enable_reg = 0x79004,
2480 		.enable_mask = BIT(4),
2481 		.hw.init = &(struct clk_init_data){
2482 			.name = "gcc_ce1_axi_clk",
2483 			.ops = &clk_branch2_ops,
2484 		},
2485 	},
2486 };
2487 
2488 static struct clk_branch gcc_ce1_clk = {
2489 	.halt_reg = 0x27004,
2490 	.halt_check = BRANCH_HALT_VOTED,
2491 	.clkr = {
2492 		.enable_reg = 0x79004,
2493 		.enable_mask = BIT(5),
2494 		.hw.init = &(struct clk_init_data){
2495 			.name = "gcc_ce1_clk",
2496 			.ops = &clk_branch2_ops,
2497 		},
2498 	},
2499 };
2500 
2501 static struct clk_branch gcc_cfg_noc_usb3_prim_axi_clk = {
2502 	.halt_reg = 0x1a084,
2503 	.halt_check = BRANCH_HALT,
2504 	.clkr = {
2505 		.enable_reg = 0x1a084,
2506 		.enable_mask = BIT(0),
2507 		.hw.init = &(struct clk_init_data){
2508 			.name = "gcc_cfg_noc_usb3_prim_axi_clk",
2509 			.parent_hws = (const struct clk_hw*[]){
2510 				&gcc_usb30_prim_master_clk_src.clkr.hw,
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_cpuss_gnoc_clk = {
2520 	.halt_reg = 0x2b004,
2521 	.halt_check = BRANCH_HALT_VOTED,
2522 	.hwcg_reg = 0x2b004,
2523 	.hwcg_bit = 1,
2524 	.clkr = {
2525 		.enable_reg = 0x79004,
2526 		.enable_mask = BIT(22),
2527 		.hw.init = &(struct clk_init_data){
2528 			.name = "gcc_cpuss_gnoc_clk",
2529 			.flags = CLK_IS_CRITICAL,
2530 			.ops = &clk_branch2_ops,
2531 		},
2532 	},
2533 };
2534 
2535 static struct clk_branch gcc_disp_ahb_clk = {
2536 	.halt_reg = 0x1700c,
2537 	.halt_check = BRANCH_HALT,
2538 	.hwcg_reg = 0x1700c,
2539 	.hwcg_bit = 1,
2540 	.clkr = {
2541 		.enable_reg = 0x1700c,
2542 		.enable_mask = BIT(0),
2543 		.hw.init = &(struct clk_init_data){
2544 			.name = "gcc_disp_ahb_clk",
2545 			.flags = CLK_IS_CRITICAL,
2546 			.ops = &clk_branch2_ops,
2547 		},
2548 	},
2549 };
2550 
2551 static struct clk_branch gcc_disp_gpll0_div_clk_src = {
2552 	.halt_check = BRANCH_HALT_DELAY,
2553 	.clkr = {
2554 		.enable_reg = 0x79004,
2555 		.enable_mask = BIT(20),
2556 		.hw.init = &(struct clk_init_data){
2557 			.name = "gcc_disp_gpll0_div_clk_src",
2558 			.parent_hws = (const struct clk_hw*[]){
2559 				&gpll0_out_early.clkr.hw,
2560 			},
2561 			.num_parents = 1,
2562 			.ops = &clk_branch2_ops,
2563 		},
2564 	},
2565 };
2566 
2567 static struct clk_branch gcc_disp_hf_axi_clk = {
2568 	.halt_reg = 0x17020,
2569 	.halt_check = BRANCH_HALT,
2570 	.clkr = {
2571 		.enable_reg = 0x17020,
2572 		.enable_mask = BIT(0),
2573 		.hw.init = &(struct clk_init_data){
2574 			.name = "gcc_disp_hf_axi_clk",
2575 			.ops = &clk_branch2_ops,
2576 		},
2577 	},
2578 };
2579 
2580 static struct clk_branch gcc_disp_throttle_core_clk = {
2581 	.halt_reg = 0x17064,
2582 	.halt_check = BRANCH_HALT_VOTED,
2583 	.clkr = {
2584 		.enable_reg = 0x7900c,
2585 		.enable_mask = BIT(5),
2586 		.hw.init = &(struct clk_init_data){
2587 			.name = "gcc_disp_throttle_core_clk",
2588 			.ops = &clk_branch2_ops,
2589 		},
2590 	},
2591 };
2592 
2593 static struct clk_branch gcc_disp_xo_clk = {
2594 	.halt_reg = 0x1702c,
2595 	.halt_check = BRANCH_HALT,
2596 	.clkr = {
2597 		.enable_reg = 0x1702c,
2598 		.enable_mask = BIT(0),
2599 		.hw.init = &(struct clk_init_data){
2600 			.name = "gcc_disp_xo_clk",
2601 			.flags = CLK_IS_CRITICAL,
2602 			.ops = &clk_branch2_ops,
2603 		},
2604 	},
2605 };
2606 
2607 static struct clk_branch gcc_gp1_clk = {
2608 	.halt_reg = 0x4d000,
2609 	.halt_check = BRANCH_HALT,
2610 	.clkr = {
2611 		.enable_reg = 0x4d000,
2612 		.enable_mask = BIT(0),
2613 		.hw.init = &(struct clk_init_data){
2614 			.name = "gcc_gp1_clk",
2615 			.parent_hws = (const struct clk_hw*[]){
2616 				&gcc_gp1_clk_src.clkr.hw,
2617 			},
2618 			.num_parents = 1,
2619 			.flags = CLK_SET_RATE_PARENT,
2620 			.ops = &clk_branch2_ops,
2621 		},
2622 	},
2623 };
2624 
2625 static struct clk_branch gcc_gp2_clk = {
2626 	.halt_reg = 0x4e000,
2627 	.halt_check = BRANCH_HALT,
2628 	.clkr = {
2629 		.enable_reg = 0x4e000,
2630 		.enable_mask = BIT(0),
2631 		.hw.init = &(struct clk_init_data){
2632 			.name = "gcc_gp2_clk",
2633 			.parent_hws = (const struct clk_hw*[]){
2634 				&gcc_gp2_clk_src.clkr.hw,
2635 			},
2636 			.num_parents = 1,
2637 			.flags = CLK_SET_RATE_PARENT,
2638 			.ops = &clk_branch2_ops,
2639 		},
2640 	},
2641 };
2642 
2643 static struct clk_branch gcc_gp3_clk = {
2644 	.halt_reg = 0x4f000,
2645 	.halt_check = BRANCH_HALT,
2646 	.clkr = {
2647 		.enable_reg = 0x4f000,
2648 		.enable_mask = BIT(0),
2649 		.hw.init = &(struct clk_init_data){
2650 			.name = "gcc_gp3_clk",
2651 			.parent_hws = (const struct clk_hw*[]){
2652 				&gcc_gp3_clk_src.clkr.hw,
2653 			},
2654 			.num_parents = 1,
2655 			.flags = CLK_SET_RATE_PARENT,
2656 			.ops = &clk_branch2_ops,
2657 		},
2658 	},
2659 };
2660 
2661 static struct clk_branch gcc_gpu_cfg_ahb_clk = {
2662 	.halt_reg = 0x36004,
2663 	.halt_check = BRANCH_HALT,
2664 	.hwcg_reg = 0x36004,
2665 	.hwcg_bit = 1,
2666 	.clkr = {
2667 		.enable_reg = 0x36004,
2668 		.enable_mask = BIT(0),
2669 		.hw.init = &(struct clk_init_data){
2670 			.name = "gcc_gpu_cfg_ahb_clk",
2671 			.flags = CLK_IS_CRITICAL,
2672 			.ops = &clk_branch2_ops,
2673 		},
2674 	},
2675 };
2676 
2677 static struct clk_branch gcc_gpu_gpll0_clk_src = {
2678 	.halt_check = BRANCH_HALT_DELAY,
2679 	.clkr = {
2680 		.enable_reg = 0x79004,
2681 		.enable_mask = BIT(15),
2682 		.hw.init = &(struct clk_init_data){
2683 			.name = "gcc_gpu_gpll0_clk_src",
2684 			.parent_hws = (const struct clk_hw*[]){
2685 				&gpll0_out_early.clkr.hw,
2686 			},
2687 			.num_parents = 1,
2688 			.ops = &clk_branch2_ops,
2689 		},
2690 	},
2691 };
2692 
2693 static struct clk_branch gcc_gpu_gpll0_div_clk_src = {
2694 	.halt_check = BRANCH_HALT_DELAY,
2695 	.clkr = {
2696 		.enable_reg = 0x79004,
2697 		.enable_mask = BIT(16),
2698 		.hw.init = &(struct clk_init_data){
2699 			.name = "gcc_gpu_gpll0_div_clk_src",
2700 			.parent_hws = (const struct clk_hw*[]){
2701 				&gpll0_out_aux2.hw,
2702 			},
2703 			.num_parents = 1,
2704 			.ops = &clk_branch2_ops,
2705 		},
2706 	},
2707 };
2708 
2709 static struct clk_branch gcc_gpu_memnoc_gfx_clk = {
2710 	.halt_reg = 0x3600c,
2711 	.halt_check = BRANCH_VOTED,
2712 	.clkr = {
2713 		.enable_reg = 0x3600c,
2714 		.enable_mask = BIT(0),
2715 		.hw.init = &(struct clk_init_data){
2716 			.name = "gcc_gpu_memnoc_gfx_clk",
2717 			.ops = &clk_branch2_ops,
2718 		},
2719 	},
2720 };
2721 
2722 static struct clk_branch gcc_gpu_snoc_dvm_gfx_clk = {
2723 	.halt_reg = 0x36018,
2724 	.halt_check = BRANCH_HALT,
2725 	.clkr = {
2726 		.enable_reg = 0x36018,
2727 		.enable_mask = BIT(0),
2728 		.hw.init = &(struct clk_init_data){
2729 			.name = "gcc_gpu_snoc_dvm_gfx_clk",
2730 			.ops = &clk_branch2_ops,
2731 		},
2732 	},
2733 };
2734 
2735 static struct clk_branch gcc_gpu_throttle_core_clk = {
2736 	.halt_reg = 0x36048,
2737 	.halt_check = BRANCH_HALT_VOTED,
2738 	.clkr = {
2739 		.enable_reg = 0x79004,
2740 		.enable_mask = BIT(31),
2741 		.hw.init = &(struct clk_init_data){
2742 			.name = "gcc_gpu_throttle_core_clk",
2743 			.ops = &clk_branch2_ops,
2744 		},
2745 	},
2746 };
2747 
2748 static struct clk_branch gcc_gpu_throttle_xo_clk = {
2749 	.halt_reg = 0x36044,
2750 	.halt_check = BRANCH_HALT,
2751 	.clkr = {
2752 		.enable_reg = 0x36044,
2753 		.enable_mask = BIT(0),
2754 		.hw.init = &(struct clk_init_data){
2755 			.name = "gcc_gpu_throttle_xo_clk",
2756 			.ops = &clk_branch2_ops,
2757 		},
2758 	},
2759 };
2760 
2761 static struct clk_branch gcc_mss_vs_clk = {
2762 	.halt_reg = 0x42048,
2763 	.halt_check = BRANCH_HALT,
2764 	.clkr = {
2765 		.enable_reg = 0x42048,
2766 		.enable_mask = BIT(0),
2767 		.hw.init = &(struct clk_init_data){
2768 			.name = "gcc_mss_vs_clk",
2769 			.parent_hws = (const struct clk_hw*[]){
2770 				&gcc_vsensor_clk_src.clkr.hw,
2771 			},
2772 			.num_parents = 1,
2773 			.flags = CLK_SET_RATE_PARENT,
2774 			.ops = &clk_branch2_ops,
2775 		},
2776 	},
2777 };
2778 
2779 static struct clk_branch gcc_pdm2_clk = {
2780 	.halt_reg = 0x2000c,
2781 	.halt_check = BRANCH_HALT,
2782 	.clkr = {
2783 		.enable_reg = 0x2000c,
2784 		.enable_mask = BIT(0),
2785 		.hw.init = &(struct clk_init_data){
2786 			.name = "gcc_pdm2_clk",
2787 			.parent_hws = (const struct clk_hw*[]){
2788 				&gcc_pdm2_clk_src.clkr.hw,
2789 			},
2790 			.num_parents = 1,
2791 			.flags = CLK_SET_RATE_PARENT,
2792 			.ops = &clk_branch2_ops,
2793 		},
2794 	},
2795 };
2796 
2797 static struct clk_branch gcc_pdm_ahb_clk = {
2798 	.halt_reg = 0x20004,
2799 	.halt_check = BRANCH_HALT,
2800 	.hwcg_reg = 0x20004,
2801 	.hwcg_bit = 1,
2802 	.clkr = {
2803 		.enable_reg = 0x20004,
2804 		.enable_mask = BIT(0),
2805 		.hw.init = &(struct clk_init_data){
2806 			.name = "gcc_pdm_ahb_clk",
2807 			.ops = &clk_branch2_ops,
2808 		},
2809 	},
2810 };
2811 
2812 static struct clk_branch gcc_pdm_xo4_clk = {
2813 	.halt_reg = 0x20008,
2814 	.halt_check = BRANCH_HALT,
2815 	.clkr = {
2816 		.enable_reg = 0x20008,
2817 		.enable_mask = BIT(0),
2818 		.hw.init = &(struct clk_init_data){
2819 			.name = "gcc_pdm_xo4_clk",
2820 			.ops = &clk_branch2_ops,
2821 		},
2822 	},
2823 };
2824 
2825 static struct clk_branch gcc_prng_ahb_clk = {
2826 	.halt_reg = 0x21004,
2827 	.halt_check = BRANCH_HALT_VOTED,
2828 	.hwcg_reg = 0x21004,
2829 	.hwcg_bit = 1,
2830 	.clkr = {
2831 		.enable_reg = 0x79004,
2832 		.enable_mask = BIT(13),
2833 		.hw.init = &(struct clk_init_data){
2834 			.name = "gcc_prng_ahb_clk",
2835 			.ops = &clk_branch2_ops,
2836 		},
2837 	},
2838 };
2839 
2840 static struct clk_branch gcc_qmip_camera_nrt_ahb_clk = {
2841 	.halt_reg = 0x17014,
2842 	.halt_check = BRANCH_HALT,
2843 	.hwcg_reg = 0x17014,
2844 	.hwcg_bit = 1,
2845 	.clkr = {
2846 		.enable_reg = 0x7900c,
2847 		.enable_mask = BIT(0),
2848 		.hw.init = &(struct clk_init_data){
2849 			.name = "gcc_qmip_camera_nrt_ahb_clk",
2850 			.ops = &clk_branch2_ops,
2851 		},
2852 	},
2853 };
2854 
2855 static struct clk_branch gcc_qmip_camera_rt_ahb_clk = {
2856 	.halt_reg = 0x17060,
2857 	.halt_check = BRANCH_HALT_VOTED,
2858 	.hwcg_reg = 0x17060,
2859 	.hwcg_bit = 1,
2860 	.clkr = {
2861 		.enable_reg = 0x7900c,
2862 		.enable_mask = BIT(2),
2863 		.hw.init = &(struct clk_init_data){
2864 			.name = "gcc_qmip_camera_rt_ahb_clk",
2865 			.ops = &clk_branch2_ops,
2866 		},
2867 	},
2868 };
2869 
2870 static struct clk_branch gcc_qmip_disp_ahb_clk = {
2871 	.halt_reg = 0x17018,
2872 	.halt_check = BRANCH_HALT,
2873 	.hwcg_reg = 0x17018,
2874 	.hwcg_bit = 1,
2875 	.clkr = {
2876 		.enable_reg = 0x7900c,
2877 		.enable_mask = BIT(1),
2878 		.hw.init = &(struct clk_init_data){
2879 			.name = "gcc_qmip_disp_ahb_clk",
2880 			.ops = &clk_branch2_ops,
2881 		},
2882 	},
2883 };
2884 
2885 static struct clk_branch gcc_qmip_gpu_cfg_ahb_clk = {
2886 	.halt_reg = 0x36040,
2887 	.halt_check = BRANCH_HALT_VOTED,
2888 	.hwcg_reg = 0x36040,
2889 	.hwcg_bit = 1,
2890 	.clkr = {
2891 		.enable_reg = 0x7900c,
2892 		.enable_mask = BIT(4),
2893 		.hw.init = &(struct clk_init_data){
2894 			.name = "gcc_qmip_gpu_cfg_ahb_clk",
2895 			.ops = &clk_branch2_ops,
2896 		},
2897 	},
2898 };
2899 
2900 static struct clk_branch gcc_qmip_video_vcodec_ahb_clk = {
2901 	.halt_reg = 0x17010,
2902 	.halt_check = BRANCH_HALT,
2903 	.hwcg_reg = 0x17010,
2904 	.hwcg_bit = 1,
2905 	.clkr = {
2906 		.enable_reg = 0x79004,
2907 		.enable_mask = BIT(25),
2908 		.hw.init = &(struct clk_init_data){
2909 			.name = "gcc_qmip_video_vcodec_ahb_clk",
2910 			.ops = &clk_branch2_ops,
2911 		},
2912 	},
2913 };
2914 
2915 static struct clk_branch gcc_qupv3_wrap0_core_2x_clk = {
2916 	.halt_reg = 0x1f014,
2917 	.halt_check = BRANCH_HALT_VOTED,
2918 	.clkr = {
2919 		.enable_reg = 0x7900c,
2920 		.enable_mask = BIT(9),
2921 		.hw.init = &(struct clk_init_data){
2922 			.name = "gcc_qupv3_wrap0_core_2x_clk",
2923 			.ops = &clk_branch2_ops,
2924 		},
2925 	},
2926 };
2927 
2928 static struct clk_branch gcc_qupv3_wrap0_core_clk = {
2929 	.halt_reg = 0x1f00c,
2930 	.halt_check = BRANCH_HALT_VOTED,
2931 	.clkr = {
2932 		.enable_reg = 0x7900c,
2933 		.enable_mask = BIT(8),
2934 		.hw.init = &(struct clk_init_data){
2935 			.name = "gcc_qupv3_wrap0_core_clk",
2936 			.ops = &clk_branch2_ops,
2937 		},
2938 	},
2939 };
2940 
2941 static struct clk_branch gcc_qupv3_wrap0_s0_clk = {
2942 	.halt_reg = 0x1f144,
2943 	.halt_check = BRANCH_HALT_VOTED,
2944 	.clkr = {
2945 		.enable_reg = 0x7900c,
2946 		.enable_mask = BIT(10),
2947 		.hw.init = &(struct clk_init_data){
2948 			.name = "gcc_qupv3_wrap0_s0_clk",
2949 			.parent_hws = (const struct clk_hw*[]){
2950 				&gcc_qupv3_wrap0_s0_clk_src.clkr.hw,
2951 			},
2952 			.num_parents = 1,
2953 			.flags = CLK_SET_RATE_PARENT,
2954 			.ops = &clk_branch2_ops,
2955 		},
2956 	},
2957 };
2958 
2959 static struct clk_branch gcc_qupv3_wrap0_s1_clk = {
2960 	.halt_reg = 0x1f274,
2961 	.halt_check = BRANCH_HALT_VOTED,
2962 	.clkr = {
2963 		.enable_reg = 0x7900c,
2964 		.enable_mask = BIT(11),
2965 		.hw.init = &(struct clk_init_data){
2966 			.name = "gcc_qupv3_wrap0_s1_clk",
2967 			.parent_hws = (const struct clk_hw*[]){
2968 				&gcc_qupv3_wrap0_s1_clk_src.clkr.hw,
2969 			},
2970 			.num_parents = 1,
2971 			.flags = CLK_SET_RATE_PARENT,
2972 			.ops = &clk_branch2_ops,
2973 		},
2974 	},
2975 };
2976 
2977 static struct clk_branch gcc_qupv3_wrap0_s2_clk = {
2978 	.halt_reg = 0x1f3a4,
2979 	.halt_check = BRANCH_HALT_VOTED,
2980 	.clkr = {
2981 		.enable_reg = 0x7900c,
2982 		.enable_mask = BIT(12),
2983 		.hw.init = &(struct clk_init_data){
2984 			.name = "gcc_qupv3_wrap0_s2_clk",
2985 			.parent_hws = (const struct clk_hw*[]){
2986 				&gcc_qupv3_wrap0_s2_clk_src.clkr.hw,
2987 			},
2988 			.num_parents = 1,
2989 			.flags = CLK_SET_RATE_PARENT,
2990 			.ops = &clk_branch2_ops,
2991 		},
2992 	},
2993 };
2994 
2995 static struct clk_branch gcc_qupv3_wrap0_s3_clk = {
2996 	.halt_reg = 0x1f4d4,
2997 	.halt_check = BRANCH_HALT_VOTED,
2998 	.clkr = {
2999 		.enable_reg = 0x7900c,
3000 		.enable_mask = BIT(13),
3001 		.hw.init = &(struct clk_init_data){
3002 			.name = "gcc_qupv3_wrap0_s3_clk",
3003 			.parent_hws = (const struct clk_hw*[]){
3004 				&gcc_qupv3_wrap0_s3_clk_src.clkr.hw,
3005 			},
3006 			.num_parents = 1,
3007 			.flags = CLK_SET_RATE_PARENT,
3008 			.ops = &clk_branch2_ops,
3009 		},
3010 	},
3011 };
3012 
3013 static struct clk_branch gcc_qupv3_wrap0_s4_clk = {
3014 	.halt_reg = 0x1f604,
3015 	.halt_check = BRANCH_HALT_VOTED,
3016 	.clkr = {
3017 		.enable_reg = 0x7900c,
3018 		.enable_mask = BIT(14),
3019 		.hw.init = &(struct clk_init_data){
3020 			.name = "gcc_qupv3_wrap0_s4_clk",
3021 			.parent_hws = (const struct clk_hw*[]){
3022 				&gcc_qupv3_wrap0_s4_clk_src.clkr.hw,
3023 			},
3024 			.num_parents = 1,
3025 			.flags = CLK_SET_RATE_PARENT,
3026 			.ops = &clk_branch2_ops,
3027 		},
3028 	},
3029 };
3030 
3031 static struct clk_branch gcc_qupv3_wrap0_s5_clk = {
3032 	.halt_reg = 0x1f734,
3033 	.halt_check = BRANCH_HALT_VOTED,
3034 	.clkr = {
3035 		.enable_reg = 0x7900c,
3036 		.enable_mask = BIT(15),
3037 		.hw.init = &(struct clk_init_data){
3038 			.name = "gcc_qupv3_wrap0_s5_clk",
3039 			.parent_hws = (const struct clk_hw*[]){
3040 				&gcc_qupv3_wrap0_s5_clk_src.clkr.hw,
3041 			},
3042 			.num_parents = 1,
3043 			.flags = CLK_SET_RATE_PARENT,
3044 			.ops = &clk_branch2_ops,
3045 		},
3046 	},
3047 };
3048 
3049 static struct clk_branch gcc_qupv3_wrap1_core_2x_clk = {
3050 	.halt_reg = 0x39014,
3051 	.halt_check = BRANCH_HALT_VOTED,
3052 	.clkr = {
3053 		.enable_reg = 0x7900c,
3054 		.enable_mask = BIT(18),
3055 		.hw.init = &(struct clk_init_data){
3056 			.name = "gcc_qupv3_wrap1_core_2x_clk",
3057 			.ops = &clk_branch2_ops,
3058 		},
3059 	},
3060 };
3061 
3062 static struct clk_branch gcc_qupv3_wrap1_core_clk = {
3063 	.halt_reg = 0x3900c,
3064 	.halt_check = BRANCH_HALT_VOTED,
3065 	.clkr = {
3066 		.enable_reg = 0x7900c,
3067 		.enable_mask = BIT(19),
3068 		.hw.init = &(struct clk_init_data){
3069 			.name = "gcc_qupv3_wrap1_core_clk",
3070 			.ops = &clk_branch2_ops,
3071 		},
3072 	},
3073 };
3074 
3075 static struct clk_branch gcc_qupv3_wrap1_s0_clk = {
3076 	.halt_reg = 0x39144,
3077 	.halt_check = BRANCH_HALT_VOTED,
3078 	.clkr = {
3079 		.enable_reg = 0x7900c,
3080 		.enable_mask = BIT(22),
3081 		.hw.init = &(struct clk_init_data){
3082 			.name = "gcc_qupv3_wrap1_s0_clk",
3083 			.parent_hws = (const struct clk_hw*[]){
3084 				&gcc_qupv3_wrap1_s0_clk_src.clkr.hw,
3085 			},
3086 			.num_parents = 1,
3087 			.flags = CLK_SET_RATE_PARENT,
3088 			.ops = &clk_branch2_ops,
3089 		},
3090 	},
3091 };
3092 
3093 static struct clk_branch gcc_qupv3_wrap1_s1_clk = {
3094 	.halt_reg = 0x39274,
3095 	.halt_check = BRANCH_HALT_VOTED,
3096 	.clkr = {
3097 		.enable_reg = 0x7900c,
3098 		.enable_mask = BIT(23),
3099 		.hw.init = &(struct clk_init_data){
3100 			.name = "gcc_qupv3_wrap1_s1_clk",
3101 			.parent_hws = (const struct clk_hw*[]){
3102 				&gcc_qupv3_wrap1_s1_clk_src.clkr.hw,
3103 			},
3104 			.num_parents = 1,
3105 			.flags = CLK_SET_RATE_PARENT,
3106 			.ops = &clk_branch2_ops,
3107 		},
3108 	},
3109 };
3110 
3111 static struct clk_branch gcc_qupv3_wrap1_s2_clk = {
3112 	.halt_reg = 0x393a4,
3113 	.halt_check = BRANCH_HALT_VOTED,
3114 	.clkr = {
3115 		.enable_reg = 0x7900c,
3116 		.enable_mask = BIT(24),
3117 		.hw.init = &(struct clk_init_data){
3118 			.name = "gcc_qupv3_wrap1_s2_clk",
3119 			.parent_hws = (const struct clk_hw*[]){
3120 				&gcc_qupv3_wrap1_s2_clk_src.clkr.hw,
3121 			},
3122 			.num_parents = 1,
3123 			.flags = CLK_SET_RATE_PARENT,
3124 			.ops = &clk_branch2_ops,
3125 		},
3126 	},
3127 };
3128 
3129 static struct clk_branch gcc_qupv3_wrap1_s3_clk = {
3130 	.halt_reg = 0x394d4,
3131 	.halt_check = BRANCH_HALT_VOTED,
3132 	.clkr = {
3133 		.enable_reg = 0x7900c,
3134 		.enable_mask = BIT(25),
3135 		.hw.init = &(struct clk_init_data){
3136 			.name = "gcc_qupv3_wrap1_s3_clk",
3137 			.parent_hws = (const struct clk_hw*[]){
3138 				&gcc_qupv3_wrap1_s3_clk_src.clkr.hw,
3139 			},
3140 			.num_parents = 1,
3141 			.flags = CLK_SET_RATE_PARENT,
3142 			.ops = &clk_branch2_ops,
3143 		},
3144 	},
3145 };
3146 
3147 static struct clk_branch gcc_qupv3_wrap1_s4_clk = {
3148 	.halt_reg = 0x39604,
3149 	.halt_check = BRANCH_HALT_VOTED,
3150 	.clkr = {
3151 		.enable_reg = 0x7900c,
3152 		.enable_mask = BIT(26),
3153 		.hw.init = &(struct clk_init_data){
3154 			.name = "gcc_qupv3_wrap1_s4_clk",
3155 			.parent_hws = (const struct clk_hw*[]){
3156 				&gcc_qupv3_wrap1_s4_clk_src.clkr.hw,
3157 			},
3158 			.num_parents = 1,
3159 			.flags = CLK_SET_RATE_PARENT,
3160 			.ops = &clk_branch2_ops,
3161 		},
3162 	},
3163 };
3164 
3165 static struct clk_branch gcc_qupv3_wrap1_s5_clk = {
3166 	.halt_reg = 0x39734,
3167 	.halt_check = BRANCH_HALT_VOTED,
3168 	.clkr = {
3169 		.enable_reg = 0x7900c,
3170 		.enable_mask = BIT(27),
3171 		.hw.init = &(struct clk_init_data){
3172 			.name = "gcc_qupv3_wrap1_s5_clk",
3173 			.parent_hws = (const struct clk_hw*[]){
3174 				&gcc_qupv3_wrap1_s5_clk_src.clkr.hw,
3175 			},
3176 			.num_parents = 1,
3177 			.flags = CLK_SET_RATE_PARENT,
3178 			.ops = &clk_branch2_ops,
3179 		},
3180 	},
3181 };
3182 
3183 static struct clk_branch gcc_qupv3_wrap_0_m_ahb_clk = {
3184 	.halt_reg = 0x1f004,
3185 	.halt_check = BRANCH_HALT_VOTED,
3186 	.clkr = {
3187 		.enable_reg = 0x7900c,
3188 		.enable_mask = BIT(6),
3189 		.hw.init = &(struct clk_init_data){
3190 			.name = "gcc_qupv3_wrap_0_m_ahb_clk",
3191 			.ops = &clk_branch2_ops,
3192 		},
3193 	},
3194 };
3195 
3196 static struct clk_branch gcc_qupv3_wrap_0_s_ahb_clk = {
3197 	.halt_reg = 0x1f008,
3198 	.halt_check = BRANCH_HALT_VOTED,
3199 	.hwcg_reg = 0x1f008,
3200 	.hwcg_bit = 1,
3201 	.clkr = {
3202 		.enable_reg = 0x7900c,
3203 		.enable_mask = BIT(7),
3204 		.hw.init = &(struct clk_init_data){
3205 			.name = "gcc_qupv3_wrap_0_s_ahb_clk",
3206 			.ops = &clk_branch2_ops,
3207 		},
3208 	},
3209 };
3210 
3211 static struct clk_branch gcc_qupv3_wrap_1_m_ahb_clk = {
3212 	.halt_reg = 0x39004,
3213 	.halt_check = BRANCH_HALT_VOTED,
3214 	.clkr = {
3215 		.enable_reg = 0x7900c,
3216 		.enable_mask = BIT(20),
3217 		.hw.init = &(struct clk_init_data){
3218 			.name = "gcc_qupv3_wrap_1_m_ahb_clk",
3219 			.ops = &clk_branch2_ops,
3220 		},
3221 	},
3222 };
3223 
3224 static struct clk_branch gcc_qupv3_wrap_1_s_ahb_clk = {
3225 	.halt_reg = 0x39008,
3226 	.halt_check = BRANCH_HALT_VOTED,
3227 	.hwcg_reg = 0x39008,
3228 	.hwcg_bit = 1,
3229 	.clkr = {
3230 		.enable_reg = 0x7900c,
3231 		.enable_mask = BIT(21),
3232 		.hw.init = &(struct clk_init_data){
3233 			.name = "gcc_qupv3_wrap_1_s_ahb_clk",
3234 			.ops = &clk_branch2_ops,
3235 		},
3236 	},
3237 };
3238 
3239 static struct clk_branch gcc_sdcc1_ahb_clk = {
3240 	.halt_reg = 0x38008,
3241 	.halt_check = BRANCH_HALT,
3242 	.clkr = {
3243 		.enable_reg = 0x38008,
3244 		.enable_mask = BIT(0),
3245 		.hw.init = &(struct clk_init_data){
3246 			.name = "gcc_sdcc1_ahb_clk",
3247 			.ops = &clk_branch2_ops,
3248 		},
3249 	},
3250 };
3251 
3252 static struct clk_branch gcc_sdcc1_apps_clk = {
3253 	.halt_reg = 0x38004,
3254 	.halt_check = BRANCH_HALT,
3255 	.clkr = {
3256 		.enable_reg = 0x38004,
3257 		.enable_mask = BIT(0),
3258 		.hw.init = &(struct clk_init_data){
3259 			.name = "gcc_sdcc1_apps_clk",
3260 			.parent_hws = (const struct clk_hw*[]){
3261 				&gcc_sdcc1_apps_clk_src.clkr.hw,
3262 			},
3263 			.num_parents = 1,
3264 			.flags = CLK_SET_RATE_PARENT,
3265 			.ops = &clk_branch2_ops,
3266 		},
3267 	},
3268 };
3269 
3270 static struct clk_branch gcc_sdcc1_ice_core_clk = {
3271 	.halt_reg = 0x3800c,
3272 	.halt_check = BRANCH_HALT,
3273 	.clkr = {
3274 		.enable_reg = 0x3800c,
3275 		.enable_mask = BIT(0),
3276 		.hw.init = &(struct clk_init_data){
3277 			.name = "gcc_sdcc1_ice_core_clk",
3278 			.parent_hws = (const struct clk_hw*[]){
3279 				&gcc_sdcc1_ice_core_clk_src.clkr.hw,
3280 			},
3281 			.num_parents = 1,
3282 			.flags = CLK_SET_RATE_PARENT,
3283 			.ops = &clk_branch2_ops,
3284 		},
3285 	},
3286 };
3287 
3288 static struct clk_branch gcc_sdcc2_ahb_clk = {
3289 	.halt_reg = 0x1e008,
3290 	.halt_check = BRANCH_HALT,
3291 	.clkr = {
3292 		.enable_reg = 0x1e008,
3293 		.enable_mask = BIT(0),
3294 		.hw.init = &(struct clk_init_data){
3295 			.name = "gcc_sdcc2_ahb_clk",
3296 			.ops = &clk_branch2_ops,
3297 		},
3298 	},
3299 };
3300 
3301 static struct clk_branch gcc_sdcc2_apps_clk = {
3302 	.halt_reg = 0x1e004,
3303 	.halt_check = BRANCH_HALT,
3304 	.clkr = {
3305 		.enable_reg = 0x1e004,
3306 		.enable_mask = BIT(0),
3307 		.hw.init = &(struct clk_init_data){
3308 			.name = "gcc_sdcc2_apps_clk",
3309 			.parent_hws = (const struct clk_hw*[]){
3310 				&gcc_sdcc2_apps_clk_src.clkr.hw,
3311 			},
3312 			.num_parents = 1,
3313 			.flags = CLK_SET_RATE_PARENT,
3314 			.ops = &clk_branch2_ops,
3315 		},
3316 	},
3317 };
3318 
3319 static struct clk_branch gcc_sys_noc_compute_sf_axi_clk = {
3320 	.halt_reg = 0x1050c,
3321 	.halt_check = BRANCH_HALT,
3322 	.clkr = {
3323 		.enable_reg = 0x1050c,
3324 		.enable_mask = BIT(0),
3325 		.hw.init = &(struct clk_init_data){
3326 			.name = "gcc_sys_noc_compute_sf_axi_clk",
3327 			.flags = CLK_IS_CRITICAL,
3328 			.ops = &clk_branch2_ops,
3329 		},
3330 	},
3331 };
3332 
3333 static struct clk_branch gcc_sys_noc_cpuss_ahb_clk = {
3334 	.halt_reg = 0x2b06c,
3335 	.halt_check = BRANCH_HALT_VOTED,
3336 	.clkr = {
3337 		.enable_reg = 0x79004,
3338 		.enable_mask = BIT(0),
3339 		.hw.init = &(struct clk_init_data){
3340 			.name = "gcc_sys_noc_cpuss_ahb_clk",
3341 			.flags = CLK_IS_CRITICAL,
3342 			.ops = &clk_branch2_ops,
3343 		},
3344 	},
3345 };
3346 
3347 static struct clk_branch gcc_sys_noc_ufs_phy_axi_clk = {
3348 	.halt_reg = 0x45098,
3349 	.halt_check = BRANCH_HALT,
3350 	.clkr = {
3351 		.enable_reg = 0x45098,
3352 		.enable_mask = BIT(0),
3353 		.hw.init = &(struct clk_init_data){
3354 			.name = "gcc_sys_noc_ufs_phy_axi_clk",
3355 			.parent_hws = (const struct clk_hw*[]){
3356 				&gcc_ufs_phy_axi_clk_src.clkr.hw,
3357 			},
3358 			.num_parents = 1,
3359 			.flags = CLK_SET_RATE_PARENT,
3360 			.ops = &clk_branch2_ops,
3361 		},
3362 	},
3363 };
3364 
3365 static struct clk_branch gcc_sys_noc_usb3_prim_axi_clk = {
3366 	.halt_reg = 0x1a080,
3367 	.halt_check = BRANCH_HALT,
3368 	.clkr = {
3369 		.enable_reg = 0x1a080,
3370 		.enable_mask = BIT(0),
3371 		.hw.init = &(struct clk_init_data){
3372 			.name = "gcc_sys_noc_usb3_prim_axi_clk",
3373 			.parent_hws = (const struct clk_hw*[]){
3374 				&gcc_usb30_prim_master_clk_src.clkr.hw,
3375 			},
3376 			.num_parents = 1,
3377 			.flags = CLK_SET_RATE_PARENT,
3378 			.ops = &clk_branch2_ops,
3379 		},
3380 	},
3381 };
3382 
3383 static struct clk_branch gcc_ufs_mem_clkref_clk = {
3384 	.halt_reg = 0x8c000,
3385 	.halt_check = BRANCH_HALT,
3386 	.clkr = {
3387 		.enable_reg = 0x8c000,
3388 		.enable_mask = BIT(0),
3389 		.hw.init = &(struct clk_init_data){
3390 			.name = "gcc_ufs_mem_clkref_clk",
3391 			.ops = &clk_branch2_ops,
3392 		},
3393 	},
3394 };
3395 
3396 static struct clk_branch gcc_ufs_phy_ahb_clk = {
3397 	.halt_reg = 0x45014,
3398 	.halt_check = BRANCH_HALT,
3399 	.hwcg_reg = 0x45014,
3400 	.hwcg_bit = 1,
3401 	.clkr = {
3402 		.enable_reg = 0x45014,
3403 		.enable_mask = BIT(0),
3404 		.hw.init = &(struct clk_init_data){
3405 			.name = "gcc_ufs_phy_ahb_clk",
3406 			.ops = &clk_branch2_ops,
3407 		},
3408 	},
3409 };
3410 
3411 static struct clk_branch gcc_ufs_phy_axi_clk = {
3412 	.halt_reg = 0x45010,
3413 	.halt_check = BRANCH_HALT,
3414 	.hwcg_reg = 0x45010,
3415 	.hwcg_bit = 1,
3416 	.clkr = {
3417 		.enable_reg = 0x45010,
3418 		.enable_mask = BIT(0),
3419 		.hw.init = &(struct clk_init_data){
3420 			.name = "gcc_ufs_phy_axi_clk",
3421 			.parent_hws = (const struct clk_hw*[]){
3422 				&gcc_ufs_phy_axi_clk_src.clkr.hw,
3423 			},
3424 			.num_parents = 1,
3425 			.flags = CLK_SET_RATE_PARENT,
3426 			.ops = &clk_branch2_ops,
3427 		},
3428 	},
3429 };
3430 
3431 static struct clk_branch gcc_ufs_phy_ice_core_clk = {
3432 	.halt_reg = 0x45044,
3433 	.halt_check = BRANCH_HALT,
3434 	.hwcg_reg = 0x45044,
3435 	.hwcg_bit = 1,
3436 	.clkr = {
3437 		.enable_reg = 0x45044,
3438 		.enable_mask = BIT(0),
3439 		.hw.init = &(struct clk_init_data){
3440 			.name = "gcc_ufs_phy_ice_core_clk",
3441 			.parent_hws = (const struct clk_hw*[]){
3442 				&gcc_ufs_phy_ice_core_clk_src.clkr.hw,
3443 			},
3444 			.num_parents = 1,
3445 			.flags = CLK_SET_RATE_PARENT,
3446 			.ops = &clk_branch2_ops,
3447 		},
3448 	},
3449 };
3450 
3451 static struct clk_branch gcc_ufs_phy_phy_aux_clk = {
3452 	.halt_reg = 0x45078,
3453 	.halt_check = BRANCH_HALT,
3454 	.hwcg_reg = 0x45078,
3455 	.hwcg_bit = 1,
3456 	.clkr = {
3457 		.enable_reg = 0x45078,
3458 		.enable_mask = BIT(0),
3459 		.hw.init = &(struct clk_init_data){
3460 			.name = "gcc_ufs_phy_phy_aux_clk",
3461 			.parent_hws = (const struct clk_hw*[]){
3462 				&gcc_ufs_phy_phy_aux_clk_src.clkr.hw,
3463 			},
3464 			.num_parents = 1,
3465 			.flags = CLK_SET_RATE_PARENT,
3466 			.ops = &clk_branch2_ops,
3467 		},
3468 	},
3469 };
3470 
3471 static struct clk_branch gcc_ufs_phy_rx_symbol_0_clk = {
3472 	.halt_reg = 0x4501c,
3473 	.halt_check = BRANCH_HALT_SKIP,
3474 	.clkr = {
3475 		.enable_reg = 0x4501c,
3476 		.enable_mask = BIT(0),
3477 		.hw.init = &(struct clk_init_data){
3478 			.name = "gcc_ufs_phy_rx_symbol_0_clk",
3479 			.ops = &clk_branch2_ops,
3480 		},
3481 	},
3482 };
3483 
3484 static struct clk_branch gcc_ufs_phy_tx_symbol_0_clk = {
3485 	.halt_reg = 0x45018,
3486 	.halt_check = BRANCH_HALT_SKIP,
3487 	.clkr = {
3488 		.enable_reg = 0x45018,
3489 		.enable_mask = BIT(0),
3490 		.hw.init = &(struct clk_init_data){
3491 			.name = "gcc_ufs_phy_tx_symbol_0_clk",
3492 			.ops = &clk_branch2_ops,
3493 		},
3494 	},
3495 };
3496 
3497 static struct clk_branch gcc_ufs_phy_unipro_core_clk = {
3498 	.halt_reg = 0x45040,
3499 	.halt_check = BRANCH_HALT,
3500 	.hwcg_reg = 0x45040,
3501 	.hwcg_bit = 1,
3502 	.clkr = {
3503 		.enable_reg = 0x45040,
3504 		.enable_mask = BIT(0),
3505 		.hw.init = &(struct clk_init_data){
3506 			.name = "gcc_ufs_phy_unipro_core_clk",
3507 			.parent_hws = (const struct clk_hw*[]){
3508 				&gcc_ufs_phy_unipro_core_clk_src.clkr.hw,
3509 			},
3510 			.num_parents = 1,
3511 			.flags = CLK_SET_RATE_PARENT,
3512 			.ops = &clk_branch2_ops,
3513 		},
3514 	},
3515 };
3516 
3517 static struct clk_branch gcc_usb30_prim_master_clk = {
3518 	.halt_reg = 0x1a010,
3519 	.halt_check = BRANCH_HALT,
3520 	.clkr = {
3521 		.enable_reg = 0x1a010,
3522 		.enable_mask = BIT(0),
3523 		.hw.init = &(struct clk_init_data){
3524 			.name = "gcc_usb30_prim_master_clk",
3525 			.parent_hws = (const struct clk_hw*[]){
3526 				&gcc_usb30_prim_master_clk_src.clkr.hw,
3527 			},
3528 			.num_parents = 1,
3529 			.flags = CLK_SET_RATE_PARENT,
3530 			.ops = &clk_branch2_ops,
3531 		},
3532 	},
3533 };
3534 
3535 static struct clk_branch gcc_usb30_prim_mock_utmi_clk = {
3536 	.halt_reg = 0x1a018,
3537 	.halt_check = BRANCH_HALT,
3538 	.clkr = {
3539 		.enable_reg = 0x1a018,
3540 		.enable_mask = BIT(0),
3541 		.hw.init = &(struct clk_init_data){
3542 			.name = "gcc_usb30_prim_mock_utmi_clk",
3543 			.parent_hws = (const struct clk_hw*[]){
3544 				&gcc_usb30_prim_mock_utmi_clk_src.clkr.hw,
3545 			},
3546 			.num_parents = 1,
3547 			.flags = CLK_SET_RATE_PARENT,
3548 			.ops = &clk_branch2_ops,
3549 		},
3550 	},
3551 };
3552 
3553 static struct clk_branch gcc_usb30_prim_sleep_clk = {
3554 	.halt_reg = 0x1a014,
3555 	.halt_check = BRANCH_HALT,
3556 	.clkr = {
3557 		.enable_reg = 0x1a014,
3558 		.enable_mask = BIT(0),
3559 		.hw.init = &(struct clk_init_data){
3560 			.name = "gcc_usb30_prim_sleep_clk",
3561 			.ops = &clk_branch2_ops,
3562 		},
3563 	},
3564 };
3565 
3566 static struct clk_branch gcc_usb3_prim_clkref_clk = {
3567 	.halt_reg = 0x80278,
3568 	.halt_check = BRANCH_HALT,
3569 	.clkr = {
3570 		.enable_reg = 0x80278,
3571 		.enable_mask = BIT(0),
3572 		.hw.init = &(struct clk_init_data){
3573 			.name = "gcc_usb3_prim_clkref_clk",
3574 			.ops = &clk_branch2_ops,
3575 		},
3576 	},
3577 };
3578 
3579 static struct clk_branch gcc_usb3_prim_phy_com_aux_clk = {
3580 	.halt_reg = 0x1a054,
3581 	.halt_check = BRANCH_HALT,
3582 	.clkr = {
3583 		.enable_reg = 0x1a054,
3584 		.enable_mask = BIT(0),
3585 		.hw.init = &(struct clk_init_data){
3586 			.name = "gcc_usb3_prim_phy_com_aux_clk",
3587 			.parent_hws = (const struct clk_hw*[]){
3588 				&gcc_usb3_prim_phy_aux_clk_src.clkr.hw,
3589 			},
3590 			.num_parents = 1,
3591 			.flags = CLK_SET_RATE_PARENT,
3592 			.ops = &clk_branch2_ops,
3593 		},
3594 	},
3595 };
3596 
3597 static struct clk_branch gcc_usb3_prim_phy_pipe_clk = {
3598 	.halt_check = BRANCH_HALT_SKIP,
3599 	.clkr = {
3600 		.enable_reg = 0x1a058,
3601 		.enable_mask = BIT(0),
3602 		.hw.init = &(struct clk_init_data){
3603 			.name = "gcc_usb3_prim_phy_pipe_clk",
3604 			.ops = &clk_branch2_ops,
3605 		},
3606 	},
3607 };
3608 
3609 static struct clk_branch gcc_vdda_vs_clk = {
3610 	.halt_reg = 0x4200c,
3611 	.halt_check = BRANCH_HALT,
3612 	.clkr = {
3613 		.enable_reg = 0x4200c,
3614 		.enable_mask = BIT(0),
3615 		.hw.init = &(struct clk_init_data){
3616 			.name = "gcc_vdda_vs_clk",
3617 			.parent_hws = (const struct clk_hw*[]){
3618 				&gcc_vsensor_clk_src.clkr.hw,
3619 			},
3620 			.num_parents = 1,
3621 			.flags = CLK_SET_RATE_PARENT,
3622 			.ops = &clk_branch2_ops,
3623 		},
3624 	},
3625 };
3626 
3627 static struct clk_branch gcc_vddcx_vs_clk = {
3628 	.halt_reg = 0x42004,
3629 	.halt_check = BRANCH_HALT,
3630 	.clkr = {
3631 		.enable_reg = 0x42004,
3632 		.enable_mask = BIT(0),
3633 		.hw.init = &(struct clk_init_data){
3634 			.name = "gcc_vddcx_vs_clk",
3635 			.parent_hws = (const struct clk_hw*[]){
3636 				&gcc_vsensor_clk_src.clkr.hw,
3637 			},
3638 			.num_parents = 1,
3639 			.flags = CLK_SET_RATE_PARENT,
3640 			.ops = &clk_branch2_ops,
3641 		},
3642 	},
3643 };
3644 
3645 static struct clk_branch gcc_vddmx_vs_clk = {
3646 	.halt_reg = 0x42008,
3647 	.halt_check = BRANCH_HALT,
3648 	.clkr = {
3649 		.enable_reg = 0x42008,
3650 		.enable_mask = BIT(0),
3651 		.hw.init = &(struct clk_init_data){
3652 			.name = "gcc_vddmx_vs_clk",
3653 			.parent_hws = (const struct clk_hw*[]){
3654 				&gcc_vsensor_clk_src.clkr.hw,
3655 			},
3656 			.num_parents = 1,
3657 			.flags = CLK_SET_RATE_PARENT,
3658 			.ops = &clk_branch2_ops,
3659 		},
3660 	},
3661 };
3662 
3663 static struct clk_branch gcc_video_ahb_clk = {
3664 	.halt_reg = 0x17004,
3665 	.halt_check = BRANCH_HALT,
3666 	.hwcg_reg = 0x17004,
3667 	.hwcg_bit = 1,
3668 	.clkr = {
3669 		.enable_reg = 0x17004,
3670 		.enable_mask = BIT(0),
3671 		.hw.init = &(struct clk_init_data){
3672 			.name = "gcc_video_ahb_clk",
3673 			.flags = CLK_IS_CRITICAL,
3674 			.ops = &clk_branch2_ops,
3675 		},
3676 	},
3677 };
3678 
3679 static struct clk_branch gcc_video_axi0_clk = {
3680 	.halt_reg = 0x1701c,
3681 	.halt_check = BRANCH_HALT,
3682 	.clkr = {
3683 		.enable_reg = 0x1701c,
3684 		.enable_mask = BIT(0),
3685 		.hw.init = &(struct clk_init_data){
3686 			.name = "gcc_video_axi0_clk",
3687 			.ops = &clk_branch2_ops,
3688 		},
3689 	},
3690 };
3691 
3692 static struct clk_branch gcc_video_throttle_core_clk = {
3693 	.halt_reg = 0x17068,
3694 	.halt_check = BRANCH_HALT_VOTED,
3695 	.clkr = {
3696 		.enable_reg = 0x79004,
3697 		.enable_mask = BIT(28),
3698 		.hw.init = &(struct clk_init_data){
3699 			.name = "gcc_video_throttle_core_clk",
3700 			.ops = &clk_branch2_ops,
3701 		},
3702 	},
3703 };
3704 
3705 static struct clk_branch gcc_video_xo_clk = {
3706 	.halt_reg = 0x17024,
3707 	.halt_check = BRANCH_HALT,
3708 	.clkr = {
3709 		.enable_reg = 0x17024,
3710 		.enable_mask = BIT(0),
3711 		.hw.init = &(struct clk_init_data){
3712 			.name = "gcc_video_xo_clk",
3713 			.flags = CLK_IS_CRITICAL,
3714 			.ops = &clk_branch2_ops,
3715 		},
3716 	},
3717 };
3718 
3719 static struct clk_branch gcc_vs_ctrl_ahb_clk = {
3720 	.halt_reg = 0x42014,
3721 	.halt_check = BRANCH_HALT,
3722 	.hwcg_reg = 0x42014,
3723 	.hwcg_bit = 1,
3724 	.clkr = {
3725 		.enable_reg = 0x42014,
3726 		.enable_mask = BIT(0),
3727 		.hw.init = &(struct clk_init_data){
3728 			.name = "gcc_vs_ctrl_ahb_clk",
3729 			.ops = &clk_branch2_ops,
3730 		},
3731 	},
3732 };
3733 
3734 static struct clk_branch gcc_vs_ctrl_clk = {
3735 	.halt_reg = 0x42010,
3736 	.halt_check = BRANCH_HALT,
3737 	.clkr = {
3738 		.enable_reg = 0x42010,
3739 		.enable_mask = BIT(0),
3740 		.hw.init = &(struct clk_init_data){
3741 			.name = "gcc_vs_ctrl_clk",
3742 			.parent_hws = (const struct clk_hw*[]){
3743 				&gcc_vs_ctrl_clk_src.clkr.hw,
3744 			},
3745 			.num_parents = 1,
3746 			.flags = CLK_SET_RATE_PARENT,
3747 			.ops = &clk_branch2_ops,
3748 		},
3749 	},
3750 };
3751 
3752 static struct clk_branch gcc_wcss_vs_clk = {
3753 	.halt_reg = 0x42050,
3754 	.halt_check = BRANCH_HALT,
3755 	.clkr = {
3756 		.enable_reg = 0x42050,
3757 		.enable_mask = BIT(0),
3758 		.hw.init = &(struct clk_init_data){
3759 			.name = "gcc_wcss_vs_clk",
3760 			.parent_hws = (const struct clk_hw*[]){
3761 				&gcc_vsensor_clk_src.clkr.hw,
3762 			},
3763 			.num_parents = 1,
3764 			.flags = CLK_SET_RATE_PARENT,
3765 			.ops = &clk_branch2_ops,
3766 		},
3767 	},
3768 };
3769 
3770 static struct gdsc usb30_prim_gdsc = {
3771 	.gdscr = 0x1a004,
3772 	.pd = {
3773 		.name = "usb30_prim_gdsc",
3774 	},
3775 	.pwrsts = PWRSTS_OFF_ON,
3776 };
3777 
3778 static struct gdsc ufs_phy_gdsc = {
3779 	.gdscr = 0x45004,
3780 	.pd = {
3781 		.name = "ufs_phy_gdsc",
3782 	},
3783 	.pwrsts = PWRSTS_OFF_ON,
3784 };
3785 
3786 static struct gdsc camss_vfe0_gdsc = {
3787 	.gdscr = 0x54004,
3788 	.pd = {
3789 		.name = "camss_vfe0_gdsc",
3790 	},
3791 	.pwrsts = PWRSTS_OFF_ON,
3792 };
3793 
3794 static struct gdsc camss_vfe1_gdsc = {
3795 	.gdscr = 0x5403c,
3796 	.pd = {
3797 		.name = "camss_vfe1_gdsc",
3798 	},
3799 	.pwrsts = PWRSTS_OFF_ON,
3800 };
3801 
3802 static struct gdsc camss_top_gdsc = {
3803 	.gdscr = 0x5607c,
3804 	.pd = {
3805 		.name = "camss_top_gdsc",
3806 	},
3807 	.pwrsts = PWRSTS_OFF_ON,
3808 };
3809 
3810 static struct gdsc cam_cpp_gdsc = {
3811 	.gdscr = 0x560bc,
3812 	.pd = {
3813 		.name = "cam_cpp_gdsc",
3814 	},
3815 	.pwrsts = PWRSTS_OFF_ON,
3816 };
3817 
3818 static struct gdsc hlos1_vote_turing_mmu_tbu1_gdsc = {
3819 	.gdscr = 0x7d060,
3820 	.pd = {
3821 		.name = "hlos1_vote_turing_mmu_tbu1_gdsc",
3822 	},
3823 	.pwrsts = PWRSTS_OFF_ON,
3824 	.flags = VOTABLE,
3825 };
3826 
3827 static struct gdsc hlos1_vote_mm_snoc_mmu_tbu_rt_gdsc = {
3828 	.gdscr = 0x80074,
3829 	.pd = {
3830 		.name = "hlos1_vote_mm_snoc_mmu_tbu_rt_gdsc",
3831 	},
3832 	.pwrsts = PWRSTS_OFF_ON,
3833 	.flags = VOTABLE,
3834 };
3835 
3836 static struct gdsc hlos1_vote_mm_snoc_mmu_tbu_nrt_gdsc = {
3837 	.gdscr = 0x80084,
3838 	.pd = {
3839 		.name = "hlos1_vote_mm_snoc_mmu_tbu_nrt_gdsc",
3840 	},
3841 	.pwrsts = PWRSTS_OFF_ON,
3842 	.flags = VOTABLE,
3843 };
3844 
3845 
3846 static struct gdsc hlos1_vote_turing_mmu_tbu0_gdsc = {
3847 	.gdscr = 0x80094,
3848 	.pd = {
3849 		.name = "hlos1_vote_turing_mmu_tbu0_gdsc",
3850 	},
3851 	.pwrsts = PWRSTS_OFF_ON,
3852 	.flags = VOTABLE,
3853 };
3854 
3855 static struct gdsc *gcc_sm6125_gdscs[] = {
3856 	[USB30_PRIM_GDSC] = &usb30_prim_gdsc,
3857 	[UFS_PHY_GDSC] = &ufs_phy_gdsc,
3858 	[CAMSS_VFE0_GDSC] = &camss_vfe0_gdsc,
3859 	[CAMSS_VFE1_GDSC] = &camss_vfe1_gdsc,
3860 	[CAMSS_TOP_GDSC] = &camss_top_gdsc,
3861 	[CAM_CPP_GDSC] = &cam_cpp_gdsc,
3862 	[HLOS1_VOTE_TURING_MMU_TBU1_GDSC] = &hlos1_vote_turing_mmu_tbu1_gdsc,
3863 	[HLOS1_VOTE_MM_SNOC_MMU_TBU_RT_GDSC] = &hlos1_vote_mm_snoc_mmu_tbu_rt_gdsc,
3864 	[HLOS1_VOTE_MM_SNOC_MMU_TBU_NRT_GDSC] = &hlos1_vote_mm_snoc_mmu_tbu_nrt_gdsc,
3865 	[HLOS1_VOTE_TURING_MMU_TBU0_GDSC] = &hlos1_vote_turing_mmu_tbu0_gdsc,
3866 };
3867 
3868 static struct clk_hw *gcc_sm6125_hws[] = {
3869 	[GPLL0_OUT_AUX2] = &gpll0_out_aux2.hw,
3870 	[GPLL0_OUT_MAIN] = &gpll0_out_main.hw,
3871 	[GPLL6_OUT_MAIN] = &gpll6_out_main.hw,
3872 	[GPLL7_OUT_MAIN] = &gpll7_out_main.hw,
3873 	[GPLL8_OUT_MAIN] = &gpll8_out_main.hw,
3874 	[GPLL9_OUT_MAIN] = &gpll9_out_main.hw,
3875 };
3876 
3877 static struct clk_regmap *gcc_sm6125_clocks[] = {
3878 	[GCC_AHB2PHY_CSI_CLK] = &gcc_ahb2phy_csi_clk.clkr,
3879 	[GCC_AHB2PHY_USB_CLK] = &gcc_ahb2phy_usb_clk.clkr,
3880 	[GCC_APC_VS_CLK] = &gcc_apc_vs_clk.clkr,
3881 	[GCC_BIMC_GPU_AXI_CLK] = &gcc_bimc_gpu_axi_clk.clkr,
3882 	[GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr,
3883 	[GCC_CAMERA_AHB_CLK] = &gcc_camera_ahb_clk.clkr,
3884 	[GCC_CAMERA_XO_CLK] = &gcc_camera_xo_clk.clkr,
3885 	[GCC_CAMSS_AHB_CLK_SRC] = &gcc_camss_ahb_clk_src.clkr,
3886 	[GCC_CAMSS_CCI_AHB_CLK] = &gcc_camss_cci_ahb_clk.clkr,
3887 	[GCC_CAMSS_CCI_CLK] = &gcc_camss_cci_clk.clkr,
3888 	[GCC_CAMSS_CCI_CLK_SRC] = &gcc_camss_cci_clk_src.clkr,
3889 	[GCC_CAMSS_CPHY_CSID0_CLK] = &gcc_camss_cphy_csid0_clk.clkr,
3890 	[GCC_CAMSS_CPHY_CSID1_CLK] = &gcc_camss_cphy_csid1_clk.clkr,
3891 	[GCC_CAMSS_CPHY_CSID2_CLK] = &gcc_camss_cphy_csid2_clk.clkr,
3892 	[GCC_CAMSS_CPHY_CSID3_CLK] = &gcc_camss_cphy_csid3_clk.clkr,
3893 	[GCC_CAMSS_CPP_AHB_CLK] = &gcc_camss_cpp_ahb_clk.clkr,
3894 	[GCC_CAMSS_CPP_AXI_CLK] = &gcc_camss_cpp_axi_clk.clkr,
3895 	[GCC_CAMSS_CPP_CLK] = &gcc_camss_cpp_clk.clkr,
3896 	[GCC_CAMSS_CPP_CLK_SRC] = &gcc_camss_cpp_clk_src.clkr,
3897 	[GCC_CAMSS_CPP_VBIF_AHB_CLK] = &gcc_camss_cpp_vbif_ahb_clk.clkr,
3898 	[GCC_CAMSS_CSI0_AHB_CLK] = &gcc_camss_csi0_ahb_clk.clkr,
3899 	[GCC_CAMSS_CSI0_CLK] = &gcc_camss_csi0_clk.clkr,
3900 	[GCC_CAMSS_CSI0_CLK_SRC] = &gcc_camss_csi0_clk_src.clkr,
3901 	[GCC_CAMSS_CSI0PHYTIMER_CLK] = &gcc_camss_csi0phytimer_clk.clkr,
3902 	[GCC_CAMSS_CSI0PHYTIMER_CLK_SRC] = &gcc_camss_csi0phytimer_clk_src.clkr,
3903 	[GCC_CAMSS_CSI0PIX_CLK] = &gcc_camss_csi0pix_clk.clkr,
3904 	[GCC_CAMSS_CSI0RDI_CLK] = &gcc_camss_csi0rdi_clk.clkr,
3905 	[GCC_CAMSS_CSI1_AHB_CLK] = &gcc_camss_csi1_ahb_clk.clkr,
3906 	[GCC_CAMSS_CSI1_CLK] = &gcc_camss_csi1_clk.clkr,
3907 	[GCC_CAMSS_CSI1_CLK_SRC] = &gcc_camss_csi1_clk_src.clkr,
3908 	[GCC_CAMSS_CSI1PHYTIMER_CLK] = &gcc_camss_csi1phytimer_clk.clkr,
3909 	[GCC_CAMSS_CSI1PHYTIMER_CLK_SRC] = &gcc_camss_csi1phytimer_clk_src.clkr,
3910 	[GCC_CAMSS_CSI1PIX_CLK] = &gcc_camss_csi1pix_clk.clkr,
3911 	[GCC_CAMSS_CSI1RDI_CLK] = &gcc_camss_csi1rdi_clk.clkr,
3912 	[GCC_CAMSS_CSI2_AHB_CLK] = &gcc_camss_csi2_ahb_clk.clkr,
3913 	[GCC_CAMSS_CSI2_CLK] = &gcc_camss_csi2_clk.clkr,
3914 	[GCC_CAMSS_CSI2_CLK_SRC] = &gcc_camss_csi2_clk_src.clkr,
3915 	[GCC_CAMSS_CSI2PHYTIMER_CLK] = &gcc_camss_csi2phytimer_clk.clkr,
3916 	[GCC_CAMSS_CSI2PHYTIMER_CLK_SRC] = &gcc_camss_csi2phytimer_clk_src.clkr,
3917 	[GCC_CAMSS_CSI2PIX_CLK] = &gcc_camss_csi2pix_clk.clkr,
3918 	[GCC_CAMSS_CSI2RDI_CLK] = &gcc_camss_csi2rdi_clk.clkr,
3919 	[GCC_CAMSS_CSI3_AHB_CLK] = &gcc_camss_csi3_ahb_clk.clkr,
3920 	[GCC_CAMSS_CSI3_CLK] = &gcc_camss_csi3_clk.clkr,
3921 	[GCC_CAMSS_CSI3_CLK_SRC] = &gcc_camss_csi3_clk_src.clkr,
3922 	[GCC_CAMSS_CSI3PIX_CLK] = &gcc_camss_csi3pix_clk.clkr,
3923 	[GCC_CAMSS_CSI3RDI_CLK] = &gcc_camss_csi3rdi_clk.clkr,
3924 	[GCC_CAMSS_CSI_VFE0_CLK] = &gcc_camss_csi_vfe0_clk.clkr,
3925 	[GCC_CAMSS_CSI_VFE1_CLK] = &gcc_camss_csi_vfe1_clk.clkr,
3926 	[GCC_CAMSS_CSIPHY0_CLK] = &gcc_camss_csiphy0_clk.clkr,
3927 	[GCC_CAMSS_CSIPHY1_CLK] = &gcc_camss_csiphy1_clk.clkr,
3928 	[GCC_CAMSS_CSIPHY2_CLK] = &gcc_camss_csiphy2_clk.clkr,
3929 	[GCC_CAMSS_CSIPHY_CLK_SRC] = &gcc_camss_csiphy_clk_src.clkr,
3930 	[GCC_CAMSS_GP0_CLK] = &gcc_camss_gp0_clk.clkr,
3931 	[GCC_CAMSS_GP0_CLK_SRC] = &gcc_camss_gp0_clk_src.clkr,
3932 	[GCC_CAMSS_GP1_CLK] = &gcc_camss_gp1_clk.clkr,
3933 	[GCC_CAMSS_GP1_CLK_SRC] = &gcc_camss_gp1_clk_src.clkr,
3934 	[GCC_CAMSS_ISPIF_AHB_CLK] = &gcc_camss_ispif_ahb_clk.clkr,
3935 	[GCC_CAMSS_JPEG_AHB_CLK] = &gcc_camss_jpeg_ahb_clk.clkr,
3936 	[GCC_CAMSS_JPEG_AXI_CLK] = &gcc_camss_jpeg_axi_clk.clkr,
3937 	[GCC_CAMSS_JPEG_CLK] = &gcc_camss_jpeg_clk.clkr,
3938 	[GCC_CAMSS_JPEG_CLK_SRC] = &gcc_camss_jpeg_clk_src.clkr,
3939 	[GCC_CAMSS_MCLK0_CLK] = &gcc_camss_mclk0_clk.clkr,
3940 	[GCC_CAMSS_MCLK0_CLK_SRC] = &gcc_camss_mclk0_clk_src.clkr,
3941 	[GCC_CAMSS_MCLK1_CLK] = &gcc_camss_mclk1_clk.clkr,
3942 	[GCC_CAMSS_MCLK1_CLK_SRC] = &gcc_camss_mclk1_clk_src.clkr,
3943 	[GCC_CAMSS_MCLK2_CLK] = &gcc_camss_mclk2_clk.clkr,
3944 	[GCC_CAMSS_MCLK2_CLK_SRC] = &gcc_camss_mclk2_clk_src.clkr,
3945 	[GCC_CAMSS_MCLK3_CLK] = &gcc_camss_mclk3_clk.clkr,
3946 	[GCC_CAMSS_MCLK3_CLK_SRC] = &gcc_camss_mclk3_clk_src.clkr,
3947 	[GCC_CAMSS_MICRO_AHB_CLK] = &gcc_camss_micro_ahb_clk.clkr,
3948 	[GCC_CAMSS_THROTTLE_NRT_AXI_CLK] = &gcc_camss_throttle_nrt_axi_clk.clkr,
3949 	[GCC_CAMSS_THROTTLE_RT_AXI_CLK] = &gcc_camss_throttle_rt_axi_clk.clkr,
3950 	[GCC_CAMSS_TOP_AHB_CLK] = &gcc_camss_top_ahb_clk.clkr,
3951 	[GCC_CAMSS_VFE0_AHB_CLK] = &gcc_camss_vfe0_ahb_clk.clkr,
3952 	[GCC_CAMSS_VFE0_CLK] = &gcc_camss_vfe0_clk.clkr,
3953 	[GCC_CAMSS_VFE0_CLK_SRC] = &gcc_camss_vfe0_clk_src.clkr,
3954 	[GCC_CAMSS_VFE0_STREAM_CLK] = &gcc_camss_vfe0_stream_clk.clkr,
3955 	[GCC_CAMSS_VFE1_AHB_CLK] = &gcc_camss_vfe1_ahb_clk.clkr,
3956 	[GCC_CAMSS_VFE1_CLK] = &gcc_camss_vfe1_clk.clkr,
3957 	[GCC_CAMSS_VFE1_CLK_SRC] = &gcc_camss_vfe1_clk_src.clkr,
3958 	[GCC_CAMSS_VFE1_STREAM_CLK] = &gcc_camss_vfe1_stream_clk.clkr,
3959 	[GCC_CAMSS_VFE_TSCTR_CLK] = &gcc_camss_vfe_tsctr_clk.clkr,
3960 	[GCC_CAMSS_VFE_VBIF_AHB_CLK] = &gcc_camss_vfe_vbif_ahb_clk.clkr,
3961 	[GCC_CAMSS_VFE_VBIF_AXI_CLK] = &gcc_camss_vfe_vbif_axi_clk.clkr,
3962 	[GCC_CE1_AHB_CLK] = &gcc_ce1_ahb_clk.clkr,
3963 	[GCC_CE1_AXI_CLK] = &gcc_ce1_axi_clk.clkr,
3964 	[GCC_CE1_CLK] = &gcc_ce1_clk.clkr,
3965 	[GCC_CFG_NOC_USB3_PRIM_AXI_CLK] = &gcc_cfg_noc_usb3_prim_axi_clk.clkr,
3966 	[GCC_CPUSS_GNOC_CLK] = &gcc_cpuss_gnoc_clk.clkr,
3967 	[GCC_DISP_AHB_CLK] = &gcc_disp_ahb_clk.clkr,
3968 	[GCC_DISP_GPLL0_DIV_CLK_SRC] = &gcc_disp_gpll0_div_clk_src.clkr,
3969 	[GCC_DISP_HF_AXI_CLK] = &gcc_disp_hf_axi_clk.clkr,
3970 	[GCC_DISP_THROTTLE_CORE_CLK] = &gcc_disp_throttle_core_clk.clkr,
3971 	[GCC_DISP_XO_CLK] = &gcc_disp_xo_clk.clkr,
3972 	[GCC_GP1_CLK] = &gcc_gp1_clk.clkr,
3973 	[GCC_GP1_CLK_SRC] = &gcc_gp1_clk_src.clkr,
3974 	[GCC_GP2_CLK] = &gcc_gp2_clk.clkr,
3975 	[GCC_GP2_CLK_SRC] = &gcc_gp2_clk_src.clkr,
3976 	[GCC_GP3_CLK] = &gcc_gp3_clk.clkr,
3977 	[GCC_GP3_CLK_SRC] = &gcc_gp3_clk_src.clkr,
3978 	[GCC_GPU_CFG_AHB_CLK] = &gcc_gpu_cfg_ahb_clk.clkr,
3979 	[GCC_GPU_GPLL0_CLK_SRC] = &gcc_gpu_gpll0_clk_src.clkr,
3980 	[GCC_GPU_GPLL0_DIV_CLK_SRC] = &gcc_gpu_gpll0_div_clk_src.clkr,
3981 	[GCC_GPU_MEMNOC_GFX_CLK] = &gcc_gpu_memnoc_gfx_clk.clkr,
3982 	[GCC_GPU_SNOC_DVM_GFX_CLK] = &gcc_gpu_snoc_dvm_gfx_clk.clkr,
3983 	[GCC_GPU_THROTTLE_CORE_CLK] = &gcc_gpu_throttle_core_clk.clkr,
3984 	[GCC_GPU_THROTTLE_XO_CLK] = &gcc_gpu_throttle_xo_clk.clkr,
3985 	[GCC_MSS_VS_CLK] = &gcc_mss_vs_clk.clkr,
3986 	[GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr,
3987 	[GCC_PDM2_CLK_SRC] = &gcc_pdm2_clk_src.clkr,
3988 	[GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr,
3989 	[GCC_PDM_XO4_CLK] = &gcc_pdm_xo4_clk.clkr,
3990 	[GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr,
3991 	[GCC_QMIP_CAMERA_NRT_AHB_CLK] = &gcc_qmip_camera_nrt_ahb_clk.clkr,
3992 	[GCC_QMIP_CAMERA_RT_AHB_CLK] = &gcc_qmip_camera_rt_ahb_clk.clkr,
3993 	[GCC_QMIP_DISP_AHB_CLK] = &gcc_qmip_disp_ahb_clk.clkr,
3994 	[GCC_QMIP_GPU_CFG_AHB_CLK] = &gcc_qmip_gpu_cfg_ahb_clk.clkr,
3995 	[GCC_QMIP_VIDEO_VCODEC_AHB_CLK] = &gcc_qmip_video_vcodec_ahb_clk.clkr,
3996 	[GCC_QUPV3_WRAP0_CORE_2X_CLK] = &gcc_qupv3_wrap0_core_2x_clk.clkr,
3997 	[GCC_QUPV3_WRAP0_CORE_CLK] = &gcc_qupv3_wrap0_core_clk.clkr,
3998 	[GCC_QUPV3_WRAP0_S0_CLK] = &gcc_qupv3_wrap0_s0_clk.clkr,
3999 	[GCC_QUPV3_WRAP0_S0_CLK_SRC] = &gcc_qupv3_wrap0_s0_clk_src.clkr,
4000 	[GCC_QUPV3_WRAP0_S1_CLK] = &gcc_qupv3_wrap0_s1_clk.clkr,
4001 	[GCC_QUPV3_WRAP0_S1_CLK_SRC] = &gcc_qupv3_wrap0_s1_clk_src.clkr,
4002 	[GCC_QUPV3_WRAP0_S2_CLK] = &gcc_qupv3_wrap0_s2_clk.clkr,
4003 	[GCC_QUPV3_WRAP0_S2_CLK_SRC] = &gcc_qupv3_wrap0_s2_clk_src.clkr,
4004 	[GCC_QUPV3_WRAP0_S3_CLK] = &gcc_qupv3_wrap0_s3_clk.clkr,
4005 	[GCC_QUPV3_WRAP0_S3_CLK_SRC] = &gcc_qupv3_wrap0_s3_clk_src.clkr,
4006 	[GCC_QUPV3_WRAP0_S4_CLK] = &gcc_qupv3_wrap0_s4_clk.clkr,
4007 	[GCC_QUPV3_WRAP0_S4_CLK_SRC] = &gcc_qupv3_wrap0_s4_clk_src.clkr,
4008 	[GCC_QUPV3_WRAP0_S5_CLK] = &gcc_qupv3_wrap0_s5_clk.clkr,
4009 	[GCC_QUPV3_WRAP0_S5_CLK_SRC] = &gcc_qupv3_wrap0_s5_clk_src.clkr,
4010 	[GCC_QUPV3_WRAP1_CORE_2X_CLK] = &gcc_qupv3_wrap1_core_2x_clk.clkr,
4011 	[GCC_QUPV3_WRAP1_CORE_CLK] = &gcc_qupv3_wrap1_core_clk.clkr,
4012 	[GCC_QUPV3_WRAP1_S0_CLK] = &gcc_qupv3_wrap1_s0_clk.clkr,
4013 	[GCC_QUPV3_WRAP1_S0_CLK_SRC] = &gcc_qupv3_wrap1_s0_clk_src.clkr,
4014 	[GCC_QUPV3_WRAP1_S1_CLK] = &gcc_qupv3_wrap1_s1_clk.clkr,
4015 	[GCC_QUPV3_WRAP1_S1_CLK_SRC] = &gcc_qupv3_wrap1_s1_clk_src.clkr,
4016 	[GCC_QUPV3_WRAP1_S2_CLK] = &gcc_qupv3_wrap1_s2_clk.clkr,
4017 	[GCC_QUPV3_WRAP1_S2_CLK_SRC] = &gcc_qupv3_wrap1_s2_clk_src.clkr,
4018 	[GCC_QUPV3_WRAP1_S3_CLK] = &gcc_qupv3_wrap1_s3_clk.clkr,
4019 	[GCC_QUPV3_WRAP1_S3_CLK_SRC] = &gcc_qupv3_wrap1_s3_clk_src.clkr,
4020 	[GCC_QUPV3_WRAP1_S4_CLK] = &gcc_qupv3_wrap1_s4_clk.clkr,
4021 	[GCC_QUPV3_WRAP1_S4_CLK_SRC] = &gcc_qupv3_wrap1_s4_clk_src.clkr,
4022 	[GCC_QUPV3_WRAP1_S5_CLK] = &gcc_qupv3_wrap1_s5_clk.clkr,
4023 	[GCC_QUPV3_WRAP1_S5_CLK_SRC] = &gcc_qupv3_wrap1_s5_clk_src.clkr,
4024 	[GCC_QUPV3_WRAP_0_M_AHB_CLK] = &gcc_qupv3_wrap_0_m_ahb_clk.clkr,
4025 	[GCC_QUPV3_WRAP_0_S_AHB_CLK] = &gcc_qupv3_wrap_0_s_ahb_clk.clkr,
4026 	[GCC_QUPV3_WRAP_1_M_AHB_CLK] = &gcc_qupv3_wrap_1_m_ahb_clk.clkr,
4027 	[GCC_QUPV3_WRAP_1_S_AHB_CLK] = &gcc_qupv3_wrap_1_s_ahb_clk.clkr,
4028 	[GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr,
4029 	[GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr,
4030 	[GCC_SDCC1_APPS_CLK_SRC] = &gcc_sdcc1_apps_clk_src.clkr,
4031 	[GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr,
4032 	[GCC_SDCC1_ICE_CORE_CLK_SRC] = &gcc_sdcc1_ice_core_clk_src.clkr,
4033 	[GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr,
4034 	[GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr,
4035 	[GCC_SDCC2_APPS_CLK_SRC] = &gcc_sdcc2_apps_clk_src.clkr,
4036 	[GCC_SYS_NOC_COMPUTE_SF_AXI_CLK] = &gcc_sys_noc_compute_sf_axi_clk.clkr,
4037 	[GCC_SYS_NOC_CPUSS_AHB_CLK] = &gcc_sys_noc_cpuss_ahb_clk.clkr,
4038 	[GCC_SYS_NOC_UFS_PHY_AXI_CLK] = &gcc_sys_noc_ufs_phy_axi_clk.clkr,
4039 	[GCC_SYS_NOC_USB3_PRIM_AXI_CLK] = &gcc_sys_noc_usb3_prim_axi_clk.clkr,
4040 	[GCC_UFS_MEM_CLKREF_CLK] = &gcc_ufs_mem_clkref_clk.clkr,
4041 	[GCC_UFS_PHY_AHB_CLK] = &gcc_ufs_phy_ahb_clk.clkr,
4042 	[GCC_UFS_PHY_AXI_CLK] = &gcc_ufs_phy_axi_clk.clkr,
4043 	[GCC_UFS_PHY_AXI_CLK_SRC] = &gcc_ufs_phy_axi_clk_src.clkr,
4044 	[GCC_UFS_PHY_ICE_CORE_CLK] = &gcc_ufs_phy_ice_core_clk.clkr,
4045 	[GCC_UFS_PHY_ICE_CORE_CLK_SRC] = &gcc_ufs_phy_ice_core_clk_src.clkr,
4046 	[GCC_UFS_PHY_PHY_AUX_CLK] = &gcc_ufs_phy_phy_aux_clk.clkr,
4047 	[GCC_UFS_PHY_PHY_AUX_CLK_SRC] = &gcc_ufs_phy_phy_aux_clk_src.clkr,
4048 	[GCC_UFS_PHY_RX_SYMBOL_0_CLK] = &gcc_ufs_phy_rx_symbol_0_clk.clkr,
4049 	[GCC_UFS_PHY_TX_SYMBOL_0_CLK] = &gcc_ufs_phy_tx_symbol_0_clk.clkr,
4050 	[GCC_UFS_PHY_UNIPRO_CORE_CLK] = &gcc_ufs_phy_unipro_core_clk.clkr,
4051 	[GCC_UFS_PHY_UNIPRO_CORE_CLK_SRC] =
4052 		&gcc_ufs_phy_unipro_core_clk_src.clkr,
4053 	[GCC_USB30_PRIM_MASTER_CLK] = &gcc_usb30_prim_master_clk.clkr,
4054 	[GCC_USB30_PRIM_MASTER_CLK_SRC] = &gcc_usb30_prim_master_clk_src.clkr,
4055 	[GCC_USB30_PRIM_MOCK_UTMI_CLK] = &gcc_usb30_prim_mock_utmi_clk.clkr,
4056 	[GCC_USB30_PRIM_MOCK_UTMI_CLK_SRC] =
4057 		&gcc_usb30_prim_mock_utmi_clk_src.clkr,
4058 	[GCC_USB30_PRIM_SLEEP_CLK] = &gcc_usb30_prim_sleep_clk.clkr,
4059 	[GCC_USB3_PRIM_PHY_AUX_CLK_SRC] = &gcc_usb3_prim_phy_aux_clk_src.clkr,
4060 	[GCC_USB3_PRIM_PHY_COM_AUX_CLK] = &gcc_usb3_prim_phy_com_aux_clk.clkr,
4061 	[GCC_USB3_PRIM_PHY_PIPE_CLK] = &gcc_usb3_prim_phy_pipe_clk.clkr,
4062 	[GCC_VDDA_VS_CLK] = &gcc_vdda_vs_clk.clkr,
4063 	[GCC_VDDCX_VS_CLK] = &gcc_vddcx_vs_clk.clkr,
4064 	[GCC_VDDMX_VS_CLK] = &gcc_vddmx_vs_clk.clkr,
4065 	[GCC_VIDEO_AHB_CLK] = &gcc_video_ahb_clk.clkr,
4066 	[GCC_VIDEO_AXI0_CLK] = &gcc_video_axi0_clk.clkr,
4067 	[GCC_VIDEO_THROTTLE_CORE_CLK] = &gcc_video_throttle_core_clk.clkr,
4068 	[GCC_VIDEO_XO_CLK] = &gcc_video_xo_clk.clkr,
4069 	[GCC_VS_CTRL_AHB_CLK] = &gcc_vs_ctrl_ahb_clk.clkr,
4070 	[GCC_VS_CTRL_CLK] = &gcc_vs_ctrl_clk.clkr,
4071 	[GCC_VS_CTRL_CLK_SRC] = &gcc_vs_ctrl_clk_src.clkr,
4072 	[GCC_VSENSOR_CLK_SRC] = &gcc_vsensor_clk_src.clkr,
4073 	[GCC_WCSS_VS_CLK] = &gcc_wcss_vs_clk.clkr,
4074 	[GPLL0_OUT_EARLY] = &gpll0_out_early.clkr,
4075 	[GPLL3_OUT_EARLY] = &gpll3_out_early.clkr,
4076 	[GPLL4_OUT_MAIN] = &gpll4_out_main.clkr,
4077 	[GPLL5_OUT_MAIN] = &gpll5_out_main.clkr,
4078 	[GPLL6_OUT_EARLY] = &gpll6_out_early.clkr,
4079 	[GPLL7_OUT_EARLY] = &gpll7_out_early.clkr,
4080 	[GPLL8_OUT_EARLY] = &gpll8_out_early.clkr,
4081 	[GPLL9_OUT_EARLY] = &gpll9_out_early.clkr,
4082 	[GCC_USB3_PRIM_CLKREF_CLK] = &gcc_usb3_prim_clkref_clk.clkr,
4083 };
4084 
4085 static const struct qcom_reset_map gcc_sm6125_resets[] = {
4086 	[GCC_QUSB2PHY_PRIM_BCR] = { 0x1c000 },
4087 	[GCC_QUSB2PHY_SEC_BCR] = { 0x1c004 },
4088 	[GCC_UFS_PHY_BCR] = { 0x45000 },
4089 	[GCC_USB30_PRIM_BCR] = { 0x1a000 },
4090 	[GCC_USB_PHY_CFG_AHB2PHY_BCR] = { 0x1d000 },
4091 	[GCC_USB3PHY_PHY_PRIM_SP0_BCR] = { 0x1b008 },
4092 	[GCC_USB3_PHY_PRIM_SP0_BCR] = { 0x1b000 },
4093 	[GCC_CAMSS_MICRO_BCR] = { 0x560ac },
4094 };
4095 
4096 static struct clk_rcg_dfs_data gcc_dfs_clocks[] = {
4097 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s0_clk_src),
4098 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s1_clk_src),
4099 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s2_clk_src),
4100 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s3_clk_src),
4101 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s4_clk_src),
4102 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s5_clk_src),
4103 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s0_clk_src),
4104 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s1_clk_src),
4105 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s2_clk_src),
4106 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s3_clk_src),
4107 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s4_clk_src),
4108 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s5_clk_src),
4109 };
4110 
4111 static const struct regmap_config gcc_sm6125_regmap_config = {
4112 	.reg_bits = 32,
4113 	.reg_stride = 4,
4114 	.val_bits = 32,
4115 	.max_register = 0xc7000,
4116 	.fast_io = true,
4117 };
4118 
4119 static const struct qcom_cc_desc gcc_sm6125_desc = {
4120 	.config = &gcc_sm6125_regmap_config,
4121 	.clks = gcc_sm6125_clocks,
4122 	.num_clks = ARRAY_SIZE(gcc_sm6125_clocks),
4123 	.clk_hws = gcc_sm6125_hws,
4124 	.num_clk_hws = ARRAY_SIZE(gcc_sm6125_hws),
4125 	.resets = gcc_sm6125_resets,
4126 	.num_resets = ARRAY_SIZE(gcc_sm6125_resets),
4127 	.gdscs = gcc_sm6125_gdscs,
4128 	.num_gdscs = ARRAY_SIZE(gcc_sm6125_gdscs),
4129 };
4130 
4131 static const struct of_device_id gcc_sm6125_match_table[] = {
4132 	{ .compatible = "qcom,gcc-sm6125" },
4133 	{ }
4134 };
4135 MODULE_DEVICE_TABLE(of, gcc_sm6125_match_table);
4136 
4137 static int gcc_sm6125_probe(struct platform_device *pdev)
4138 {
4139 	struct regmap *regmap;
4140 	int ret;
4141 
4142 	regmap = qcom_cc_map(pdev, &gcc_sm6125_desc);
4143 	if (IS_ERR(regmap))
4144 		return PTR_ERR(regmap);
4145 
4146 	/*
4147 	 * Disable the GPLL0 active input to video block via
4148 	 * MISC registers.
4149 	 */
4150 	regmap_update_bits(regmap, 0x80258, 0x1, 0x1);
4151 
4152 	/*
4153 	 * Enable DUAL_EDGE mode for MCLK RCGs
4154 	 * This is required to enable MND divider mode
4155 	 */
4156 	regmap_update_bits(regmap, 0x51004, 0x3000, 0x2000);
4157 	regmap_update_bits(regmap, 0x51020, 0x3000, 0x2000);
4158 	regmap_update_bits(regmap, 0x5103c, 0x3000, 0x2000);
4159 	regmap_update_bits(regmap, 0x51058, 0x3000, 0x2000);
4160 
4161 	ret = qcom_cc_register_rcg_dfs(regmap, gcc_dfs_clocks,
4162 						ARRAY_SIZE(gcc_dfs_clocks));
4163 	if (ret)
4164 		return ret;
4165 
4166 	return qcom_cc_really_probe(pdev, &gcc_sm6125_desc, regmap);
4167 }
4168 
4169 static struct platform_driver gcc_sm6125_driver = {
4170 	.probe = gcc_sm6125_probe,
4171 	.driver = {
4172 		.name = "gcc-sm6125",
4173 		.of_match_table = gcc_sm6125_match_table,
4174 	},
4175 };
4176 
4177 static int __init gcc_sm6125_init(void)
4178 {
4179 	return platform_driver_register(&gcc_sm6125_driver);
4180 }
4181 subsys_initcall(gcc_sm6125_init);
4182 
4183 static void __exit gcc_sm6125_exit(void)
4184 {
4185 	platform_driver_unregister(&gcc_sm6125_driver);
4186 }
4187 module_exit(gcc_sm6125_exit);
4188 
4189 MODULE_DESCRIPTION("QTI GCC SM6125 Driver");
4190 MODULE_LICENSE("GPL v2");
4191