1 // SPDX-License-Identifier: GPL-2.0-only
2 /*x
3  * Copyright (c) 2015, The Linux Foundation. All rights reserved.
4  */
5 
6 #include <linux/kernel.h>
7 #include <linux/bitops.h>
8 #include <linux/err.h>
9 #include <linux/platform_device.h>
10 #include <linux/module.h>
11 #include <linux/of.h>
12 #include <linux/clk-provider.h>
13 #include <linux/regmap.h>
14 #include <linux/reset-controller.h>
15 #include <linux/clk.h>
16 
17 #include <dt-bindings/clock/qcom,mmcc-msm8996.h>
18 
19 #include "common.h"
20 #include "clk-regmap.h"
21 #include "clk-regmap-divider.h"
22 #include "clk-alpha-pll.h"
23 #include "clk-rcg.h"
24 #include "clk-branch.h"
25 #include "reset.h"
26 #include "gdsc.h"
27 
28 enum {
29 	P_XO,
30 	P_MMPLL0,
31 	P_GPLL0,
32 	P_GPLL0_DIV,
33 	P_MMPLL1,
34 	P_MMPLL9,
35 	P_MMPLL2,
36 	P_MMPLL8,
37 	P_MMPLL3,
38 	P_DSI0PLL,
39 	P_DSI1PLL,
40 	P_MMPLL5,
41 	P_HDMIPLL,
42 	P_DSI0PLL_BYTE,
43 	P_DSI1PLL_BYTE,
44 	P_MMPLL4,
45 };
46 
47 static struct clk_fixed_factor gpll0_div = {
48 	.mult = 1,
49 	.div = 2,
50 	.hw.init = &(struct clk_init_data){
51 		.name = "gpll0_div",
52 		.parent_data = (const struct clk_parent_data[]){
53 			{ .fw_name = "gpll0", .name = "gpll0" },
54 		},
55 		.num_parents = 1,
56 		.ops = &clk_fixed_factor_ops,
57 	},
58 };
59 
60 static struct pll_vco mmpll_p_vco[] = {
61 	{ 250000000, 500000000, 3 },
62 	{ 500000000, 1000000000, 2 },
63 	{ 1000000000, 1500000000, 1 },
64 	{ 1500000000, 2000000000, 0 },
65 };
66 
67 static struct pll_vco mmpll_gfx_vco[] = {
68 	{ 400000000, 1000000000, 2 },
69 	{ 1000000000, 1500000000, 1 },
70 	{ 1500000000, 2000000000, 0 },
71 };
72 
73 static struct pll_vco mmpll_t_vco[] = {
74 	{ 500000000, 1500000000, 0 },
75 };
76 
77 static struct clk_alpha_pll mmpll0_early = {
78 	.offset = 0x0,
79 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
80 	.vco_table = mmpll_p_vco,
81 	.num_vco = ARRAY_SIZE(mmpll_p_vco),
82 	.clkr = {
83 		.enable_reg = 0x100,
84 		.enable_mask = BIT(0),
85 		.hw.init = &(struct clk_init_data){
86 			.name = "mmpll0_early",
87 			.parent_data = (const struct clk_parent_data[]){
88 				{ .fw_name = "xo", .name = "xo_board" },
89 			},
90 			.num_parents = 1,
91 			.ops = &clk_alpha_pll_ops,
92 		},
93 	},
94 };
95 
96 static struct clk_alpha_pll_postdiv mmpll0 = {
97 	.offset = 0x0,
98 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
99 	.width = 4,
100 	.clkr.hw.init = &(struct clk_init_data){
101 		.name = "mmpll0",
102 		.parent_hws = (const struct clk_hw*[]){
103 			&mmpll0_early.clkr.hw
104 		},
105 		.num_parents = 1,
106 		.ops = &clk_alpha_pll_postdiv_ops,
107 		.flags = CLK_SET_RATE_PARENT,
108 	},
109 };
110 
111 static struct clk_alpha_pll mmpll1_early = {
112 	.offset = 0x30,
113 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
114 	.vco_table = mmpll_p_vco,
115 	.num_vco = ARRAY_SIZE(mmpll_p_vco),
116 	.clkr = {
117 		.enable_reg = 0x100,
118 		.enable_mask = BIT(1),
119 		.hw.init = &(struct clk_init_data){
120 			.name = "mmpll1_early",
121 			.parent_data = (const struct clk_parent_data[]){
122 				{ .fw_name = "xo", .name = "xo_board" },
123 			},
124 			.num_parents = 1,
125 			.ops = &clk_alpha_pll_ops,
126 		}
127 	},
128 };
129 
130 static struct clk_alpha_pll_postdiv mmpll1 = {
131 	.offset = 0x30,
132 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
133 	.width = 4,
134 	.clkr.hw.init = &(struct clk_init_data){
135 		.name = "mmpll1",
136 		.parent_hws = (const struct clk_hw*[]){
137 			&mmpll1_early.clkr.hw
138 		},
139 		.num_parents = 1,
140 		.ops = &clk_alpha_pll_postdiv_ops,
141 		.flags = CLK_SET_RATE_PARENT,
142 	},
143 };
144 
145 static struct clk_alpha_pll mmpll2_early = {
146 	.offset = 0x4100,
147 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
148 	.vco_table = mmpll_gfx_vco,
149 	.num_vco = ARRAY_SIZE(mmpll_gfx_vco),
150 	.clkr.hw.init = &(struct clk_init_data){
151 		.name = "mmpll2_early",
152 		.parent_data = (const struct clk_parent_data[]){
153 			{ .fw_name = "xo", .name = "xo_board" },
154 		},
155 		.num_parents = 1,
156 		.ops = &clk_alpha_pll_ops,
157 	},
158 };
159 
160 static struct clk_alpha_pll_postdiv mmpll2 = {
161 	.offset = 0x4100,
162 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
163 	.width = 4,
164 	.clkr.hw.init = &(struct clk_init_data){
165 		.name = "mmpll2",
166 		.parent_hws = (const struct clk_hw*[]){
167 			&mmpll2_early.clkr.hw
168 		},
169 		.num_parents = 1,
170 		.ops = &clk_alpha_pll_postdiv_ops,
171 		.flags = CLK_SET_RATE_PARENT,
172 	},
173 };
174 
175 static struct clk_alpha_pll mmpll3_early = {
176 	.offset = 0x60,
177 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
178 	.vco_table = mmpll_p_vco,
179 	.num_vco = ARRAY_SIZE(mmpll_p_vco),
180 	.clkr.hw.init = &(struct clk_init_data){
181 		.name = "mmpll3_early",
182 		.parent_data = (const struct clk_parent_data[]){
183 			{ .fw_name = "xo", .name = "xo_board" },
184 		},
185 		.num_parents = 1,
186 		.ops = &clk_alpha_pll_ops,
187 	},
188 };
189 
190 static struct clk_alpha_pll_postdiv mmpll3 = {
191 	.offset = 0x60,
192 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
193 	.width = 4,
194 	.clkr.hw.init = &(struct clk_init_data){
195 		.name = "mmpll3",
196 		.parent_hws = (const struct clk_hw*[]){
197 			&mmpll3_early.clkr.hw
198 		},
199 		.num_parents = 1,
200 		.ops = &clk_alpha_pll_postdiv_ops,
201 		.flags = CLK_SET_RATE_PARENT,
202 	},
203 };
204 
205 static struct clk_alpha_pll mmpll4_early = {
206 	.offset = 0x90,
207 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
208 	.vco_table = mmpll_t_vco,
209 	.num_vco = ARRAY_SIZE(mmpll_t_vco),
210 	.clkr.hw.init = &(struct clk_init_data){
211 		.name = "mmpll4_early",
212 		.parent_data = (const struct clk_parent_data[]){
213 			{ .fw_name = "xo", .name = "xo_board" },
214 		},
215 		.num_parents = 1,
216 		.ops = &clk_alpha_pll_ops,
217 	},
218 };
219 
220 static struct clk_alpha_pll_postdiv mmpll4 = {
221 	.offset = 0x90,
222 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
223 	.width = 2,
224 	.clkr.hw.init = &(struct clk_init_data){
225 		.name = "mmpll4",
226 		.parent_hws = (const struct clk_hw*[]){
227 			&mmpll4_early.clkr.hw
228 		},
229 		.num_parents = 1,
230 		.ops = &clk_alpha_pll_postdiv_ops,
231 		.flags = CLK_SET_RATE_PARENT,
232 	},
233 };
234 
235 static struct clk_alpha_pll mmpll5_early = {
236 	.offset = 0xc0,
237 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
238 	.vco_table = mmpll_p_vco,
239 	.num_vco = ARRAY_SIZE(mmpll_p_vco),
240 	.clkr.hw.init = &(struct clk_init_data){
241 		.name = "mmpll5_early",
242 		.parent_data = (const struct clk_parent_data[]){
243 			{ .fw_name = "xo", .name = "xo_board" },
244 		},
245 		.num_parents = 1,
246 		.ops = &clk_alpha_pll_ops,
247 	},
248 };
249 
250 static struct clk_alpha_pll_postdiv mmpll5 = {
251 	.offset = 0xc0,
252 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
253 	.width = 4,
254 	.clkr.hw.init = &(struct clk_init_data){
255 		.name = "mmpll5",
256 		.parent_hws = (const struct clk_hw*[]){
257 			&mmpll5_early.clkr.hw
258 		},
259 		.num_parents = 1,
260 		.ops = &clk_alpha_pll_postdiv_ops,
261 		.flags = CLK_SET_RATE_PARENT,
262 	},
263 };
264 
265 static struct clk_alpha_pll mmpll8_early = {
266 	.offset = 0x4130,
267 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
268 	.vco_table = mmpll_gfx_vco,
269 	.num_vco = ARRAY_SIZE(mmpll_gfx_vco),
270 	.clkr.hw.init = &(struct clk_init_data){
271 		.name = "mmpll8_early",
272 		.parent_data = (const struct clk_parent_data[]){
273 			{ .fw_name = "xo", .name = "xo_board" },
274 		},
275 		.num_parents = 1,
276 		.ops = &clk_alpha_pll_ops,
277 	},
278 };
279 
280 static struct clk_alpha_pll_postdiv mmpll8 = {
281 	.offset = 0x4130,
282 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
283 	.width = 4,
284 	.clkr.hw.init = &(struct clk_init_data){
285 		.name = "mmpll8",
286 		.parent_hws = (const struct clk_hw*[]){
287 			&mmpll8_early.clkr.hw
288 		},
289 		.num_parents = 1,
290 		.ops = &clk_alpha_pll_postdiv_ops,
291 		.flags = CLK_SET_RATE_PARENT,
292 	},
293 };
294 
295 static struct clk_alpha_pll mmpll9_early = {
296 	.offset = 0x4200,
297 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
298 	.vco_table = mmpll_t_vco,
299 	.num_vco = ARRAY_SIZE(mmpll_t_vco),
300 	.clkr.hw.init = &(struct clk_init_data){
301 		.name = "mmpll9_early",
302 		.parent_data = (const struct clk_parent_data[]){
303 			{ .fw_name = "xo", .name = "xo_board" },
304 		},
305 		.num_parents = 1,
306 		.ops = &clk_alpha_pll_ops,
307 	},
308 };
309 
310 static struct clk_alpha_pll_postdiv mmpll9 = {
311 	.offset = 0x4200,
312 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
313 	.width = 2,
314 	.clkr.hw.init = &(struct clk_init_data){
315 		.name = "mmpll9",
316 		.parent_hws = (const struct clk_hw*[]){
317 			&mmpll9_early.clkr.hw
318 		},
319 		.num_parents = 1,
320 		.ops = &clk_alpha_pll_postdiv_ops,
321 		.flags = CLK_SET_RATE_PARENT,
322 	},
323 };
324 
325 static const struct parent_map mmss_xo_hdmi_map[] = {
326 	{ P_XO, 0 },
327 	{ P_HDMIPLL, 1 }
328 };
329 
330 static const struct clk_parent_data mmss_xo_hdmi[] = {
331 	{ .fw_name = "xo", .name = "xo_board" },
332 	{ .fw_name = "hdmipll", .name = "hdmipll" }
333 };
334 
335 static const struct parent_map mmss_xo_dsi0pll_dsi1pll_map[] = {
336 	{ P_XO, 0 },
337 	{ P_DSI0PLL, 1 },
338 	{ P_DSI1PLL, 2 }
339 };
340 
341 static const struct clk_parent_data mmss_xo_dsi0pll_dsi1pll[] = {
342 	{ .fw_name = "xo", .name = "xo_board" },
343 	{ .fw_name = "dsi0pll", .name = "dsi0pll" },
344 	{ .fw_name = "dsi1pll", .name = "dsi1pll" }
345 };
346 
347 static const struct parent_map mmss_xo_gpll0_gpll0_div_map[] = {
348 	{ P_XO, 0 },
349 	{ P_GPLL0, 5 },
350 	{ P_GPLL0_DIV, 6 }
351 };
352 
353 static const struct clk_parent_data mmss_xo_gpll0_gpll0_div[] = {
354 	{ .fw_name = "xo", .name = "xo_board" },
355 	{ .fw_name = "gpll0", .name = "gpll0" },
356 	{ .hw = &gpll0_div.hw }
357 };
358 
359 static const struct parent_map mmss_xo_dsibyte_map[] = {
360 	{ P_XO, 0 },
361 	{ P_DSI0PLL_BYTE, 1 },
362 	{ P_DSI1PLL_BYTE, 2 }
363 };
364 
365 static const struct clk_parent_data mmss_xo_dsibyte[] = {
366 	{ .fw_name = "xo", .name = "xo_board" },
367 	{ .fw_name = "dsi0pllbyte", .name = "dsi0pllbyte" },
368 	{ .fw_name = "dsi1pllbyte", .name = "dsi1pllbyte" }
369 };
370 
371 static const struct parent_map mmss_xo_mmpll0_gpll0_gpll0_div_map[] = {
372 	{ P_XO, 0 },
373 	{ P_MMPLL0, 1 },
374 	{ P_GPLL0, 5 },
375 	{ P_GPLL0_DIV, 6 }
376 };
377 
378 static const struct clk_parent_data mmss_xo_mmpll0_gpll0_gpll0_div[] = {
379 	{ .fw_name = "xo", .name = "xo_board" },
380 	{ .hw = &mmpll0.clkr.hw },
381 	{ .fw_name = "gpll0", .name = "gpll0" },
382 	{ .hw = &gpll0_div.hw }
383 };
384 
385 static const struct parent_map mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map[] = {
386 	{ P_XO, 0 },
387 	{ P_MMPLL0, 1 },
388 	{ P_MMPLL1, 2 },
389 	{ P_GPLL0, 5 },
390 	{ P_GPLL0_DIV, 6 }
391 };
392 
393 static const struct clk_parent_data mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div[] = {
394 	{ .fw_name = "xo", .name = "xo_board" },
395 	{ .hw = &mmpll0.clkr.hw },
396 	{ .hw = &mmpll1.clkr.hw },
397 	{ .fw_name = "gpll0", .name = "gpll0" },
398 	{ .hw = &gpll0_div.hw }
399 };
400 
401 static const struct parent_map mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map[] = {
402 	{ P_XO, 0 },
403 	{ P_MMPLL0, 1 },
404 	{ P_MMPLL3, 3 },
405 	{ P_GPLL0, 5 },
406 	{ P_GPLL0_DIV, 6 }
407 };
408 
409 static const struct clk_parent_data mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div[] = {
410 	{ .fw_name = "xo", .name = "xo_board" },
411 	{ .hw = &mmpll0.clkr.hw },
412 	{ .hw = &mmpll3.clkr.hw },
413 	{ .fw_name = "gpll0", .name = "gpll0" },
414 	{ .hw = &gpll0_div.hw }
415 };
416 
417 static const struct parent_map mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map[] = {
418 	{ P_XO, 0 },
419 	{ P_MMPLL0, 1 },
420 	{ P_MMPLL5, 2 },
421 	{ P_GPLL0, 5 },
422 	{ P_GPLL0_DIV, 6 }
423 };
424 
425 static const struct clk_parent_data mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div[] = {
426 	{ .fw_name = "xo", .name = "xo_board" },
427 	{ .hw = &mmpll0.clkr.hw },
428 	{ .hw = &mmpll5.clkr.hw },
429 	{ .fw_name = "gpll0", .name = "gpll0" },
430 	{ .hw = &gpll0_div.hw }
431 };
432 
433 static const struct parent_map mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map[] = {
434 	{ P_XO, 0 },
435 	{ P_MMPLL0, 1 },
436 	{ P_MMPLL4, 3 },
437 	{ P_GPLL0, 5 },
438 	{ P_GPLL0_DIV, 6 }
439 };
440 
441 static const struct clk_parent_data mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div[] = {
442 	{ .fw_name = "xo", .name = "xo_board" },
443 	{ .hw = &mmpll0.clkr.hw },
444 	{ .hw = &mmpll4.clkr.hw },
445 	{ .fw_name = "gpll0", .name = "gpll0" },
446 	{ .hw = &gpll0_div.hw }
447 };
448 
449 static const struct parent_map mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_map[] = {
450 	{ P_XO, 0 },
451 	{ P_MMPLL0, 1 },
452 	{ P_MMPLL9, 2 },
453 	{ P_MMPLL2, 3 },
454 	{ P_MMPLL8, 4 },
455 	{ P_GPLL0, 5 }
456 };
457 
458 static const struct clk_parent_data mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0[] = {
459 	{ .fw_name = "xo", .name = "xo_board" },
460 	{ .hw = &mmpll0.clkr.hw },
461 	{ .hw = &mmpll9.clkr.hw },
462 	{ .hw = &mmpll2.clkr.hw },
463 	{ .hw = &mmpll8.clkr.hw },
464 	{ .fw_name = "gpll0", .name = "gpll0" },
465 };
466 
467 static const struct parent_map mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div_map[] = {
468 	{ P_XO, 0 },
469 	{ P_MMPLL0, 1 },
470 	{ P_MMPLL9, 2 },
471 	{ P_MMPLL2, 3 },
472 	{ P_MMPLL8, 4 },
473 	{ P_GPLL0, 5 },
474 	{ P_GPLL0_DIV, 6 }
475 };
476 
477 static const struct clk_parent_data mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div[] = {
478 	{ .fw_name = "xo", .name = "xo_board" },
479 	{ .hw = &mmpll0.clkr.hw },
480 	{ .hw = &mmpll9.clkr.hw },
481 	{ .hw = &mmpll2.clkr.hw },
482 	{ .hw = &mmpll8.clkr.hw },
483 	{ .fw_name = "gpll0", .name = "gpll0" },
484 	{ .hw = &gpll0_div.hw }
485 };
486 
487 static const struct parent_map mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map[] = {
488 	{ P_XO, 0 },
489 	{ P_MMPLL0, 1 },
490 	{ P_MMPLL1, 2 },
491 	{ P_MMPLL4, 3 },
492 	{ P_MMPLL3, 4 },
493 	{ P_GPLL0, 5 },
494 	{ P_GPLL0_DIV, 6 }
495 };
496 
497 static const struct clk_parent_data mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div[] = {
498 	{ .fw_name = "xo", .name = "xo_board" },
499 	{ .hw = &mmpll0.clkr.hw },
500 	{ .hw = &mmpll1.clkr.hw },
501 	{ .hw = &mmpll4.clkr.hw },
502 	{ .hw = &mmpll3.clkr.hw },
503 	{ .fw_name = "gpll0", .name = "gpll0" },
504 	{ .hw = &gpll0_div.hw }
505 };
506 
507 static const struct freq_tbl ftbl_ahb_clk_src[] = {
508 	F(19200000, P_XO, 1, 0, 0),
509 	F(40000000, P_GPLL0_DIV, 7.5, 0, 0),
510 	F(80000000, P_MMPLL0, 10, 0, 0),
511 	{ }
512 };
513 
514 static struct clk_rcg2 ahb_clk_src = {
515 	.cmd_rcgr = 0x5000,
516 	.hid_width = 5,
517 	.parent_map = mmss_xo_mmpll0_gpll0_gpll0_div_map,
518 	.freq_tbl = ftbl_ahb_clk_src,
519 	.clkr.hw.init = &(struct clk_init_data){
520 		.name = "ahb_clk_src",
521 		.parent_data = mmss_xo_mmpll0_gpll0_gpll0_div,
522 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_gpll0_gpll0_div),
523 		.ops = &clk_rcg2_ops,
524 	},
525 };
526 
527 static const struct freq_tbl ftbl_axi_clk_src[] = {
528 	F(19200000, P_XO, 1, 0, 0),
529 	F(75000000, P_GPLL0_DIV, 4, 0, 0),
530 	F(100000000, P_GPLL0, 6, 0, 0),
531 	F(171430000, P_GPLL0, 3.5, 0, 0),
532 	F(200000000, P_GPLL0, 3, 0, 0),
533 	F(320000000, P_MMPLL0, 2.5, 0, 0),
534 	F(400000000, P_MMPLL0, 2, 0, 0),
535 	{ }
536 };
537 
538 static struct clk_rcg2 axi_clk_src = {
539 	.cmd_rcgr = 0x5040,
540 	.hid_width = 5,
541 	.parent_map = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map,
542 	.freq_tbl = ftbl_axi_clk_src,
543 	.clkr.hw.init = &(struct clk_init_data){
544 		.name = "axi_clk_src",
545 		.parent_data = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div,
546 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div),
547 		.ops = &clk_rcg2_ops,
548 	},
549 };
550 
551 static struct clk_rcg2 maxi_clk_src = {
552 	.cmd_rcgr = 0x5090,
553 	.hid_width = 5,
554 	.parent_map = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map,
555 	.freq_tbl = ftbl_axi_clk_src,
556 	.clkr.hw.init = &(struct clk_init_data){
557 		.name = "maxi_clk_src",
558 		.parent_data = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div,
559 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div),
560 		.ops = &clk_rcg2_ops,
561 	},
562 };
563 
564 static struct clk_rcg2_gfx3d gfx3d_clk_src = {
565 	.rcg = {
566 		.cmd_rcgr = 0x4000,
567 		.hid_width = 5,
568 		.parent_map = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_map,
569 		.clkr.hw.init = &(struct clk_init_data){
570 			.name = "gfx3d_clk_src",
571 			.parent_data = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0,
572 			.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0),
573 			.ops = &clk_gfx3d_ops,
574 			.flags = CLK_SET_RATE_PARENT,
575 		},
576 	},
577 	.hws = (struct clk_hw*[]) {
578 		&mmpll9.clkr.hw,
579 		&mmpll2.clkr.hw,
580 		&mmpll8.clkr.hw
581 	},
582 };
583 
584 static const struct freq_tbl ftbl_rbbmtimer_clk_src[] = {
585 	F(19200000, P_XO, 1, 0, 0),
586 	{ }
587 };
588 
589 static struct clk_rcg2 rbbmtimer_clk_src = {
590 	.cmd_rcgr = 0x4090,
591 	.hid_width = 5,
592 	.parent_map = mmss_xo_mmpll0_gpll0_gpll0_div_map,
593 	.freq_tbl = ftbl_rbbmtimer_clk_src,
594 	.clkr.hw.init = &(struct clk_init_data){
595 		.name = "rbbmtimer_clk_src",
596 		.parent_data = mmss_xo_mmpll0_gpll0_gpll0_div,
597 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_gpll0_gpll0_div),
598 		.ops = &clk_rcg2_ops,
599 	},
600 };
601 
602 static struct clk_rcg2 isense_clk_src = {
603 	.cmd_rcgr = 0x4010,
604 	.hid_width = 5,
605 	.parent_map = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div_map,
606 	.clkr.hw.init = &(struct clk_init_data){
607 		.name = "isense_clk_src",
608 		.parent_data = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div,
609 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div),
610 		.ops = &clk_rcg2_ops,
611 	},
612 };
613 
614 static const struct freq_tbl ftbl_rbcpr_clk_src[] = {
615 	F(19200000, P_XO, 1, 0, 0),
616 	F(50000000, P_GPLL0, 12, 0, 0),
617 	{ }
618 };
619 
620 static struct clk_rcg2 rbcpr_clk_src = {
621 	.cmd_rcgr = 0x4060,
622 	.hid_width = 5,
623 	.parent_map = mmss_xo_mmpll0_gpll0_gpll0_div_map,
624 	.freq_tbl = ftbl_rbcpr_clk_src,
625 	.clkr.hw.init = &(struct clk_init_data){
626 		.name = "rbcpr_clk_src",
627 		.parent_data = mmss_xo_mmpll0_gpll0_gpll0_div,
628 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_gpll0_gpll0_div),
629 		.ops = &clk_rcg2_ops,
630 	},
631 };
632 
633 static const struct freq_tbl ftbl_video_core_clk_src[] = {
634 	F(75000000, P_GPLL0_DIV, 4, 0, 0),
635 	F(150000000, P_GPLL0, 4, 0, 0),
636 	F(346666667, P_MMPLL3, 3, 0, 0),
637 	F(520000000, P_MMPLL3, 2, 0, 0),
638 	{ }
639 };
640 
641 static struct clk_rcg2 video_core_clk_src = {
642 	.cmd_rcgr = 0x1000,
643 	.mnd_width = 8,
644 	.hid_width = 5,
645 	.parent_map = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map,
646 	.freq_tbl = ftbl_video_core_clk_src,
647 	.clkr.hw.init = &(struct clk_init_data){
648 		.name = "video_core_clk_src",
649 		.parent_data = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div,
650 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div),
651 		.ops = &clk_rcg2_ops,
652 	},
653 };
654 
655 static struct clk_rcg2 video_subcore0_clk_src = {
656 	.cmd_rcgr = 0x1060,
657 	.mnd_width = 8,
658 	.hid_width = 5,
659 	.parent_map = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map,
660 	.freq_tbl = ftbl_video_core_clk_src,
661 	.clkr.hw.init = &(struct clk_init_data){
662 		.name = "video_subcore0_clk_src",
663 		.parent_data = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div,
664 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div),
665 		.ops = &clk_rcg2_ops,
666 	},
667 };
668 
669 static struct clk_rcg2 video_subcore1_clk_src = {
670 	.cmd_rcgr = 0x1080,
671 	.mnd_width = 8,
672 	.hid_width = 5,
673 	.parent_map = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map,
674 	.freq_tbl = ftbl_video_core_clk_src,
675 	.clkr.hw.init = &(struct clk_init_data){
676 		.name = "video_subcore1_clk_src",
677 		.parent_data = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div,
678 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div),
679 		.ops = &clk_rcg2_ops,
680 	},
681 };
682 
683 static struct clk_rcg2 pclk0_clk_src = {
684 	.cmd_rcgr = 0x2000,
685 	.mnd_width = 8,
686 	.hid_width = 5,
687 	.parent_map = mmss_xo_dsi0pll_dsi1pll_map,
688 	.clkr.hw.init = &(struct clk_init_data){
689 		.name = "pclk0_clk_src",
690 		.parent_data = mmss_xo_dsi0pll_dsi1pll,
691 		.num_parents = ARRAY_SIZE(mmss_xo_dsi0pll_dsi1pll),
692 		.ops = &clk_pixel_ops,
693 		.flags = CLK_SET_RATE_PARENT,
694 	},
695 };
696 
697 static struct clk_rcg2 pclk1_clk_src = {
698 	.cmd_rcgr = 0x2020,
699 	.mnd_width = 8,
700 	.hid_width = 5,
701 	.parent_map = mmss_xo_dsi0pll_dsi1pll_map,
702 	.clkr.hw.init = &(struct clk_init_data){
703 		.name = "pclk1_clk_src",
704 		.parent_data = mmss_xo_dsi0pll_dsi1pll,
705 		.num_parents = ARRAY_SIZE(mmss_xo_dsi0pll_dsi1pll),
706 		.ops = &clk_pixel_ops,
707 		.flags = CLK_SET_RATE_PARENT,
708 	},
709 };
710 
711 static const struct freq_tbl ftbl_mdp_clk_src[] = {
712 	F(85714286, P_GPLL0, 7, 0, 0),
713 	F(100000000, P_GPLL0, 6, 0, 0),
714 	F(150000000, P_GPLL0, 4, 0, 0),
715 	F(171428571, P_GPLL0, 3.5, 0, 0),
716 	F(200000000, P_GPLL0, 3, 0, 0),
717 	F(275000000, P_MMPLL5, 3, 0, 0),
718 	F(300000000, P_GPLL0, 2, 0, 0),
719 	F(330000000, P_MMPLL5, 2.5, 0, 0),
720 	F(412500000, P_MMPLL5, 2, 0, 0),
721 	{ }
722 };
723 
724 static struct clk_rcg2 mdp_clk_src = {
725 	.cmd_rcgr = 0x2040,
726 	.hid_width = 5,
727 	.parent_map = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map,
728 	.freq_tbl = ftbl_mdp_clk_src,
729 	.clkr.hw.init = &(struct clk_init_data){
730 		.name = "mdp_clk_src",
731 		.parent_data = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div,
732 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div),
733 		.ops = &clk_rcg2_ops,
734 	},
735 };
736 
737 static struct freq_tbl extpclk_freq_tbl[] = {
738 	{ .src = P_HDMIPLL },
739 	{ }
740 };
741 
742 static struct clk_rcg2 extpclk_clk_src = {
743 	.cmd_rcgr = 0x2060,
744 	.hid_width = 5,
745 	.parent_map = mmss_xo_hdmi_map,
746 	.freq_tbl = extpclk_freq_tbl,
747 	.clkr.hw.init = &(struct clk_init_data){
748 		.name = "extpclk_clk_src",
749 		.parent_data = mmss_xo_hdmi,
750 		.num_parents = ARRAY_SIZE(mmss_xo_hdmi),
751 		.ops = &clk_byte_ops,
752 		.flags = CLK_SET_RATE_PARENT,
753 	},
754 };
755 
756 static struct freq_tbl ftbl_mdss_vsync_clk[] = {
757 	F(19200000, P_XO, 1, 0, 0),
758 	{ }
759 };
760 
761 static struct clk_rcg2 vsync_clk_src = {
762 	.cmd_rcgr = 0x2080,
763 	.hid_width = 5,
764 	.parent_map = mmss_xo_gpll0_gpll0_div_map,
765 	.freq_tbl = ftbl_mdss_vsync_clk,
766 	.clkr.hw.init = &(struct clk_init_data){
767 		.name = "vsync_clk_src",
768 		.parent_data = mmss_xo_gpll0_gpll0_div,
769 		.num_parents = ARRAY_SIZE(mmss_xo_gpll0_gpll0_div),
770 		.ops = &clk_rcg2_ops,
771 	},
772 };
773 
774 static struct freq_tbl ftbl_mdss_hdmi_clk[] = {
775 	F(19200000, P_XO, 1, 0, 0),
776 	{ }
777 };
778 
779 static struct clk_rcg2 hdmi_clk_src = {
780 	.cmd_rcgr = 0x2100,
781 	.hid_width = 5,
782 	.parent_map = mmss_xo_gpll0_gpll0_div_map,
783 	.freq_tbl = ftbl_mdss_hdmi_clk,
784 	.clkr.hw.init = &(struct clk_init_data){
785 		.name = "hdmi_clk_src",
786 		.parent_data = mmss_xo_gpll0_gpll0_div,
787 		.num_parents = ARRAY_SIZE(mmss_xo_gpll0_gpll0_div),
788 		.ops = &clk_rcg2_ops,
789 	},
790 };
791 
792 static struct clk_rcg2 byte0_clk_src = {
793 	.cmd_rcgr = 0x2120,
794 	.hid_width = 5,
795 	.parent_map = mmss_xo_dsibyte_map,
796 	.clkr.hw.init = &(struct clk_init_data){
797 		.name = "byte0_clk_src",
798 		.parent_data = mmss_xo_dsibyte,
799 		.num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
800 		.ops = &clk_byte2_ops,
801 		.flags = CLK_SET_RATE_PARENT,
802 	},
803 };
804 
805 static struct clk_rcg2 byte1_clk_src = {
806 	.cmd_rcgr = 0x2140,
807 	.hid_width = 5,
808 	.parent_map = mmss_xo_dsibyte_map,
809 	.clkr.hw.init = &(struct clk_init_data){
810 		.name = "byte1_clk_src",
811 		.parent_data = mmss_xo_dsibyte,
812 		.num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
813 		.ops = &clk_byte2_ops,
814 		.flags = CLK_SET_RATE_PARENT,
815 	},
816 };
817 
818 static struct freq_tbl ftbl_mdss_esc0_1_clk[] = {
819 	F(19200000, P_XO, 1, 0, 0),
820 	{ }
821 };
822 
823 static struct clk_rcg2 esc0_clk_src = {
824 	.cmd_rcgr = 0x2160,
825 	.hid_width = 5,
826 	.parent_map = mmss_xo_dsibyte_map,
827 	.freq_tbl = ftbl_mdss_esc0_1_clk,
828 	.clkr.hw.init = &(struct clk_init_data){
829 		.name = "esc0_clk_src",
830 		.parent_data = mmss_xo_dsibyte,
831 		.num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
832 		.ops = &clk_rcg2_ops,
833 	},
834 };
835 
836 static struct clk_rcg2 esc1_clk_src = {
837 	.cmd_rcgr = 0x2180,
838 	.hid_width = 5,
839 	.parent_map = mmss_xo_dsibyte_map,
840 	.freq_tbl = ftbl_mdss_esc0_1_clk,
841 	.clkr.hw.init = &(struct clk_init_data){
842 		.name = "esc1_clk_src",
843 		.parent_data = mmss_xo_dsibyte,
844 		.num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
845 		.ops = &clk_rcg2_ops,
846 	},
847 };
848 
849 static const struct freq_tbl ftbl_camss_gp0_clk_src[] = {
850 	F(10000, P_XO, 16, 1, 120),
851 	F(24000, P_XO, 16, 1, 50),
852 	F(6000000, P_GPLL0_DIV, 10, 1, 5),
853 	F(12000000, P_GPLL0_DIV, 1, 1, 25),
854 	F(13000000, P_GPLL0_DIV, 2, 13, 150),
855 	F(24000000, P_GPLL0_DIV, 1, 2, 25),
856 	{ }
857 };
858 
859 static struct clk_rcg2 camss_gp0_clk_src = {
860 	.cmd_rcgr = 0x3420,
861 	.mnd_width = 8,
862 	.hid_width = 5,
863 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
864 	.freq_tbl = ftbl_camss_gp0_clk_src,
865 	.clkr.hw.init = &(struct clk_init_data){
866 		.name = "camss_gp0_clk_src",
867 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
868 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
869 		.ops = &clk_rcg2_ops,
870 	},
871 };
872 
873 static struct clk_rcg2 camss_gp1_clk_src = {
874 	.cmd_rcgr = 0x3450,
875 	.mnd_width = 8,
876 	.hid_width = 5,
877 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
878 	.freq_tbl = ftbl_camss_gp0_clk_src,
879 	.clkr.hw.init = &(struct clk_init_data){
880 		.name = "camss_gp1_clk_src",
881 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
882 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
883 		.ops = &clk_rcg2_ops,
884 	},
885 };
886 
887 static const struct freq_tbl ftbl_mclk0_clk_src[] = {
888 	F(4800000, P_XO, 4, 0, 0),
889 	F(6000000, P_GPLL0_DIV, 10, 1, 5),
890 	F(8000000, P_GPLL0_DIV, 1, 2, 75),
891 	F(9600000, P_XO, 2, 0, 0),
892 	F(16666667, P_GPLL0_DIV, 2, 1, 9),
893 	F(19200000, P_XO, 1, 0, 0),
894 	F(24000000, P_GPLL0_DIV, 1, 2, 25),
895 	F(33333333, P_GPLL0_DIV, 1, 1, 9),
896 	F(48000000, P_GPLL0, 1, 2, 25),
897 	F(66666667, P_GPLL0, 1, 1, 9),
898 	{ }
899 };
900 
901 static struct clk_rcg2 mclk0_clk_src = {
902 	.cmd_rcgr = 0x3360,
903 	.mnd_width = 8,
904 	.hid_width = 5,
905 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
906 	.freq_tbl = ftbl_mclk0_clk_src,
907 	.clkr.hw.init = &(struct clk_init_data){
908 		.name = "mclk0_clk_src",
909 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
910 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
911 		.ops = &clk_rcg2_ops,
912 	},
913 };
914 
915 static struct clk_rcg2 mclk1_clk_src = {
916 	.cmd_rcgr = 0x3390,
917 	.mnd_width = 8,
918 	.hid_width = 5,
919 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
920 	.freq_tbl = ftbl_mclk0_clk_src,
921 	.clkr.hw.init = &(struct clk_init_data){
922 		.name = "mclk1_clk_src",
923 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
924 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
925 		.ops = &clk_rcg2_ops,
926 	},
927 };
928 
929 static struct clk_rcg2 mclk2_clk_src = {
930 	.cmd_rcgr = 0x33c0,
931 	.mnd_width = 8,
932 	.hid_width = 5,
933 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
934 	.freq_tbl = ftbl_mclk0_clk_src,
935 	.clkr.hw.init = &(struct clk_init_data){
936 		.name = "mclk2_clk_src",
937 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
938 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
939 		.ops = &clk_rcg2_ops,
940 	},
941 };
942 
943 static struct clk_rcg2 mclk3_clk_src = {
944 	.cmd_rcgr = 0x33f0,
945 	.mnd_width = 8,
946 	.hid_width = 5,
947 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
948 	.freq_tbl = ftbl_mclk0_clk_src,
949 	.clkr.hw.init = &(struct clk_init_data){
950 		.name = "mclk3_clk_src",
951 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
952 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
953 		.ops = &clk_rcg2_ops,
954 	},
955 };
956 
957 static const struct freq_tbl ftbl_cci_clk_src[] = {
958 	F(19200000, P_XO, 1, 0, 0),
959 	F(37500000, P_GPLL0, 16, 0, 0),
960 	F(50000000, P_GPLL0, 12, 0, 0),
961 	F(100000000, P_GPLL0, 6, 0, 0),
962 	{ }
963 };
964 
965 static struct clk_rcg2 cci_clk_src = {
966 	.cmd_rcgr = 0x3300,
967 	.mnd_width = 8,
968 	.hid_width = 5,
969 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
970 	.freq_tbl = ftbl_cci_clk_src,
971 	.clkr.hw.init = &(struct clk_init_data){
972 		.name = "cci_clk_src",
973 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
974 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
975 		.ops = &clk_rcg2_ops,
976 	},
977 };
978 
979 static const struct freq_tbl ftbl_csi0phytimer_clk_src[] = {
980 	F(100000000, P_GPLL0_DIV, 3, 0, 0),
981 	F(200000000, P_GPLL0, 3, 0, 0),
982 	F(266666667, P_MMPLL0, 3, 0, 0),
983 	{ }
984 };
985 
986 static struct clk_rcg2 csi0phytimer_clk_src = {
987 	.cmd_rcgr = 0x3000,
988 	.hid_width = 5,
989 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
990 	.freq_tbl = ftbl_csi0phytimer_clk_src,
991 	.clkr.hw.init = &(struct clk_init_data){
992 		.name = "csi0phytimer_clk_src",
993 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
994 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
995 		.ops = &clk_rcg2_ops,
996 	},
997 };
998 
999 static struct clk_rcg2 csi1phytimer_clk_src = {
1000 	.cmd_rcgr = 0x3030,
1001 	.hid_width = 5,
1002 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1003 	.freq_tbl = ftbl_csi0phytimer_clk_src,
1004 	.clkr.hw.init = &(struct clk_init_data){
1005 		.name = "csi1phytimer_clk_src",
1006 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1007 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1008 		.ops = &clk_rcg2_ops,
1009 	},
1010 };
1011 
1012 static struct clk_rcg2 csi2phytimer_clk_src = {
1013 	.cmd_rcgr = 0x3060,
1014 	.hid_width = 5,
1015 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1016 	.freq_tbl = ftbl_csi0phytimer_clk_src,
1017 	.clkr.hw.init = &(struct clk_init_data){
1018 		.name = "csi2phytimer_clk_src",
1019 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1020 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1021 		.ops = &clk_rcg2_ops,
1022 	},
1023 };
1024 
1025 static const struct freq_tbl ftbl_csiphy0_3p_clk_src[] = {
1026 	F(100000000, P_GPLL0_DIV, 3, 0, 0),
1027 	F(200000000, P_GPLL0, 3, 0, 0),
1028 	F(320000000, P_MMPLL4, 3, 0, 0),
1029 	F(384000000, P_MMPLL4, 2.5, 0, 0),
1030 	{ }
1031 };
1032 
1033 static struct clk_rcg2 csiphy0_3p_clk_src = {
1034 	.cmd_rcgr = 0x3240,
1035 	.hid_width = 5,
1036 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1037 	.freq_tbl = ftbl_csiphy0_3p_clk_src,
1038 	.clkr.hw.init = &(struct clk_init_data){
1039 		.name = "csiphy0_3p_clk_src",
1040 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1041 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1042 		.ops = &clk_rcg2_ops,
1043 	},
1044 };
1045 
1046 static struct clk_rcg2 csiphy1_3p_clk_src = {
1047 	.cmd_rcgr = 0x3260,
1048 	.hid_width = 5,
1049 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1050 	.freq_tbl = ftbl_csiphy0_3p_clk_src,
1051 	.clkr.hw.init = &(struct clk_init_data){
1052 		.name = "csiphy1_3p_clk_src",
1053 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1054 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1055 		.ops = &clk_rcg2_ops,
1056 	},
1057 };
1058 
1059 static struct clk_rcg2 csiphy2_3p_clk_src = {
1060 	.cmd_rcgr = 0x3280,
1061 	.hid_width = 5,
1062 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1063 	.freq_tbl = ftbl_csiphy0_3p_clk_src,
1064 	.clkr.hw.init = &(struct clk_init_data){
1065 		.name = "csiphy2_3p_clk_src",
1066 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1067 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1068 		.ops = &clk_rcg2_ops,
1069 	},
1070 };
1071 
1072 static const struct freq_tbl ftbl_jpeg0_clk_src[] = {
1073 	F(75000000, P_GPLL0_DIV, 4, 0, 0),
1074 	F(150000000, P_GPLL0, 4, 0, 0),
1075 	F(228571429, P_MMPLL0, 3.5, 0, 0),
1076 	F(266666667, P_MMPLL0, 3, 0, 0),
1077 	F(320000000, P_MMPLL0, 2.5, 0, 0),
1078 	F(480000000, P_MMPLL4, 2, 0, 0),
1079 	{ }
1080 };
1081 
1082 static struct clk_rcg2 jpeg0_clk_src = {
1083 	.cmd_rcgr = 0x3500,
1084 	.hid_width = 5,
1085 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1086 	.freq_tbl = ftbl_jpeg0_clk_src,
1087 	.clkr.hw.init = &(struct clk_init_data){
1088 		.name = "jpeg0_clk_src",
1089 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1090 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1091 		.ops = &clk_rcg2_ops,
1092 	},
1093 };
1094 
1095 static const struct freq_tbl ftbl_jpeg2_clk_src[] = {
1096 	F(75000000, P_GPLL0_DIV, 4, 0, 0),
1097 	F(150000000, P_GPLL0, 4, 0, 0),
1098 	F(228571429, P_MMPLL0, 3.5, 0, 0),
1099 	F(266666667, P_MMPLL0, 3, 0, 0),
1100 	F(320000000, P_MMPLL0, 2.5, 0, 0),
1101 	{ }
1102 };
1103 
1104 static struct clk_rcg2 jpeg2_clk_src = {
1105 	.cmd_rcgr = 0x3540,
1106 	.hid_width = 5,
1107 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1108 	.freq_tbl = ftbl_jpeg2_clk_src,
1109 	.clkr.hw.init = &(struct clk_init_data){
1110 		.name = "jpeg2_clk_src",
1111 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1112 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1113 		.ops = &clk_rcg2_ops,
1114 	},
1115 };
1116 
1117 static struct clk_rcg2 jpeg_dma_clk_src = {
1118 	.cmd_rcgr = 0x3560,
1119 	.hid_width = 5,
1120 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1121 	.freq_tbl = ftbl_jpeg0_clk_src,
1122 	.clkr.hw.init = &(struct clk_init_data){
1123 		.name = "jpeg_dma_clk_src",
1124 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1125 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1126 		.ops = &clk_rcg2_ops,
1127 	},
1128 };
1129 
1130 static const struct freq_tbl ftbl_vfe0_clk_src[] = {
1131 	F(75000000, P_GPLL0_DIV, 4, 0, 0),
1132 	F(100000000, P_GPLL0_DIV, 3, 0, 0),
1133 	F(300000000, P_GPLL0, 2, 0, 0),
1134 	F(320000000, P_MMPLL0, 2.5, 0, 0),
1135 	F(480000000, P_MMPLL4, 2, 0, 0),
1136 	F(600000000, P_GPLL0, 1, 0, 0),
1137 	{ }
1138 };
1139 
1140 static struct clk_rcg2 vfe0_clk_src = {
1141 	.cmd_rcgr = 0x3600,
1142 	.hid_width = 5,
1143 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1144 	.freq_tbl = ftbl_vfe0_clk_src,
1145 	.clkr.hw.init = &(struct clk_init_data){
1146 		.name = "vfe0_clk_src",
1147 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1148 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1149 		.ops = &clk_rcg2_ops,
1150 	},
1151 };
1152 
1153 static struct clk_rcg2 vfe1_clk_src = {
1154 	.cmd_rcgr = 0x3620,
1155 	.hid_width = 5,
1156 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1157 	.freq_tbl = ftbl_vfe0_clk_src,
1158 	.clkr.hw.init = &(struct clk_init_data){
1159 		.name = "vfe1_clk_src",
1160 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1161 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1162 		.ops = &clk_rcg2_ops,
1163 	},
1164 };
1165 
1166 static const struct freq_tbl ftbl_cpp_clk_src[] = {
1167 	F(100000000, P_GPLL0_DIV, 3, 0, 0),
1168 	F(200000000, P_GPLL0, 3, 0, 0),
1169 	F(320000000, P_MMPLL0, 2.5, 0, 0),
1170 	F(480000000, P_MMPLL4, 2, 0, 0),
1171 	F(640000000, P_MMPLL4, 1.5, 0, 0),
1172 	{ }
1173 };
1174 
1175 static struct clk_rcg2 cpp_clk_src = {
1176 	.cmd_rcgr = 0x3640,
1177 	.hid_width = 5,
1178 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1179 	.freq_tbl = ftbl_cpp_clk_src,
1180 	.clkr.hw.init = &(struct clk_init_data){
1181 		.name = "cpp_clk_src",
1182 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1183 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1184 		.ops = &clk_rcg2_ops,
1185 	},
1186 };
1187 
1188 static const struct freq_tbl ftbl_csi0_clk_src[] = {
1189 	F(100000000, P_GPLL0_DIV, 3, 0, 0),
1190 	F(200000000, P_GPLL0, 3, 0, 0),
1191 	F(266666667, P_MMPLL0, 3, 0, 0),
1192 	F(480000000, P_MMPLL4, 2, 0, 0),
1193 	F(600000000, P_GPLL0, 1, 0, 0),
1194 	{ }
1195 };
1196 
1197 static struct clk_rcg2 csi0_clk_src = {
1198 	.cmd_rcgr = 0x3090,
1199 	.hid_width = 5,
1200 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1201 	.freq_tbl = ftbl_csi0_clk_src,
1202 	.clkr.hw.init = &(struct clk_init_data){
1203 		.name = "csi0_clk_src",
1204 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1205 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1206 		.ops = &clk_rcg2_ops,
1207 	},
1208 };
1209 
1210 static struct clk_rcg2 csi1_clk_src = {
1211 	.cmd_rcgr = 0x3100,
1212 	.hid_width = 5,
1213 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1214 	.freq_tbl = ftbl_csi0_clk_src,
1215 	.clkr.hw.init = &(struct clk_init_data){
1216 		.name = "csi1_clk_src",
1217 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1218 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1219 		.ops = &clk_rcg2_ops,
1220 	},
1221 };
1222 
1223 static struct clk_rcg2 csi2_clk_src = {
1224 	.cmd_rcgr = 0x3160,
1225 	.hid_width = 5,
1226 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1227 	.freq_tbl = ftbl_csi0_clk_src,
1228 	.clkr.hw.init = &(struct clk_init_data){
1229 		.name = "csi2_clk_src",
1230 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1231 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1232 		.ops = &clk_rcg2_ops,
1233 	},
1234 };
1235 
1236 static struct clk_rcg2 csi3_clk_src = {
1237 	.cmd_rcgr = 0x31c0,
1238 	.hid_width = 5,
1239 	.parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
1240 	.freq_tbl = ftbl_csi0_clk_src,
1241 	.clkr.hw.init = &(struct clk_init_data){
1242 		.name = "csi3_clk_src",
1243 		.parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
1244 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
1245 		.ops = &clk_rcg2_ops,
1246 	},
1247 };
1248 
1249 static const struct freq_tbl ftbl_fd_core_clk_src[] = {
1250 	F(100000000, P_GPLL0_DIV, 3, 0, 0),
1251 	F(200000000, P_GPLL0, 3, 0, 0),
1252 	F(400000000, P_MMPLL0, 2, 0, 0),
1253 	{ }
1254 };
1255 
1256 static struct clk_rcg2 fd_core_clk_src = {
1257 	.cmd_rcgr = 0x3b00,
1258 	.hid_width = 5,
1259 	.parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
1260 	.freq_tbl = ftbl_fd_core_clk_src,
1261 	.clkr.hw.init = &(struct clk_init_data){
1262 		.name = "fd_core_clk_src",
1263 		.parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
1264 		.num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
1265 		.ops = &clk_rcg2_ops,
1266 	},
1267 };
1268 
1269 static struct clk_branch mmss_mmagic_ahb_clk = {
1270 	.halt_reg = 0x5024,
1271 	.clkr = {
1272 		.enable_reg = 0x5024,
1273 		.enable_mask = BIT(0),
1274 		.hw.init = &(struct clk_init_data){
1275 			.name = "mmss_mmagic_ahb_clk",
1276 			.parent_hws = (const struct clk_hw*[]){
1277 				&ahb_clk_src.clkr.hw
1278 			},
1279 			.num_parents = 1,
1280 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1281 			.ops = &clk_branch2_ops,
1282 		},
1283 	},
1284 };
1285 
1286 static struct clk_branch mmss_mmagic_cfg_ahb_clk = {
1287 	.halt_reg = 0x5054,
1288 	.clkr = {
1289 		.enable_reg = 0x5054,
1290 		.enable_mask = BIT(0),
1291 		.hw.init = &(struct clk_init_data){
1292 			.name = "mmss_mmagic_cfg_ahb_clk",
1293 			.parent_hws = (const struct clk_hw*[]){
1294 				&ahb_clk_src.clkr.hw
1295 			},
1296 			.num_parents = 1,
1297 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1298 			.ops = &clk_branch2_ops,
1299 		},
1300 	},
1301 };
1302 
1303 static struct clk_branch mmss_misc_ahb_clk = {
1304 	.halt_reg = 0x5018,
1305 	.clkr = {
1306 		.enable_reg = 0x5018,
1307 		.enable_mask = BIT(0),
1308 		.hw.init = &(struct clk_init_data){
1309 			.name = "mmss_misc_ahb_clk",
1310 			.parent_hws = (const struct clk_hw*[]){
1311 				&ahb_clk_src.clkr.hw
1312 			},
1313 			.num_parents = 1,
1314 			.flags = CLK_SET_RATE_PARENT,
1315 			.ops = &clk_branch2_ops,
1316 		},
1317 	},
1318 };
1319 
1320 static struct clk_branch mmss_misc_cxo_clk = {
1321 	.halt_reg = 0x5014,
1322 	.clkr = {
1323 		.enable_reg = 0x5014,
1324 		.enable_mask = BIT(0),
1325 		.hw.init = &(struct clk_init_data){
1326 			.name = "mmss_misc_cxo_clk",
1327 			.parent_data = (const struct clk_parent_data[]){
1328 				{ .fw_name = "xo", .name = "xo_board" },
1329 			},
1330 			.num_parents = 1,
1331 			.ops = &clk_branch2_ops,
1332 		},
1333 	},
1334 };
1335 
1336 static struct clk_branch mmss_mmagic_maxi_clk = {
1337 	.halt_reg = 0x5074,
1338 	.clkr = {
1339 		.enable_reg = 0x5074,
1340 		.enable_mask = BIT(0),
1341 		.hw.init = &(struct clk_init_data){
1342 			.name = "mmss_mmagic_maxi_clk",
1343 			.parent_hws = (const struct clk_hw*[]){
1344 				&maxi_clk_src.clkr.hw
1345 			},
1346 			.num_parents = 1,
1347 			.flags = CLK_SET_RATE_PARENT,
1348 			.ops = &clk_branch2_ops,
1349 		},
1350 	},
1351 };
1352 
1353 static struct clk_branch mmagic_camss_axi_clk = {
1354 	.halt_reg = 0x3c44,
1355 	.clkr = {
1356 		.enable_reg = 0x3c44,
1357 		.enable_mask = BIT(0),
1358 		.hw.init = &(struct clk_init_data){
1359 			.name = "mmagic_camss_axi_clk",
1360 			.parent_hws = (const struct clk_hw*[]){
1361 				&axi_clk_src.clkr.hw
1362 			},
1363 			.num_parents = 1,
1364 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1365 			.ops = &clk_branch2_ops,
1366 		},
1367 	},
1368 };
1369 
1370 static struct clk_branch mmagic_camss_noc_cfg_ahb_clk = {
1371 	.halt_reg = 0x3c48,
1372 	.clkr = {
1373 		.enable_reg = 0x3c48,
1374 		.enable_mask = BIT(0),
1375 		.hw.init = &(struct clk_init_data){
1376 			.name = "mmagic_camss_noc_cfg_ahb_clk",
1377 			.parent_data = (const struct clk_parent_data[]){
1378 				{ .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
1379 			},
1380 			.num_parents = 1,
1381 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1382 			.ops = &clk_branch2_ops,
1383 		},
1384 	},
1385 };
1386 
1387 static struct clk_branch smmu_vfe_ahb_clk = {
1388 	.halt_reg = 0x3c04,
1389 	.clkr = {
1390 		.enable_reg = 0x3c04,
1391 		.enable_mask = BIT(0),
1392 		.hw.init = &(struct clk_init_data){
1393 			.name = "smmu_vfe_ahb_clk",
1394 			.parent_hws = (const struct clk_hw*[]){
1395 				&ahb_clk_src.clkr.hw
1396 			},
1397 			.num_parents = 1,
1398 			.flags = CLK_SET_RATE_PARENT,
1399 			.ops = &clk_branch2_ops,
1400 		},
1401 	},
1402 };
1403 
1404 static struct clk_branch smmu_vfe_axi_clk = {
1405 	.halt_reg = 0x3c08,
1406 	.clkr = {
1407 		.enable_reg = 0x3c08,
1408 		.enable_mask = BIT(0),
1409 		.hw.init = &(struct clk_init_data){
1410 			.name = "smmu_vfe_axi_clk",
1411 			.parent_hws = (const struct clk_hw*[]){
1412 				&axi_clk_src.clkr.hw
1413 			},
1414 			.num_parents = 1,
1415 			.flags = CLK_SET_RATE_PARENT,
1416 			.ops = &clk_branch2_ops,
1417 		},
1418 	},
1419 };
1420 
1421 static struct clk_branch smmu_cpp_ahb_clk = {
1422 	.halt_reg = 0x3c14,
1423 	.clkr = {
1424 		.enable_reg = 0x3c14,
1425 		.enable_mask = BIT(0),
1426 		.hw.init = &(struct clk_init_data){
1427 			.name = "smmu_cpp_ahb_clk",
1428 			.parent_hws = (const struct clk_hw*[]){
1429 				&ahb_clk_src.clkr.hw
1430 			},
1431 			.num_parents = 1,
1432 			.flags = CLK_SET_RATE_PARENT,
1433 			.ops = &clk_branch2_ops,
1434 		},
1435 	},
1436 };
1437 
1438 static struct clk_branch smmu_cpp_axi_clk = {
1439 	.halt_reg = 0x3c18,
1440 	.clkr = {
1441 		.enable_reg = 0x3c18,
1442 		.enable_mask = BIT(0),
1443 		.hw.init = &(struct clk_init_data){
1444 			.name = "smmu_cpp_axi_clk",
1445 			.parent_hws = (const struct clk_hw*[]){
1446 				&axi_clk_src.clkr.hw
1447 			},
1448 			.num_parents = 1,
1449 			.flags = CLK_SET_RATE_PARENT,
1450 			.ops = &clk_branch2_ops,
1451 		},
1452 	},
1453 };
1454 
1455 static struct clk_branch smmu_jpeg_ahb_clk = {
1456 	.halt_reg = 0x3c24,
1457 	.clkr = {
1458 		.enable_reg = 0x3c24,
1459 		.enable_mask = BIT(0),
1460 		.hw.init = &(struct clk_init_data){
1461 			.name = "smmu_jpeg_ahb_clk",
1462 			.parent_hws = (const struct clk_hw*[]){
1463 				&ahb_clk_src.clkr.hw
1464 			},
1465 			.num_parents = 1,
1466 			.flags = CLK_SET_RATE_PARENT,
1467 			.ops = &clk_branch2_ops,
1468 		},
1469 	},
1470 };
1471 
1472 static struct clk_branch smmu_jpeg_axi_clk = {
1473 	.halt_reg = 0x3c28,
1474 	.clkr = {
1475 		.enable_reg = 0x3c28,
1476 		.enable_mask = BIT(0),
1477 		.hw.init = &(struct clk_init_data){
1478 			.name = "smmu_jpeg_axi_clk",
1479 			.parent_hws = (const struct clk_hw*[]){
1480 				&axi_clk_src.clkr.hw
1481 			},
1482 			.num_parents = 1,
1483 			.flags = CLK_SET_RATE_PARENT,
1484 			.ops = &clk_branch2_ops,
1485 		},
1486 	},
1487 };
1488 
1489 static struct clk_branch mmagic_mdss_axi_clk = {
1490 	.halt_reg = 0x2474,
1491 	.clkr = {
1492 		.enable_reg = 0x2474,
1493 		.enable_mask = BIT(0),
1494 		.hw.init = &(struct clk_init_data){
1495 			.name = "mmagic_mdss_axi_clk",
1496 			.parent_hws = (const struct clk_hw*[]){
1497 				&axi_clk_src.clkr.hw
1498 			},
1499 			.num_parents = 1,
1500 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1501 			.ops = &clk_branch2_ops,
1502 		},
1503 	},
1504 };
1505 
1506 static struct clk_branch mmagic_mdss_noc_cfg_ahb_clk = {
1507 	.halt_reg = 0x2478,
1508 	.clkr = {
1509 		.enable_reg = 0x2478,
1510 		.enable_mask = BIT(0),
1511 		.hw.init = &(struct clk_init_data){
1512 			.name = "mmagic_mdss_noc_cfg_ahb_clk",
1513 			.parent_data = (const struct clk_parent_data[]){
1514 				{ .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
1515 			},
1516 			.num_parents = 1,
1517 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1518 			.ops = &clk_branch2_ops,
1519 		},
1520 	},
1521 };
1522 
1523 static struct clk_branch smmu_rot_ahb_clk = {
1524 	.halt_reg = 0x2444,
1525 	.clkr = {
1526 		.enable_reg = 0x2444,
1527 		.enable_mask = BIT(0),
1528 		.hw.init = &(struct clk_init_data){
1529 			.name = "smmu_rot_ahb_clk",
1530 			.parent_hws = (const struct clk_hw*[]){
1531 				&ahb_clk_src.clkr.hw
1532 			},
1533 			.num_parents = 1,
1534 			.flags = CLK_SET_RATE_PARENT,
1535 			.ops = &clk_branch2_ops,
1536 		},
1537 	},
1538 };
1539 
1540 static struct clk_branch smmu_rot_axi_clk = {
1541 	.halt_reg = 0x2448,
1542 	.clkr = {
1543 		.enable_reg = 0x2448,
1544 		.enable_mask = BIT(0),
1545 		.hw.init = &(struct clk_init_data){
1546 			.name = "smmu_rot_axi_clk",
1547 			.parent_hws = (const struct clk_hw*[]){
1548 				&axi_clk_src.clkr.hw
1549 			},
1550 			.num_parents = 1,
1551 			.flags = CLK_SET_RATE_PARENT,
1552 			.ops = &clk_branch2_ops,
1553 		},
1554 	},
1555 };
1556 
1557 static struct clk_branch smmu_mdp_ahb_clk = {
1558 	.halt_reg = 0x2454,
1559 	.clkr = {
1560 		.enable_reg = 0x2454,
1561 		.enable_mask = BIT(0),
1562 		.hw.init = &(struct clk_init_data){
1563 			.name = "smmu_mdp_ahb_clk",
1564 			.parent_hws = (const struct clk_hw*[]){
1565 				&ahb_clk_src.clkr.hw
1566 			},
1567 			.num_parents = 1,
1568 			.flags = CLK_SET_RATE_PARENT,
1569 			.ops = &clk_branch2_ops,
1570 		},
1571 	},
1572 };
1573 
1574 static struct clk_branch smmu_mdp_axi_clk = {
1575 	.halt_reg = 0x2458,
1576 	.clkr = {
1577 		.enable_reg = 0x2458,
1578 		.enable_mask = BIT(0),
1579 		.hw.init = &(struct clk_init_data){
1580 			.name = "smmu_mdp_axi_clk",
1581 			.parent_hws = (const struct clk_hw*[]){
1582 				&axi_clk_src.clkr.hw
1583 			},
1584 			.num_parents = 1,
1585 			.flags = CLK_SET_RATE_PARENT,
1586 			.ops = &clk_branch2_ops,
1587 		},
1588 	},
1589 };
1590 
1591 static struct clk_branch mmagic_video_axi_clk = {
1592 	.halt_reg = 0x1194,
1593 	.clkr = {
1594 		.enable_reg = 0x1194,
1595 		.enable_mask = BIT(0),
1596 		.hw.init = &(struct clk_init_data){
1597 			.name = "mmagic_video_axi_clk",
1598 			.parent_hws = (const struct clk_hw*[]){
1599 				&axi_clk_src.clkr.hw
1600 			},
1601 			.num_parents = 1,
1602 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1603 			.ops = &clk_branch2_ops,
1604 		},
1605 	},
1606 };
1607 
1608 static struct clk_branch mmagic_video_noc_cfg_ahb_clk = {
1609 	.halt_reg = 0x1198,
1610 	.clkr = {
1611 		.enable_reg = 0x1198,
1612 		.enable_mask = BIT(0),
1613 		.hw.init = &(struct clk_init_data){
1614 			.name = "mmagic_video_noc_cfg_ahb_clk",
1615 			.parent_data = (const struct clk_parent_data[]){
1616 				{ .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
1617 			},
1618 			.num_parents = 1,
1619 			.flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1620 			.ops = &clk_branch2_ops,
1621 		},
1622 	},
1623 };
1624 
1625 static struct clk_branch smmu_video_ahb_clk = {
1626 	.halt_reg = 0x1174,
1627 	.clkr = {
1628 		.enable_reg = 0x1174,
1629 		.enable_mask = BIT(0),
1630 		.hw.init = &(struct clk_init_data){
1631 			.name = "smmu_video_ahb_clk",
1632 			.parent_hws = (const struct clk_hw*[]){
1633 				&ahb_clk_src.clkr.hw
1634 			},
1635 			.num_parents = 1,
1636 			.flags = CLK_SET_RATE_PARENT,
1637 			.ops = &clk_branch2_ops,
1638 		},
1639 	},
1640 };
1641 
1642 static struct clk_branch smmu_video_axi_clk = {
1643 	.halt_reg = 0x1178,
1644 	.clkr = {
1645 		.enable_reg = 0x1178,
1646 		.enable_mask = BIT(0),
1647 		.hw.init = &(struct clk_init_data){
1648 			.name = "smmu_video_axi_clk",
1649 			.parent_hws = (const struct clk_hw*[]){
1650 				&axi_clk_src.clkr.hw
1651 			},
1652 			.num_parents = 1,
1653 			.flags = CLK_SET_RATE_PARENT,
1654 			.ops = &clk_branch2_ops,
1655 		},
1656 	},
1657 };
1658 
1659 static struct clk_branch mmagic_bimc_noc_cfg_ahb_clk = {
1660 	.halt_reg = 0x5298,
1661 	.clkr = {
1662 		.enable_reg = 0x5298,
1663 		.enable_mask = BIT(0),
1664 		.hw.init = &(struct clk_init_data){
1665 			.name = "mmagic_bimc_noc_cfg_ahb_clk",
1666 			.parent_data = (const struct clk_parent_data[]){
1667 				{ .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
1668 			},
1669 			.num_parents = 1,
1670 			.flags = CLK_SET_RATE_PARENT,
1671 			.ops = &clk_branch2_ops,
1672 		},
1673 	},
1674 };
1675 
1676 static struct clk_branch gpu_gx_gfx3d_clk = {
1677 	.halt_reg = 0x4028,
1678 	.clkr = {
1679 		.enable_reg = 0x4028,
1680 		.enable_mask = BIT(0),
1681 		.hw.init = &(struct clk_init_data){
1682 			.name = "gpu_gx_gfx3d_clk",
1683 			.parent_hws = (const struct clk_hw*[]){
1684 				&gfx3d_clk_src.rcg.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 gpu_gx_rbbmtimer_clk = {
1694 	.halt_reg = 0x40b0,
1695 	.clkr = {
1696 		.enable_reg = 0x40b0,
1697 		.enable_mask = BIT(0),
1698 		.hw.init = &(struct clk_init_data){
1699 			.name = "gpu_gx_rbbmtimer_clk",
1700 			.parent_hws = (const struct clk_hw*[]){
1701 				&rbbmtimer_clk_src.clkr.hw
1702 			},
1703 			.num_parents = 1,
1704 			.flags = CLK_SET_RATE_PARENT,
1705 			.ops = &clk_branch2_ops,
1706 		},
1707 	},
1708 };
1709 
1710 static struct clk_branch gpu_ahb_clk = {
1711 	.halt_reg = 0x403c,
1712 	.clkr = {
1713 		.enable_reg = 0x403c,
1714 		.enable_mask = BIT(0),
1715 		.hw.init = &(struct clk_init_data){
1716 			.name = "gpu_ahb_clk",
1717 			.parent_hws = (const struct clk_hw*[]){
1718 				&ahb_clk_src.clkr.hw
1719 			},
1720 			.num_parents = 1,
1721 			.flags = CLK_SET_RATE_PARENT,
1722 			.ops = &clk_branch2_ops,
1723 		},
1724 	},
1725 };
1726 
1727 static struct clk_branch gpu_aon_isense_clk = {
1728 	.halt_reg = 0x4044,
1729 	.clkr = {
1730 		.enable_reg = 0x4044,
1731 		.enable_mask = BIT(0),
1732 		.hw.init = &(struct clk_init_data){
1733 			.name = "gpu_aon_isense_clk",
1734 			.parent_hws = (const struct clk_hw*[]){
1735 				&isense_clk_src.clkr.hw
1736 			},
1737 			.num_parents = 1,
1738 			.flags = CLK_SET_RATE_PARENT,
1739 			.ops = &clk_branch2_ops,
1740 		},
1741 	},
1742 };
1743 
1744 static struct clk_branch vmem_maxi_clk = {
1745 	.halt_reg = 0x1204,
1746 	.clkr = {
1747 		.enable_reg = 0x1204,
1748 		.enable_mask = BIT(0),
1749 		.hw.init = &(struct clk_init_data){
1750 			.name = "vmem_maxi_clk",
1751 			.parent_hws = (const struct clk_hw*[]){
1752 				&maxi_clk_src.clkr.hw
1753 			},
1754 			.num_parents = 1,
1755 			.flags = CLK_SET_RATE_PARENT,
1756 			.ops = &clk_branch2_ops,
1757 		},
1758 	},
1759 };
1760 
1761 static struct clk_branch vmem_ahb_clk = {
1762 	.halt_reg = 0x1208,
1763 	.clkr = {
1764 		.enable_reg = 0x1208,
1765 		.enable_mask = BIT(0),
1766 		.hw.init = &(struct clk_init_data){
1767 			.name = "vmem_ahb_clk",
1768 			.parent_hws = (const struct clk_hw*[]){
1769 				&ahb_clk_src.clkr.hw
1770 			},
1771 			.num_parents = 1,
1772 			.flags = CLK_SET_RATE_PARENT,
1773 			.ops = &clk_branch2_ops,
1774 		},
1775 	},
1776 };
1777 
1778 static struct clk_branch mmss_rbcpr_clk = {
1779 	.halt_reg = 0x4084,
1780 	.clkr = {
1781 		.enable_reg = 0x4084,
1782 		.enable_mask = BIT(0),
1783 		.hw.init = &(struct clk_init_data){
1784 			.name = "mmss_rbcpr_clk",
1785 			.parent_hws = (const struct clk_hw*[]){
1786 				&rbcpr_clk_src.clkr.hw
1787 			},
1788 			.num_parents = 1,
1789 			.flags = CLK_SET_RATE_PARENT,
1790 			.ops = &clk_branch2_ops,
1791 		},
1792 	},
1793 };
1794 
1795 static struct clk_branch mmss_rbcpr_ahb_clk = {
1796 	.halt_reg = 0x4088,
1797 	.clkr = {
1798 		.enable_reg = 0x4088,
1799 		.enable_mask = BIT(0),
1800 		.hw.init = &(struct clk_init_data){
1801 			.name = "mmss_rbcpr_ahb_clk",
1802 			.parent_hws = (const struct clk_hw*[]){
1803 				&ahb_clk_src.clkr.hw
1804 			},
1805 			.num_parents = 1,
1806 			.flags = CLK_SET_RATE_PARENT,
1807 			.ops = &clk_branch2_ops,
1808 		},
1809 	},
1810 };
1811 
1812 static struct clk_branch video_core_clk = {
1813 	.halt_reg = 0x1028,
1814 	.clkr = {
1815 		.enable_reg = 0x1028,
1816 		.enable_mask = BIT(0),
1817 		.hw.init = &(struct clk_init_data){
1818 			.name = "video_core_clk",
1819 			.parent_hws = (const struct clk_hw*[]){
1820 				&video_core_clk_src.clkr.hw
1821 			},
1822 			.num_parents = 1,
1823 			.flags = CLK_SET_RATE_PARENT,
1824 			.ops = &clk_branch2_ops,
1825 		},
1826 	},
1827 };
1828 
1829 static struct clk_branch video_axi_clk = {
1830 	.halt_reg = 0x1034,
1831 	.clkr = {
1832 		.enable_reg = 0x1034,
1833 		.enable_mask = BIT(0),
1834 		.hw.init = &(struct clk_init_data){
1835 			.name = "video_axi_clk",
1836 			.parent_hws = (const struct clk_hw*[]){
1837 				&axi_clk_src.clkr.hw
1838 			},
1839 			.num_parents = 1,
1840 			.flags = CLK_SET_RATE_PARENT,
1841 			.ops = &clk_branch2_ops,
1842 		},
1843 	},
1844 };
1845 
1846 static struct clk_branch video_maxi_clk = {
1847 	.halt_reg = 0x1038,
1848 	.clkr = {
1849 		.enable_reg = 0x1038,
1850 		.enable_mask = BIT(0),
1851 		.hw.init = &(struct clk_init_data){
1852 			.name = "video_maxi_clk",
1853 			.parent_hws = (const struct clk_hw*[]){
1854 				&maxi_clk_src.clkr.hw
1855 			},
1856 			.num_parents = 1,
1857 			.flags = CLK_SET_RATE_PARENT,
1858 			.ops = &clk_branch2_ops,
1859 		},
1860 	},
1861 };
1862 
1863 static struct clk_branch video_ahb_clk = {
1864 	.halt_reg = 0x1030,
1865 	.clkr = {
1866 		.enable_reg = 0x1030,
1867 		.enable_mask = BIT(0),
1868 		.hw.init = &(struct clk_init_data){
1869 			.name = "video_ahb_clk",
1870 			.parent_hws = (const struct clk_hw*[]){
1871 				&ahb_clk_src.clkr.hw
1872 			},
1873 			.num_parents = 1,
1874 			.flags = CLK_SET_RATE_PARENT,
1875 			.ops = &clk_branch2_ops,
1876 		},
1877 	},
1878 };
1879 
1880 static struct clk_branch video_subcore0_clk = {
1881 	.halt_reg = 0x1048,
1882 	.clkr = {
1883 		.enable_reg = 0x1048,
1884 		.enable_mask = BIT(0),
1885 		.hw.init = &(struct clk_init_data){
1886 			.name = "video_subcore0_clk",
1887 			.parent_hws = (const struct clk_hw*[]){
1888 				&video_subcore0_clk_src.clkr.hw
1889 			},
1890 			.num_parents = 1,
1891 			.flags = CLK_SET_RATE_PARENT,
1892 			.ops = &clk_branch2_ops,
1893 		},
1894 	},
1895 };
1896 
1897 static struct clk_branch video_subcore1_clk = {
1898 	.halt_reg = 0x104c,
1899 	.clkr = {
1900 		.enable_reg = 0x104c,
1901 		.enable_mask = BIT(0),
1902 		.hw.init = &(struct clk_init_data){
1903 			.name = "video_subcore1_clk",
1904 			.parent_hws = (const struct clk_hw*[]){
1905 				&video_subcore1_clk_src.clkr.hw
1906 			},
1907 			.num_parents = 1,
1908 			.flags = CLK_SET_RATE_PARENT,
1909 			.ops = &clk_branch2_ops,
1910 		},
1911 	},
1912 };
1913 
1914 static struct clk_branch mdss_ahb_clk = {
1915 	.halt_reg = 0x2308,
1916 	.clkr = {
1917 		.enable_reg = 0x2308,
1918 		.enable_mask = BIT(0),
1919 		.hw.init = &(struct clk_init_data){
1920 			.name = "mdss_ahb_clk",
1921 			.parent_hws = (const struct clk_hw*[]){
1922 				&ahb_clk_src.clkr.hw
1923 			},
1924 			.num_parents = 1,
1925 			.flags = CLK_SET_RATE_PARENT,
1926 			.ops = &clk_branch2_ops,
1927 		},
1928 	},
1929 };
1930 
1931 static struct clk_branch mdss_hdmi_ahb_clk = {
1932 	.halt_reg = 0x230c,
1933 	.clkr = {
1934 		.enable_reg = 0x230c,
1935 		.enable_mask = BIT(0),
1936 		.hw.init = &(struct clk_init_data){
1937 			.name = "mdss_hdmi_ahb_clk",
1938 			.parent_hws = (const struct clk_hw*[]){
1939 				&ahb_clk_src.clkr.hw
1940 			},
1941 			.num_parents = 1,
1942 			.flags = CLK_SET_RATE_PARENT,
1943 			.ops = &clk_branch2_ops,
1944 		},
1945 	},
1946 };
1947 
1948 static struct clk_branch mdss_axi_clk = {
1949 	.halt_reg = 0x2310,
1950 	.clkr = {
1951 		.enable_reg = 0x2310,
1952 		.enable_mask = BIT(0),
1953 		.hw.init = &(struct clk_init_data){
1954 			.name = "mdss_axi_clk",
1955 			.parent_hws = (const struct clk_hw*[]){
1956 				&axi_clk_src.clkr.hw
1957 			},
1958 			.num_parents = 1,
1959 			.flags = CLK_SET_RATE_PARENT,
1960 			.ops = &clk_branch2_ops,
1961 		},
1962 	},
1963 };
1964 
1965 static struct clk_branch mdss_pclk0_clk = {
1966 	.halt_reg = 0x2314,
1967 	.clkr = {
1968 		.enable_reg = 0x2314,
1969 		.enable_mask = BIT(0),
1970 		.hw.init = &(struct clk_init_data){
1971 			.name = "mdss_pclk0_clk",
1972 			.parent_hws = (const struct clk_hw*[]){
1973 				&pclk0_clk_src.clkr.hw
1974 			},
1975 			.num_parents = 1,
1976 			.flags = CLK_SET_RATE_PARENT,
1977 			.ops = &clk_branch2_ops,
1978 		},
1979 	},
1980 };
1981 
1982 static struct clk_branch mdss_pclk1_clk = {
1983 	.halt_reg = 0x2318,
1984 	.clkr = {
1985 		.enable_reg = 0x2318,
1986 		.enable_mask = BIT(0),
1987 		.hw.init = &(struct clk_init_data){
1988 			.name = "mdss_pclk1_clk",
1989 			.parent_hws = (const struct clk_hw*[]){
1990 				&pclk1_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 mdss_mdp_clk = {
2000 	.halt_reg = 0x231c,
2001 	.clkr = {
2002 		.enable_reg = 0x231c,
2003 		.enable_mask = BIT(0),
2004 		.hw.init = &(struct clk_init_data){
2005 			.name = "mdss_mdp_clk",
2006 			.parent_hws = (const struct clk_hw*[]){
2007 				&mdp_clk_src.clkr.hw
2008 			},
2009 			.num_parents = 1,
2010 			.flags = CLK_SET_RATE_PARENT,
2011 			.ops = &clk_branch2_ops,
2012 		},
2013 	},
2014 };
2015 
2016 static struct clk_branch mdss_extpclk_clk = {
2017 	.halt_reg = 0x2324,
2018 	.clkr = {
2019 		.enable_reg = 0x2324,
2020 		.enable_mask = BIT(0),
2021 		.hw.init = &(struct clk_init_data){
2022 			.name = "mdss_extpclk_clk",
2023 			.parent_hws = (const struct clk_hw*[]){
2024 				&extpclk_clk_src.clkr.hw
2025 			},
2026 			.num_parents = 1,
2027 			.flags = CLK_SET_RATE_PARENT,
2028 			.ops = &clk_branch2_ops,
2029 		},
2030 	},
2031 };
2032 
2033 static struct clk_branch mdss_vsync_clk = {
2034 	.halt_reg = 0x2328,
2035 	.clkr = {
2036 		.enable_reg = 0x2328,
2037 		.enable_mask = BIT(0),
2038 		.hw.init = &(struct clk_init_data){
2039 			.name = "mdss_vsync_clk",
2040 			.parent_hws = (const struct clk_hw*[]){
2041 				&vsync_clk_src.clkr.hw
2042 			},
2043 			.num_parents = 1,
2044 			.flags = CLK_SET_RATE_PARENT,
2045 			.ops = &clk_branch2_ops,
2046 		},
2047 	},
2048 };
2049 
2050 static struct clk_branch mdss_hdmi_clk = {
2051 	.halt_reg = 0x2338,
2052 	.clkr = {
2053 		.enable_reg = 0x2338,
2054 		.enable_mask = BIT(0),
2055 		.hw.init = &(struct clk_init_data){
2056 			.name = "mdss_hdmi_clk",
2057 			.parent_hws = (const struct clk_hw*[]){
2058 				&hdmi_clk_src.clkr.hw
2059 			},
2060 			.num_parents = 1,
2061 			.flags = CLK_SET_RATE_PARENT,
2062 			.ops = &clk_branch2_ops,
2063 		},
2064 	},
2065 };
2066 
2067 static struct clk_branch mdss_byte0_clk = {
2068 	.halt_reg = 0x233c,
2069 	.clkr = {
2070 		.enable_reg = 0x233c,
2071 		.enable_mask = BIT(0),
2072 		.hw.init = &(struct clk_init_data){
2073 			.name = "mdss_byte0_clk",
2074 			.parent_hws = (const struct clk_hw*[]){
2075 				&byte0_clk_src.clkr.hw
2076 			},
2077 			.num_parents = 1,
2078 			.flags = CLK_SET_RATE_PARENT,
2079 			.ops = &clk_branch2_ops,
2080 		},
2081 	},
2082 };
2083 
2084 static struct clk_branch mdss_byte1_clk = {
2085 	.halt_reg = 0x2340,
2086 	.clkr = {
2087 		.enable_reg = 0x2340,
2088 		.enable_mask = BIT(0),
2089 		.hw.init = &(struct clk_init_data){
2090 			.name = "mdss_byte1_clk",
2091 			.parent_hws = (const struct clk_hw*[]){
2092 				&byte1_clk_src.clkr.hw
2093 			},
2094 			.num_parents = 1,
2095 			.flags = CLK_SET_RATE_PARENT,
2096 			.ops = &clk_branch2_ops,
2097 		},
2098 	},
2099 };
2100 
2101 static struct clk_branch mdss_esc0_clk = {
2102 	.halt_reg = 0x2344,
2103 	.clkr = {
2104 		.enable_reg = 0x2344,
2105 		.enable_mask = BIT(0),
2106 		.hw.init = &(struct clk_init_data){
2107 			.name = "mdss_esc0_clk",
2108 			.parent_hws = (const struct clk_hw*[]){
2109 				&esc0_clk_src.clkr.hw
2110 			},
2111 			.num_parents = 1,
2112 			.flags = CLK_SET_RATE_PARENT,
2113 			.ops = &clk_branch2_ops,
2114 		},
2115 	},
2116 };
2117 
2118 static struct clk_branch mdss_esc1_clk = {
2119 	.halt_reg = 0x2348,
2120 	.clkr = {
2121 		.enable_reg = 0x2348,
2122 		.enable_mask = BIT(0),
2123 		.hw.init = &(struct clk_init_data){
2124 			.name = "mdss_esc1_clk",
2125 			.parent_hws = (const struct clk_hw*[]){
2126 				&esc1_clk_src.clkr.hw
2127 			},
2128 			.num_parents = 1,
2129 			.flags = CLK_SET_RATE_PARENT,
2130 			.ops = &clk_branch2_ops,
2131 		},
2132 	},
2133 };
2134 
2135 static struct clk_branch camss_top_ahb_clk = {
2136 	.halt_reg = 0x3484,
2137 	.clkr = {
2138 		.enable_reg = 0x3484,
2139 		.enable_mask = BIT(0),
2140 		.hw.init = &(struct clk_init_data){
2141 			.name = "camss_top_ahb_clk",
2142 			.parent_hws = (const struct clk_hw*[]){
2143 				&ahb_clk_src.clkr.hw
2144 			},
2145 			.num_parents = 1,
2146 			.flags = CLK_SET_RATE_PARENT,
2147 			.ops = &clk_branch2_ops,
2148 		},
2149 	},
2150 };
2151 
2152 static struct clk_branch camss_ahb_clk = {
2153 	.halt_reg = 0x348c,
2154 	.clkr = {
2155 		.enable_reg = 0x348c,
2156 		.enable_mask = BIT(0),
2157 		.hw.init = &(struct clk_init_data){
2158 			.name = "camss_ahb_clk",
2159 			.parent_hws = (const struct clk_hw*[]){
2160 				&ahb_clk_src.clkr.hw
2161 			},
2162 			.num_parents = 1,
2163 			.flags = CLK_SET_RATE_PARENT,
2164 			.ops = &clk_branch2_ops,
2165 		},
2166 	},
2167 };
2168 
2169 static struct clk_branch camss_micro_ahb_clk = {
2170 	.halt_reg = 0x3494,
2171 	.clkr = {
2172 		.enable_reg = 0x3494,
2173 		.enable_mask = BIT(0),
2174 		.hw.init = &(struct clk_init_data){
2175 			.name = "camss_micro_ahb_clk",
2176 			.parent_hws = (const struct clk_hw*[]){
2177 				&ahb_clk_src.clkr.hw
2178 			},
2179 			.num_parents = 1,
2180 			.flags = CLK_SET_RATE_PARENT,
2181 			.ops = &clk_branch2_ops,
2182 		},
2183 	},
2184 };
2185 
2186 static struct clk_branch camss_gp0_clk = {
2187 	.halt_reg = 0x3444,
2188 	.clkr = {
2189 		.enable_reg = 0x3444,
2190 		.enable_mask = BIT(0),
2191 		.hw.init = &(struct clk_init_data){
2192 			.name = "camss_gp0_clk",
2193 			.parent_hws = (const struct clk_hw*[]){
2194 				&camss_gp0_clk_src.clkr.hw
2195 			},
2196 			.num_parents = 1,
2197 			.flags = CLK_SET_RATE_PARENT,
2198 			.ops = &clk_branch2_ops,
2199 		},
2200 	},
2201 };
2202 
2203 static struct clk_branch camss_gp1_clk = {
2204 	.halt_reg = 0x3474,
2205 	.clkr = {
2206 		.enable_reg = 0x3474,
2207 		.enable_mask = BIT(0),
2208 		.hw.init = &(struct clk_init_data){
2209 			.name = "camss_gp1_clk",
2210 			.parent_hws = (const struct clk_hw*[]){
2211 				&camss_gp1_clk_src.clkr.hw
2212 			},
2213 			.num_parents = 1,
2214 			.flags = CLK_SET_RATE_PARENT,
2215 			.ops = &clk_branch2_ops,
2216 		},
2217 	},
2218 };
2219 
2220 static struct clk_branch camss_mclk0_clk = {
2221 	.halt_reg = 0x3384,
2222 	.clkr = {
2223 		.enable_reg = 0x3384,
2224 		.enable_mask = BIT(0),
2225 		.hw.init = &(struct clk_init_data){
2226 			.name = "camss_mclk0_clk",
2227 			.parent_hws = (const struct clk_hw*[]){
2228 				&mclk0_clk_src.clkr.hw
2229 			},
2230 			.num_parents = 1,
2231 			.flags = CLK_SET_RATE_PARENT,
2232 			.ops = &clk_branch2_ops,
2233 		},
2234 	},
2235 };
2236 
2237 static struct clk_branch camss_mclk1_clk = {
2238 	.halt_reg = 0x33b4,
2239 	.clkr = {
2240 		.enable_reg = 0x33b4,
2241 		.enable_mask = BIT(0),
2242 		.hw.init = &(struct clk_init_data){
2243 			.name = "camss_mclk1_clk",
2244 			.parent_hws = (const struct clk_hw*[]){
2245 				&mclk1_clk_src.clkr.hw
2246 			},
2247 			.num_parents = 1,
2248 			.flags = CLK_SET_RATE_PARENT,
2249 			.ops = &clk_branch2_ops,
2250 		},
2251 	},
2252 };
2253 
2254 static struct clk_branch camss_mclk2_clk = {
2255 	.halt_reg = 0x33e4,
2256 	.clkr = {
2257 		.enable_reg = 0x33e4,
2258 		.enable_mask = BIT(0),
2259 		.hw.init = &(struct clk_init_data){
2260 			.name = "camss_mclk2_clk",
2261 			.parent_hws = (const struct clk_hw*[]){
2262 				&mclk2_clk_src.clkr.hw
2263 			},
2264 			.num_parents = 1,
2265 			.flags = CLK_SET_RATE_PARENT,
2266 			.ops = &clk_branch2_ops,
2267 		},
2268 	},
2269 };
2270 
2271 static struct clk_branch camss_mclk3_clk = {
2272 	.halt_reg = 0x3414,
2273 	.clkr = {
2274 		.enable_reg = 0x3414,
2275 		.enable_mask = BIT(0),
2276 		.hw.init = &(struct clk_init_data){
2277 			.name = "camss_mclk3_clk",
2278 			.parent_hws = (const struct clk_hw*[]){
2279 				&mclk3_clk_src.clkr.hw
2280 			},
2281 			.num_parents = 1,
2282 			.flags = CLK_SET_RATE_PARENT,
2283 			.ops = &clk_branch2_ops,
2284 		},
2285 	},
2286 };
2287 
2288 static struct clk_branch camss_cci_clk = {
2289 	.halt_reg = 0x3344,
2290 	.clkr = {
2291 		.enable_reg = 0x3344,
2292 		.enable_mask = BIT(0),
2293 		.hw.init = &(struct clk_init_data){
2294 			.name = "camss_cci_clk",
2295 			.parent_hws = (const struct clk_hw*[]){
2296 				&cci_clk_src.clkr.hw
2297 			},
2298 			.num_parents = 1,
2299 			.flags = CLK_SET_RATE_PARENT,
2300 			.ops = &clk_branch2_ops,
2301 		},
2302 	},
2303 };
2304 
2305 static struct clk_branch camss_cci_ahb_clk = {
2306 	.halt_reg = 0x3348,
2307 	.clkr = {
2308 		.enable_reg = 0x3348,
2309 		.enable_mask = BIT(0),
2310 		.hw.init = &(struct clk_init_data){
2311 			.name = "camss_cci_ahb_clk",
2312 			.parent_hws = (const struct clk_hw*[]){
2313 				&ahb_clk_src.clkr.hw
2314 			},
2315 			.num_parents = 1,
2316 			.flags = CLK_SET_RATE_PARENT,
2317 			.ops = &clk_branch2_ops,
2318 		},
2319 	},
2320 };
2321 
2322 static struct clk_branch camss_csi0phytimer_clk = {
2323 	.halt_reg = 0x3024,
2324 	.clkr = {
2325 		.enable_reg = 0x3024,
2326 		.enable_mask = BIT(0),
2327 		.hw.init = &(struct clk_init_data){
2328 			.name = "camss_csi0phytimer_clk",
2329 			.parent_hws = (const struct clk_hw*[]){
2330 				&csi0phytimer_clk_src.clkr.hw
2331 			},
2332 			.num_parents = 1,
2333 			.flags = CLK_SET_RATE_PARENT,
2334 			.ops = &clk_branch2_ops,
2335 		},
2336 	},
2337 };
2338 
2339 static struct clk_branch camss_csi1phytimer_clk = {
2340 	.halt_reg = 0x3054,
2341 	.clkr = {
2342 		.enable_reg = 0x3054,
2343 		.enable_mask = BIT(0),
2344 		.hw.init = &(struct clk_init_data){
2345 			.name = "camss_csi1phytimer_clk",
2346 			.parent_hws = (const struct clk_hw*[]){
2347 				&csi1phytimer_clk_src.clkr.hw
2348 			},
2349 			.num_parents = 1,
2350 			.flags = CLK_SET_RATE_PARENT,
2351 			.ops = &clk_branch2_ops,
2352 		},
2353 	},
2354 };
2355 
2356 static struct clk_branch camss_csi2phytimer_clk = {
2357 	.halt_reg = 0x3084,
2358 	.clkr = {
2359 		.enable_reg = 0x3084,
2360 		.enable_mask = BIT(0),
2361 		.hw.init = &(struct clk_init_data){
2362 			.name = "camss_csi2phytimer_clk",
2363 			.parent_hws = (const struct clk_hw*[]){
2364 				&csi2phytimer_clk_src.clkr.hw
2365 			},
2366 			.num_parents = 1,
2367 			.flags = CLK_SET_RATE_PARENT,
2368 			.ops = &clk_branch2_ops,
2369 		},
2370 	},
2371 };
2372 
2373 static struct clk_branch camss_csiphy0_3p_clk = {
2374 	.halt_reg = 0x3234,
2375 	.clkr = {
2376 		.enable_reg = 0x3234,
2377 		.enable_mask = BIT(0),
2378 		.hw.init = &(struct clk_init_data){
2379 			.name = "camss_csiphy0_3p_clk",
2380 			.parent_hws = (const struct clk_hw*[]){
2381 				&csiphy0_3p_clk_src.clkr.hw
2382 			},
2383 			.num_parents = 1,
2384 			.flags = CLK_SET_RATE_PARENT,
2385 			.ops = &clk_branch2_ops,
2386 		},
2387 	},
2388 };
2389 
2390 static struct clk_branch camss_csiphy1_3p_clk = {
2391 	.halt_reg = 0x3254,
2392 	.clkr = {
2393 		.enable_reg = 0x3254,
2394 		.enable_mask = BIT(0),
2395 		.hw.init = &(struct clk_init_data){
2396 			.name = "camss_csiphy1_3p_clk",
2397 			.parent_hws = (const struct clk_hw*[]){
2398 				&csiphy1_3p_clk_src.clkr.hw
2399 			},
2400 			.num_parents = 1,
2401 			.flags = CLK_SET_RATE_PARENT,
2402 			.ops = &clk_branch2_ops,
2403 		},
2404 	},
2405 };
2406 
2407 static struct clk_branch camss_csiphy2_3p_clk = {
2408 	.halt_reg = 0x3274,
2409 	.clkr = {
2410 		.enable_reg = 0x3274,
2411 		.enable_mask = BIT(0),
2412 		.hw.init = &(struct clk_init_data){
2413 			.name = "camss_csiphy2_3p_clk",
2414 			.parent_hws = (const struct clk_hw*[]){
2415 				&csiphy2_3p_clk_src.clkr.hw
2416 			},
2417 			.num_parents = 1,
2418 			.flags = CLK_SET_RATE_PARENT,
2419 			.ops = &clk_branch2_ops,
2420 		},
2421 	},
2422 };
2423 
2424 static struct clk_branch camss_jpeg0_clk = {
2425 	.halt_reg = 0x35a8,
2426 	.clkr = {
2427 		.enable_reg = 0x35a8,
2428 		.enable_mask = BIT(0),
2429 		.hw.init = &(struct clk_init_data){
2430 			.name = "camss_jpeg0_clk",
2431 			.parent_hws = (const struct clk_hw*[]){
2432 				&jpeg0_clk_src.clkr.hw
2433 			},
2434 			.num_parents = 1,
2435 			.flags = CLK_SET_RATE_PARENT,
2436 			.ops = &clk_branch2_ops,
2437 		},
2438 	},
2439 };
2440 
2441 static struct clk_branch camss_jpeg2_clk = {
2442 	.halt_reg = 0x35b0,
2443 	.clkr = {
2444 		.enable_reg = 0x35b0,
2445 		.enable_mask = BIT(0),
2446 		.hw.init = &(struct clk_init_data){
2447 			.name = "camss_jpeg2_clk",
2448 			.parent_hws = (const struct clk_hw*[]){
2449 				&jpeg2_clk_src.clkr.hw
2450 			},
2451 			.num_parents = 1,
2452 			.flags = CLK_SET_RATE_PARENT,
2453 			.ops = &clk_branch2_ops,
2454 		},
2455 	},
2456 };
2457 
2458 static struct clk_branch camss_jpeg_dma_clk = {
2459 	.halt_reg = 0x35c0,
2460 	.clkr = {
2461 		.enable_reg = 0x35c0,
2462 		.enable_mask = BIT(0),
2463 		.hw.init = &(struct clk_init_data){
2464 			.name = "camss_jpeg_dma_clk",
2465 			.parent_hws = (const struct clk_hw*[]){
2466 				&jpeg_dma_clk_src.clkr.hw
2467 			},
2468 			.num_parents = 1,
2469 			.flags = CLK_SET_RATE_PARENT,
2470 			.ops = &clk_branch2_ops,
2471 		},
2472 	},
2473 };
2474 
2475 static struct clk_branch camss_jpeg_ahb_clk = {
2476 	.halt_reg = 0x35b4,
2477 	.clkr = {
2478 		.enable_reg = 0x35b4,
2479 		.enable_mask = BIT(0),
2480 		.hw.init = &(struct clk_init_data){
2481 			.name = "camss_jpeg_ahb_clk",
2482 			.parent_hws = (const struct clk_hw*[]){
2483 				&ahb_clk_src.clkr.hw
2484 			},
2485 			.num_parents = 1,
2486 			.flags = CLK_SET_RATE_PARENT,
2487 			.ops = &clk_branch2_ops,
2488 		},
2489 	},
2490 };
2491 
2492 static struct clk_branch camss_jpeg_axi_clk = {
2493 	.halt_reg = 0x35b8,
2494 	.clkr = {
2495 		.enable_reg = 0x35b8,
2496 		.enable_mask = BIT(0),
2497 		.hw.init = &(struct clk_init_data){
2498 			.name = "camss_jpeg_axi_clk",
2499 			.parent_hws = (const struct clk_hw*[]){
2500 				&axi_clk_src.clkr.hw
2501 			},
2502 			.num_parents = 1,
2503 			.flags = CLK_SET_RATE_PARENT,
2504 			.ops = &clk_branch2_ops,
2505 		},
2506 	},
2507 };
2508 
2509 static struct clk_branch camss_vfe_ahb_clk = {
2510 	.halt_reg = 0x36b8,
2511 	.clkr = {
2512 		.enable_reg = 0x36b8,
2513 		.enable_mask = BIT(0),
2514 		.hw.init = &(struct clk_init_data){
2515 			.name = "camss_vfe_ahb_clk",
2516 			.parent_hws = (const struct clk_hw*[]){
2517 				&ahb_clk_src.clkr.hw
2518 			},
2519 			.num_parents = 1,
2520 			.flags = CLK_SET_RATE_PARENT,
2521 			.ops = &clk_branch2_ops,
2522 		},
2523 	},
2524 };
2525 
2526 static struct clk_branch camss_vfe_axi_clk = {
2527 	.halt_reg = 0x36bc,
2528 	.clkr = {
2529 		.enable_reg = 0x36bc,
2530 		.enable_mask = BIT(0),
2531 		.hw.init = &(struct clk_init_data){
2532 			.name = "camss_vfe_axi_clk",
2533 			.parent_hws = (const struct clk_hw*[]){
2534 				&axi_clk_src.clkr.hw
2535 			},
2536 			.num_parents = 1,
2537 			.flags = CLK_SET_RATE_PARENT,
2538 			.ops = &clk_branch2_ops,
2539 		},
2540 	},
2541 };
2542 
2543 static struct clk_branch camss_vfe0_clk = {
2544 	.halt_reg = 0x36a8,
2545 	.clkr = {
2546 		.enable_reg = 0x36a8,
2547 		.enable_mask = BIT(0),
2548 		.hw.init = &(struct clk_init_data){
2549 			.name = "camss_vfe0_clk",
2550 			.parent_hws = (const struct clk_hw*[]){
2551 				&vfe0_clk_src.clkr.hw
2552 			},
2553 			.num_parents = 1,
2554 			.flags = CLK_SET_RATE_PARENT,
2555 			.ops = &clk_branch2_ops,
2556 		},
2557 	},
2558 };
2559 
2560 static struct clk_branch camss_vfe0_stream_clk = {
2561 	.halt_reg = 0x3720,
2562 	.clkr = {
2563 		.enable_reg = 0x3720,
2564 		.enable_mask = BIT(0),
2565 		.hw.init = &(struct clk_init_data){
2566 			.name = "camss_vfe0_stream_clk",
2567 			.parent_hws = (const struct clk_hw*[]){
2568 				&vfe0_clk_src.clkr.hw
2569 			},
2570 			.num_parents = 1,
2571 			.flags = CLK_SET_RATE_PARENT,
2572 			.ops = &clk_branch2_ops,
2573 		},
2574 	},
2575 };
2576 
2577 static struct clk_branch camss_vfe0_ahb_clk = {
2578 	.halt_reg = 0x3668,
2579 	.clkr = {
2580 		.enable_reg = 0x3668,
2581 		.enable_mask = BIT(0),
2582 		.hw.init = &(struct clk_init_data){
2583 			.name = "camss_vfe0_ahb_clk",
2584 			.parent_hws = (const struct clk_hw*[]){
2585 				&ahb_clk_src.clkr.hw
2586 			},
2587 			.num_parents = 1,
2588 			.flags = CLK_SET_RATE_PARENT,
2589 			.ops = &clk_branch2_ops,
2590 		},
2591 	},
2592 };
2593 
2594 static struct clk_branch camss_vfe1_clk = {
2595 	.halt_reg = 0x36ac,
2596 	.clkr = {
2597 		.enable_reg = 0x36ac,
2598 		.enable_mask = BIT(0),
2599 		.hw.init = &(struct clk_init_data){
2600 			.name = "camss_vfe1_clk",
2601 			.parent_hws = (const struct clk_hw*[]){
2602 				&vfe1_clk_src.clkr.hw
2603 			},
2604 			.num_parents = 1,
2605 			.flags = CLK_SET_RATE_PARENT,
2606 			.ops = &clk_branch2_ops,
2607 		},
2608 	},
2609 };
2610 
2611 static struct clk_branch camss_vfe1_stream_clk = {
2612 	.halt_reg = 0x3724,
2613 	.clkr = {
2614 		.enable_reg = 0x3724,
2615 		.enable_mask = BIT(0),
2616 		.hw.init = &(struct clk_init_data){
2617 			.name = "camss_vfe1_stream_clk",
2618 			.parent_hws = (const struct clk_hw*[]){
2619 				&vfe1_clk_src.clkr.hw
2620 			},
2621 			.num_parents = 1,
2622 			.flags = CLK_SET_RATE_PARENT,
2623 			.ops = &clk_branch2_ops,
2624 		},
2625 	},
2626 };
2627 
2628 static struct clk_branch camss_vfe1_ahb_clk = {
2629 	.halt_reg = 0x3678,
2630 	.clkr = {
2631 		.enable_reg = 0x3678,
2632 		.enable_mask = BIT(0),
2633 		.hw.init = &(struct clk_init_data){
2634 			.name = "camss_vfe1_ahb_clk",
2635 			.parent_hws = (const struct clk_hw*[]){
2636 				&ahb_clk_src.clkr.hw
2637 			},
2638 			.num_parents = 1,
2639 			.flags = CLK_SET_RATE_PARENT,
2640 			.ops = &clk_branch2_ops,
2641 		},
2642 	},
2643 };
2644 
2645 static struct clk_branch camss_csi_vfe0_clk = {
2646 	.halt_reg = 0x3704,
2647 	.clkr = {
2648 		.enable_reg = 0x3704,
2649 		.enable_mask = BIT(0),
2650 		.hw.init = &(struct clk_init_data){
2651 			.name = "camss_csi_vfe0_clk",
2652 			.parent_hws = (const struct clk_hw*[]){
2653 				&vfe0_clk_src.clkr.hw
2654 			},
2655 			.num_parents = 1,
2656 			.flags = CLK_SET_RATE_PARENT,
2657 			.ops = &clk_branch2_ops,
2658 		},
2659 	},
2660 };
2661 
2662 static struct clk_branch camss_csi_vfe1_clk = {
2663 	.halt_reg = 0x3714,
2664 	.clkr = {
2665 		.enable_reg = 0x3714,
2666 		.enable_mask = BIT(0),
2667 		.hw.init = &(struct clk_init_data){
2668 			.name = "camss_csi_vfe1_clk",
2669 			.parent_hws = (const struct clk_hw*[]){
2670 				&vfe1_clk_src.clkr.hw
2671 			},
2672 			.num_parents = 1,
2673 			.flags = CLK_SET_RATE_PARENT,
2674 			.ops = &clk_branch2_ops,
2675 		},
2676 	},
2677 };
2678 
2679 static struct clk_branch camss_cpp_vbif_ahb_clk = {
2680 	.halt_reg = 0x36c8,
2681 	.clkr = {
2682 		.enable_reg = 0x36c8,
2683 		.enable_mask = BIT(0),
2684 		.hw.init = &(struct clk_init_data){
2685 			.name = "camss_cpp_vbif_ahb_clk",
2686 			.parent_hws = (const struct clk_hw*[]){
2687 				&ahb_clk_src.clkr.hw
2688 			},
2689 			.num_parents = 1,
2690 			.flags = CLK_SET_RATE_PARENT,
2691 			.ops = &clk_branch2_ops,
2692 		},
2693 	},
2694 };
2695 
2696 static struct clk_branch camss_cpp_axi_clk = {
2697 	.halt_reg = 0x36c4,
2698 	.clkr = {
2699 		.enable_reg = 0x36c4,
2700 		.enable_mask = BIT(0),
2701 		.hw.init = &(struct clk_init_data){
2702 			.name = "camss_cpp_axi_clk",
2703 			.parent_hws = (const struct clk_hw*[]){
2704 				&axi_clk_src.clkr.hw
2705 			},
2706 			.num_parents = 1,
2707 			.flags = CLK_SET_RATE_PARENT,
2708 			.ops = &clk_branch2_ops,
2709 		},
2710 	},
2711 };
2712 
2713 static struct clk_branch camss_cpp_clk = {
2714 	.halt_reg = 0x36b0,
2715 	.clkr = {
2716 		.enable_reg = 0x36b0,
2717 		.enable_mask = BIT(0),
2718 		.hw.init = &(struct clk_init_data){
2719 			.name = "camss_cpp_clk",
2720 			.parent_hws = (const struct clk_hw*[]){
2721 				&cpp_clk_src.clkr.hw
2722 			},
2723 			.num_parents = 1,
2724 			.flags = CLK_SET_RATE_PARENT,
2725 			.ops = &clk_branch2_ops,
2726 		},
2727 	},
2728 };
2729 
2730 static struct clk_branch camss_cpp_ahb_clk = {
2731 	.halt_reg = 0x36b4,
2732 	.clkr = {
2733 		.enable_reg = 0x36b4,
2734 		.enable_mask = BIT(0),
2735 		.hw.init = &(struct clk_init_data){
2736 			.name = "camss_cpp_ahb_clk",
2737 			.parent_hws = (const struct clk_hw*[]){
2738 				&ahb_clk_src.clkr.hw
2739 			},
2740 			.num_parents = 1,
2741 			.flags = CLK_SET_RATE_PARENT,
2742 			.ops = &clk_branch2_ops,
2743 		},
2744 	},
2745 };
2746 
2747 static struct clk_branch camss_csi0_clk = {
2748 	.halt_reg = 0x30b4,
2749 	.clkr = {
2750 		.enable_reg = 0x30b4,
2751 		.enable_mask = BIT(0),
2752 		.hw.init = &(struct clk_init_data){
2753 			.name = "camss_csi0_clk",
2754 			.parent_hws = (const struct clk_hw*[]){
2755 				&csi0_clk_src.clkr.hw
2756 			},
2757 			.num_parents = 1,
2758 			.flags = CLK_SET_RATE_PARENT,
2759 			.ops = &clk_branch2_ops,
2760 		},
2761 	},
2762 };
2763 
2764 static struct clk_branch camss_csi0_ahb_clk = {
2765 	.halt_reg = 0x30bc,
2766 	.clkr = {
2767 		.enable_reg = 0x30bc,
2768 		.enable_mask = BIT(0),
2769 		.hw.init = &(struct clk_init_data){
2770 			.name = "camss_csi0_ahb_clk",
2771 			.parent_hws = (const struct clk_hw*[]){
2772 				&ahb_clk_src.clkr.hw
2773 			},
2774 			.num_parents = 1,
2775 			.flags = CLK_SET_RATE_PARENT,
2776 			.ops = &clk_branch2_ops,
2777 		},
2778 	},
2779 };
2780 
2781 static struct clk_branch camss_csi0phy_clk = {
2782 	.halt_reg = 0x30c4,
2783 	.clkr = {
2784 		.enable_reg = 0x30c4,
2785 		.enable_mask = BIT(0),
2786 		.hw.init = &(struct clk_init_data){
2787 			.name = "camss_csi0phy_clk",
2788 			.parent_hws = (const struct clk_hw*[]){
2789 				&csi0_clk_src.clkr.hw
2790 			},
2791 			.num_parents = 1,
2792 			.flags = CLK_SET_RATE_PARENT,
2793 			.ops = &clk_branch2_ops,
2794 		},
2795 	},
2796 };
2797 
2798 static struct clk_branch camss_csi0rdi_clk = {
2799 	.halt_reg = 0x30d4,
2800 	.clkr = {
2801 		.enable_reg = 0x30d4,
2802 		.enable_mask = BIT(0),
2803 		.hw.init = &(struct clk_init_data){
2804 			.name = "camss_csi0rdi_clk",
2805 			.parent_hws = (const struct clk_hw*[]){
2806 				&csi0_clk_src.clkr.hw
2807 			},
2808 			.num_parents = 1,
2809 			.flags = CLK_SET_RATE_PARENT,
2810 			.ops = &clk_branch2_ops,
2811 		},
2812 	},
2813 };
2814 
2815 static struct clk_branch camss_csi0pix_clk = {
2816 	.halt_reg = 0x30e4,
2817 	.clkr = {
2818 		.enable_reg = 0x30e4,
2819 		.enable_mask = BIT(0),
2820 		.hw.init = &(struct clk_init_data){
2821 			.name = "camss_csi0pix_clk",
2822 			.parent_hws = (const struct clk_hw*[]){
2823 				&csi0_clk_src.clkr.hw
2824 			},
2825 			.num_parents = 1,
2826 			.flags = CLK_SET_RATE_PARENT,
2827 			.ops = &clk_branch2_ops,
2828 		},
2829 	},
2830 };
2831 
2832 static struct clk_branch camss_csi1_clk = {
2833 	.halt_reg = 0x3124,
2834 	.clkr = {
2835 		.enable_reg = 0x3124,
2836 		.enable_mask = BIT(0),
2837 		.hw.init = &(struct clk_init_data){
2838 			.name = "camss_csi1_clk",
2839 			.parent_hws = (const struct clk_hw*[]){
2840 				&csi1_clk_src.clkr.hw
2841 			},
2842 			.num_parents = 1,
2843 			.flags = CLK_SET_RATE_PARENT,
2844 			.ops = &clk_branch2_ops,
2845 		},
2846 	},
2847 };
2848 
2849 static struct clk_branch camss_csi1_ahb_clk = {
2850 	.halt_reg = 0x3128,
2851 	.clkr = {
2852 		.enable_reg = 0x3128,
2853 		.enable_mask = BIT(0),
2854 		.hw.init = &(struct clk_init_data){
2855 			.name = "camss_csi1_ahb_clk",
2856 			.parent_hws = (const struct clk_hw*[]){
2857 				&ahb_clk_src.clkr.hw
2858 			},
2859 			.num_parents = 1,
2860 			.flags = CLK_SET_RATE_PARENT,
2861 			.ops = &clk_branch2_ops,
2862 		},
2863 	},
2864 };
2865 
2866 static struct clk_branch camss_csi1phy_clk = {
2867 	.halt_reg = 0x3134,
2868 	.clkr = {
2869 		.enable_reg = 0x3134,
2870 		.enable_mask = BIT(0),
2871 		.hw.init = &(struct clk_init_data){
2872 			.name = "camss_csi1phy_clk",
2873 			.parent_hws = (const struct clk_hw*[]){
2874 				&csi1_clk_src.clkr.hw
2875 			},
2876 			.num_parents = 1,
2877 			.flags = CLK_SET_RATE_PARENT,
2878 			.ops = &clk_branch2_ops,
2879 		},
2880 	},
2881 };
2882 
2883 static struct clk_branch camss_csi1rdi_clk = {
2884 	.halt_reg = 0x3144,
2885 	.clkr = {
2886 		.enable_reg = 0x3144,
2887 		.enable_mask = BIT(0),
2888 		.hw.init = &(struct clk_init_data){
2889 			.name = "camss_csi1rdi_clk",
2890 			.parent_hws = (const struct clk_hw*[]){
2891 				&csi1_clk_src.clkr.hw
2892 			},
2893 			.num_parents = 1,
2894 			.flags = CLK_SET_RATE_PARENT,
2895 			.ops = &clk_branch2_ops,
2896 		},
2897 	},
2898 };
2899 
2900 static struct clk_branch camss_csi1pix_clk = {
2901 	.halt_reg = 0x3154,
2902 	.clkr = {
2903 		.enable_reg = 0x3154,
2904 		.enable_mask = BIT(0),
2905 		.hw.init = &(struct clk_init_data){
2906 			.name = "camss_csi1pix_clk",
2907 			.parent_hws = (const struct clk_hw*[]){
2908 				&csi1_clk_src.clkr.hw
2909 			},
2910 			.num_parents = 1,
2911 			.flags = CLK_SET_RATE_PARENT,
2912 			.ops = &clk_branch2_ops,
2913 		},
2914 	},
2915 };
2916 
2917 static struct clk_branch camss_csi2_clk = {
2918 	.halt_reg = 0x3184,
2919 	.clkr = {
2920 		.enable_reg = 0x3184,
2921 		.enable_mask = BIT(0),
2922 		.hw.init = &(struct clk_init_data){
2923 			.name = "camss_csi2_clk",
2924 			.parent_hws = (const struct clk_hw*[]){
2925 				&csi2_clk_src.clkr.hw
2926 			},
2927 			.num_parents = 1,
2928 			.flags = CLK_SET_RATE_PARENT,
2929 			.ops = &clk_branch2_ops,
2930 		},
2931 	},
2932 };
2933 
2934 static struct clk_branch camss_csi2_ahb_clk = {
2935 	.halt_reg = 0x3188,
2936 	.clkr = {
2937 		.enable_reg = 0x3188,
2938 		.enable_mask = BIT(0),
2939 		.hw.init = &(struct clk_init_data){
2940 			.name = "camss_csi2_ahb_clk",
2941 			.parent_hws = (const struct clk_hw*[]){
2942 				&ahb_clk_src.clkr.hw
2943 			},
2944 			.num_parents = 1,
2945 			.flags = CLK_SET_RATE_PARENT,
2946 			.ops = &clk_branch2_ops,
2947 		},
2948 	},
2949 };
2950 
2951 static struct clk_branch camss_csi2phy_clk = {
2952 	.halt_reg = 0x3194,
2953 	.clkr = {
2954 		.enable_reg = 0x3194,
2955 		.enable_mask = BIT(0),
2956 		.hw.init = &(struct clk_init_data){
2957 			.name = "camss_csi2phy_clk",
2958 			.parent_hws = (const struct clk_hw*[]){
2959 				&csi2_clk_src.clkr.hw
2960 			},
2961 			.num_parents = 1,
2962 			.flags = CLK_SET_RATE_PARENT,
2963 			.ops = &clk_branch2_ops,
2964 		},
2965 	},
2966 };
2967 
2968 static struct clk_branch camss_csi2rdi_clk = {
2969 	.halt_reg = 0x31a4,
2970 	.clkr = {
2971 		.enable_reg = 0x31a4,
2972 		.enable_mask = BIT(0),
2973 		.hw.init = &(struct clk_init_data){
2974 			.name = "camss_csi2rdi_clk",
2975 			.parent_hws = (const struct clk_hw*[]){
2976 				&csi2_clk_src.clkr.hw
2977 			},
2978 			.num_parents = 1,
2979 			.flags = CLK_SET_RATE_PARENT,
2980 			.ops = &clk_branch2_ops,
2981 		},
2982 	},
2983 };
2984 
2985 static struct clk_branch camss_csi2pix_clk = {
2986 	.halt_reg = 0x31b4,
2987 	.clkr = {
2988 		.enable_reg = 0x31b4,
2989 		.enable_mask = BIT(0),
2990 		.hw.init = &(struct clk_init_data){
2991 			.name = "camss_csi2pix_clk",
2992 			.parent_hws = (const struct clk_hw*[]){
2993 				&csi2_clk_src.clkr.hw
2994 			},
2995 			.num_parents = 1,
2996 			.flags = CLK_SET_RATE_PARENT,
2997 			.ops = &clk_branch2_ops,
2998 		},
2999 	},
3000 };
3001 
3002 static struct clk_branch camss_csi3_clk = {
3003 	.halt_reg = 0x31e4,
3004 	.clkr = {
3005 		.enable_reg = 0x31e4,
3006 		.enable_mask = BIT(0),
3007 		.hw.init = &(struct clk_init_data){
3008 			.name = "camss_csi3_clk",
3009 			.parent_hws = (const struct clk_hw*[]){
3010 				&csi3_clk_src.clkr.hw
3011 			},
3012 			.num_parents = 1,
3013 			.flags = CLK_SET_RATE_PARENT,
3014 			.ops = &clk_branch2_ops,
3015 		},
3016 	},
3017 };
3018 
3019 static struct clk_branch camss_csi3_ahb_clk = {
3020 	.halt_reg = 0x31e8,
3021 	.clkr = {
3022 		.enable_reg = 0x31e8,
3023 		.enable_mask = BIT(0),
3024 		.hw.init = &(struct clk_init_data){
3025 			.name = "camss_csi3_ahb_clk",
3026 			.parent_hws = (const struct clk_hw*[]){
3027 				&ahb_clk_src.clkr.hw
3028 			},
3029 			.num_parents = 1,
3030 			.flags = CLK_SET_RATE_PARENT,
3031 			.ops = &clk_branch2_ops,
3032 		},
3033 	},
3034 };
3035 
3036 static struct clk_branch camss_csi3phy_clk = {
3037 	.halt_reg = 0x31f4,
3038 	.clkr = {
3039 		.enable_reg = 0x31f4,
3040 		.enable_mask = BIT(0),
3041 		.hw.init = &(struct clk_init_data){
3042 			.name = "camss_csi3phy_clk",
3043 			.parent_hws = (const struct clk_hw*[]){
3044 				&csi3_clk_src.clkr.hw
3045 			},
3046 			.num_parents = 1,
3047 			.flags = CLK_SET_RATE_PARENT,
3048 			.ops = &clk_branch2_ops,
3049 		},
3050 	},
3051 };
3052 
3053 static struct clk_branch camss_csi3rdi_clk = {
3054 	.halt_reg = 0x3204,
3055 	.clkr = {
3056 		.enable_reg = 0x3204,
3057 		.enable_mask = BIT(0),
3058 		.hw.init = &(struct clk_init_data){
3059 			.name = "camss_csi3rdi_clk",
3060 			.parent_hws = (const struct clk_hw*[]){
3061 				&csi3_clk_src.clkr.hw
3062 			},
3063 			.num_parents = 1,
3064 			.flags = CLK_SET_RATE_PARENT,
3065 			.ops = &clk_branch2_ops,
3066 		},
3067 	},
3068 };
3069 
3070 static struct clk_branch camss_csi3pix_clk = {
3071 	.halt_reg = 0x3214,
3072 	.clkr = {
3073 		.enable_reg = 0x3214,
3074 		.enable_mask = BIT(0),
3075 		.hw.init = &(struct clk_init_data){
3076 			.name = "camss_csi3pix_clk",
3077 			.parent_hws = (const struct clk_hw*[]){
3078 				&csi3_clk_src.clkr.hw
3079 			},
3080 			.num_parents = 1,
3081 			.flags = CLK_SET_RATE_PARENT,
3082 			.ops = &clk_branch2_ops,
3083 		},
3084 	},
3085 };
3086 
3087 static struct clk_branch camss_ispif_ahb_clk = {
3088 	.halt_reg = 0x3224,
3089 	.clkr = {
3090 		.enable_reg = 0x3224,
3091 		.enable_mask = BIT(0),
3092 		.hw.init = &(struct clk_init_data){
3093 			.name = "camss_ispif_ahb_clk",
3094 			.parent_hws = (const struct clk_hw*[]){
3095 				&ahb_clk_src.clkr.hw
3096 			},
3097 			.num_parents = 1,
3098 			.flags = CLK_SET_RATE_PARENT,
3099 			.ops = &clk_branch2_ops,
3100 		},
3101 	},
3102 };
3103 
3104 static struct clk_branch fd_core_clk = {
3105 	.halt_reg = 0x3b68,
3106 	.clkr = {
3107 		.enable_reg = 0x3b68,
3108 		.enable_mask = BIT(0),
3109 		.hw.init = &(struct clk_init_data){
3110 			.name = "fd_core_clk",
3111 			.parent_hws = (const struct clk_hw*[]){
3112 				&fd_core_clk_src.clkr.hw
3113 			},
3114 			.num_parents = 1,
3115 			.flags = CLK_SET_RATE_PARENT,
3116 			.ops = &clk_branch2_ops,
3117 		},
3118 	},
3119 };
3120 
3121 static struct clk_branch fd_core_uar_clk = {
3122 	.halt_reg = 0x3b6c,
3123 	.clkr = {
3124 		.enable_reg = 0x3b6c,
3125 		.enable_mask = BIT(0),
3126 		.hw.init = &(struct clk_init_data){
3127 			.name = "fd_core_uar_clk",
3128 			.parent_hws = (const struct clk_hw*[]){
3129 				&fd_core_clk_src.clkr.hw
3130 			},
3131 			.num_parents = 1,
3132 			.flags = CLK_SET_RATE_PARENT,
3133 			.ops = &clk_branch2_ops,
3134 		},
3135 	},
3136 };
3137 
3138 static struct clk_branch fd_ahb_clk = {
3139 	.halt_reg = 0x3ba74,
3140 	.clkr = {
3141 		.enable_reg = 0x3ba74,
3142 		.enable_mask = BIT(0),
3143 		.hw.init = &(struct clk_init_data){
3144 			.name = "fd_ahb_clk",
3145 			.parent_hws = (const struct clk_hw*[]){
3146 				&ahb_clk_src.clkr.hw
3147 			},
3148 			.num_parents = 1,
3149 			.flags = CLK_SET_RATE_PARENT,
3150 			.ops = &clk_branch2_ops,
3151 		},
3152 	},
3153 };
3154 
3155 static struct clk_hw *mmcc_msm8996_hws[] = {
3156 	&gpll0_div.hw,
3157 };
3158 
3159 static struct gdsc mmagic_bimc_gdsc = {
3160 	.gdscr = 0x529c,
3161 	.pd = {
3162 		.name = "mmagic_bimc",
3163 	},
3164 	.pwrsts = PWRSTS_OFF_ON,
3165 	.flags = ALWAYS_ON,
3166 };
3167 
3168 static struct gdsc mmagic_video_gdsc = {
3169 	.gdscr = 0x119c,
3170 	.gds_hw_ctrl = 0x120c,
3171 	.pd = {
3172 		.name = "mmagic_video",
3173 	},
3174 	.pwrsts = PWRSTS_OFF_ON,
3175 	.flags = VOTABLE | ALWAYS_ON,
3176 };
3177 
3178 static struct gdsc mmagic_mdss_gdsc = {
3179 	.gdscr = 0x247c,
3180 	.gds_hw_ctrl = 0x2480,
3181 	.pd = {
3182 		.name = "mmagic_mdss",
3183 	},
3184 	.pwrsts = PWRSTS_OFF_ON,
3185 	.flags = VOTABLE | ALWAYS_ON,
3186 };
3187 
3188 static struct gdsc mmagic_camss_gdsc = {
3189 	.gdscr = 0x3c4c,
3190 	.gds_hw_ctrl = 0x3c50,
3191 	.pd = {
3192 		.name = "mmagic_camss",
3193 	},
3194 	.pwrsts = PWRSTS_OFF_ON,
3195 	.flags = VOTABLE | ALWAYS_ON,
3196 };
3197 
3198 static struct gdsc venus_gdsc = {
3199 	.gdscr = 0x1024,
3200 	.cxcs = (unsigned int []){ 0x1028, 0x1034, 0x1038 },
3201 	.cxc_count = 3,
3202 	.pd = {
3203 		.name = "venus",
3204 	},
3205 	.parent = &mmagic_video_gdsc.pd,
3206 	.pwrsts = PWRSTS_OFF_ON,
3207 };
3208 
3209 static struct gdsc venus_core0_gdsc = {
3210 	.gdscr = 0x1040,
3211 	.cxcs = (unsigned int []){ 0x1048 },
3212 	.cxc_count = 1,
3213 	.pd = {
3214 		.name = "venus_core0",
3215 	},
3216 	.parent = &venus_gdsc.pd,
3217 	.pwrsts = PWRSTS_OFF_ON,
3218 	.flags = HW_CTRL,
3219 };
3220 
3221 static struct gdsc venus_core1_gdsc = {
3222 	.gdscr = 0x1044,
3223 	.cxcs = (unsigned int []){ 0x104c },
3224 	.cxc_count = 1,
3225 	.pd = {
3226 		.name = "venus_core1",
3227 	},
3228 	.parent = &venus_gdsc.pd,
3229 	.pwrsts = PWRSTS_OFF_ON,
3230 	.flags = HW_CTRL,
3231 };
3232 
3233 static struct gdsc camss_gdsc = {
3234 	.gdscr = 0x34a0,
3235 	.cxcs = (unsigned int []){ 0x36bc, 0x36c4 },
3236 	.cxc_count = 2,
3237 	.pd = {
3238 		.name = "camss",
3239 	},
3240 	.parent = &mmagic_camss_gdsc.pd,
3241 	.pwrsts = PWRSTS_OFF_ON,
3242 };
3243 
3244 static struct gdsc vfe0_gdsc = {
3245 	.gdscr = 0x3664,
3246 	.cxcs = (unsigned int []){ 0x36a8 },
3247 	.cxc_count = 1,
3248 	.pd = {
3249 		.name = "vfe0",
3250 	},
3251 	.parent = &camss_gdsc.pd,
3252 	.pwrsts = PWRSTS_OFF_ON,
3253 };
3254 
3255 static struct gdsc vfe1_gdsc = {
3256 	.gdscr = 0x3674,
3257 	.cxcs = (unsigned int []){ 0x36ac },
3258 	.cxc_count = 1,
3259 	.pd = {
3260 		.name = "vfe1",
3261 	},
3262 	.parent = &camss_gdsc.pd,
3263 	.pwrsts = PWRSTS_OFF_ON,
3264 };
3265 
3266 static struct gdsc jpeg_gdsc = {
3267 	.gdscr = 0x35a4,
3268 	.cxcs = (unsigned int []){ 0x35a8, 0x35b0, 0x35c0, 0x35b8 },
3269 	.cxc_count = 4,
3270 	.pd = {
3271 		.name = "jpeg",
3272 	},
3273 	.parent = &camss_gdsc.pd,
3274 	.pwrsts = PWRSTS_OFF_ON,
3275 };
3276 
3277 static struct gdsc cpp_gdsc = {
3278 	.gdscr = 0x36d4,
3279 	.cxcs = (unsigned int []){ 0x36b0 },
3280 	.cxc_count = 1,
3281 	.pd = {
3282 		.name = "cpp",
3283 	},
3284 	.parent = &camss_gdsc.pd,
3285 	.pwrsts = PWRSTS_OFF_ON,
3286 };
3287 
3288 static struct gdsc fd_gdsc = {
3289 	.gdscr = 0x3b64,
3290 	.cxcs = (unsigned int []){ 0x3b68, 0x3b6c },
3291 	.cxc_count = 2,
3292 	.pd = {
3293 		.name = "fd",
3294 	},
3295 	.parent = &camss_gdsc.pd,
3296 	.pwrsts = PWRSTS_OFF_ON,
3297 };
3298 
3299 static struct gdsc mdss_gdsc = {
3300 	.gdscr = 0x2304,
3301 	.cxcs = (unsigned int []){ 0x2310, 0x231c },
3302 	.cxc_count = 2,
3303 	.pd = {
3304 		.name = "mdss",
3305 	},
3306 	.parent = &mmagic_mdss_gdsc.pd,
3307 	.pwrsts = PWRSTS_OFF_ON,
3308 };
3309 
3310 static struct gdsc gpu_gdsc = {
3311 	.gdscr = 0x4034,
3312 	.gds_hw_ctrl = 0x4038,
3313 	.pd = {
3314 		.name = "gpu",
3315 	},
3316 	.pwrsts = PWRSTS_OFF_ON,
3317 	.flags = VOTABLE,
3318 };
3319 
3320 static struct gdsc gpu_gx_gdsc = {
3321 	.gdscr = 0x4024,
3322 	.clamp_io_ctrl = 0x4300,
3323 	.cxcs = (unsigned int []){ 0x4028 },
3324 	.cxc_count = 1,
3325 	.pd = {
3326 		.name = "gpu_gx",
3327 	},
3328 	.pwrsts = PWRSTS_OFF_ON,
3329 	.parent = &gpu_gdsc.pd,
3330 	.flags = CLAMP_IO,
3331 	.supply = "vdd-gfx",
3332 };
3333 
3334 static struct clk_regmap *mmcc_msm8996_clocks[] = {
3335 	[MMPLL0_EARLY] = &mmpll0_early.clkr,
3336 	[MMPLL0_PLL] = &mmpll0.clkr,
3337 	[MMPLL1_EARLY] = &mmpll1_early.clkr,
3338 	[MMPLL1_PLL] = &mmpll1.clkr,
3339 	[MMPLL2_EARLY] = &mmpll2_early.clkr,
3340 	[MMPLL2_PLL] = &mmpll2.clkr,
3341 	[MMPLL3_EARLY] = &mmpll3_early.clkr,
3342 	[MMPLL3_PLL] = &mmpll3.clkr,
3343 	[MMPLL4_EARLY] = &mmpll4_early.clkr,
3344 	[MMPLL4_PLL] = &mmpll4.clkr,
3345 	[MMPLL5_EARLY] = &mmpll5_early.clkr,
3346 	[MMPLL5_PLL] = &mmpll5.clkr,
3347 	[MMPLL8_EARLY] = &mmpll8_early.clkr,
3348 	[MMPLL8_PLL] = &mmpll8.clkr,
3349 	[MMPLL9_EARLY] = &mmpll9_early.clkr,
3350 	[MMPLL9_PLL] = &mmpll9.clkr,
3351 	[AHB_CLK_SRC] = &ahb_clk_src.clkr,
3352 	[AXI_CLK_SRC] = &axi_clk_src.clkr,
3353 	[MAXI_CLK_SRC] = &maxi_clk_src.clkr,
3354 	[GFX3D_CLK_SRC] = &gfx3d_clk_src.rcg.clkr,
3355 	[RBBMTIMER_CLK_SRC] = &rbbmtimer_clk_src.clkr,
3356 	[ISENSE_CLK_SRC] = &isense_clk_src.clkr,
3357 	[RBCPR_CLK_SRC] = &rbcpr_clk_src.clkr,
3358 	[VIDEO_CORE_CLK_SRC] = &video_core_clk_src.clkr,
3359 	[VIDEO_SUBCORE0_CLK_SRC] = &video_subcore0_clk_src.clkr,
3360 	[VIDEO_SUBCORE1_CLK_SRC] = &video_subcore1_clk_src.clkr,
3361 	[PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
3362 	[PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
3363 	[MDP_CLK_SRC] = &mdp_clk_src.clkr,
3364 	[EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
3365 	[VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
3366 	[HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
3367 	[BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
3368 	[BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
3369 	[ESC0_CLK_SRC] = &esc0_clk_src.clkr,
3370 	[ESC1_CLK_SRC] = &esc1_clk_src.clkr,
3371 	[CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr,
3372 	[CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr,
3373 	[MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
3374 	[MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
3375 	[MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
3376 	[MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
3377 	[CCI_CLK_SRC] = &cci_clk_src.clkr,
3378 	[CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
3379 	[CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
3380 	[CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
3381 	[CSIPHY0_3P_CLK_SRC] = &csiphy0_3p_clk_src.clkr,
3382 	[CSIPHY1_3P_CLK_SRC] = &csiphy1_3p_clk_src.clkr,
3383 	[CSIPHY2_3P_CLK_SRC] = &csiphy2_3p_clk_src.clkr,
3384 	[JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
3385 	[JPEG2_CLK_SRC] = &jpeg2_clk_src.clkr,
3386 	[JPEG_DMA_CLK_SRC] = &jpeg_dma_clk_src.clkr,
3387 	[VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
3388 	[VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
3389 	[CPP_CLK_SRC] = &cpp_clk_src.clkr,
3390 	[CSI0_CLK_SRC] = &csi0_clk_src.clkr,
3391 	[CSI1_CLK_SRC] = &csi1_clk_src.clkr,
3392 	[CSI2_CLK_SRC] = &csi2_clk_src.clkr,
3393 	[CSI3_CLK_SRC] = &csi3_clk_src.clkr,
3394 	[FD_CORE_CLK_SRC] = &fd_core_clk_src.clkr,
3395 	[MMSS_MMAGIC_AHB_CLK] = &mmss_mmagic_ahb_clk.clkr,
3396 	[MMSS_MMAGIC_CFG_AHB_CLK] = &mmss_mmagic_cfg_ahb_clk.clkr,
3397 	[MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
3398 	[MMSS_MISC_CXO_CLK] = &mmss_misc_cxo_clk.clkr,
3399 	[MMSS_MMAGIC_MAXI_CLK] = &mmss_mmagic_maxi_clk.clkr,
3400 	[MMAGIC_CAMSS_AXI_CLK] = &mmagic_camss_axi_clk.clkr,
3401 	[MMAGIC_CAMSS_NOC_CFG_AHB_CLK] = &mmagic_camss_noc_cfg_ahb_clk.clkr,
3402 	[SMMU_VFE_AHB_CLK] = &smmu_vfe_ahb_clk.clkr,
3403 	[SMMU_VFE_AXI_CLK] = &smmu_vfe_axi_clk.clkr,
3404 	[SMMU_CPP_AHB_CLK] = &smmu_cpp_ahb_clk.clkr,
3405 	[SMMU_CPP_AXI_CLK] = &smmu_cpp_axi_clk.clkr,
3406 	[SMMU_JPEG_AHB_CLK] = &smmu_jpeg_ahb_clk.clkr,
3407 	[SMMU_JPEG_AXI_CLK] = &smmu_jpeg_axi_clk.clkr,
3408 	[MMAGIC_MDSS_AXI_CLK] = &mmagic_mdss_axi_clk.clkr,
3409 	[MMAGIC_MDSS_NOC_CFG_AHB_CLK] = &mmagic_mdss_noc_cfg_ahb_clk.clkr,
3410 	[SMMU_ROT_AHB_CLK] = &smmu_rot_ahb_clk.clkr,
3411 	[SMMU_ROT_AXI_CLK] = &smmu_rot_axi_clk.clkr,
3412 	[SMMU_MDP_AHB_CLK] = &smmu_mdp_ahb_clk.clkr,
3413 	[SMMU_MDP_AXI_CLK] = &smmu_mdp_axi_clk.clkr,
3414 	[MMAGIC_VIDEO_AXI_CLK] = &mmagic_video_axi_clk.clkr,
3415 	[MMAGIC_VIDEO_NOC_CFG_AHB_CLK] = &mmagic_video_noc_cfg_ahb_clk.clkr,
3416 	[SMMU_VIDEO_AHB_CLK] = &smmu_video_ahb_clk.clkr,
3417 	[SMMU_VIDEO_AXI_CLK] = &smmu_video_axi_clk.clkr,
3418 	[MMAGIC_BIMC_NOC_CFG_AHB_CLK] = &mmagic_bimc_noc_cfg_ahb_clk.clkr,
3419 	[GPU_GX_GFX3D_CLK] = &gpu_gx_gfx3d_clk.clkr,
3420 	[GPU_GX_RBBMTIMER_CLK] = &gpu_gx_rbbmtimer_clk.clkr,
3421 	[GPU_AHB_CLK] = &gpu_ahb_clk.clkr,
3422 	[GPU_AON_ISENSE_CLK] = &gpu_aon_isense_clk.clkr,
3423 	[VMEM_MAXI_CLK] = &vmem_maxi_clk.clkr,
3424 	[VMEM_AHB_CLK] = &vmem_ahb_clk.clkr,
3425 	[MMSS_RBCPR_CLK] = &mmss_rbcpr_clk.clkr,
3426 	[MMSS_RBCPR_AHB_CLK] = &mmss_rbcpr_ahb_clk.clkr,
3427 	[VIDEO_CORE_CLK] = &video_core_clk.clkr,
3428 	[VIDEO_AXI_CLK] = &video_axi_clk.clkr,
3429 	[VIDEO_MAXI_CLK] = &video_maxi_clk.clkr,
3430 	[VIDEO_AHB_CLK] = &video_ahb_clk.clkr,
3431 	[VIDEO_SUBCORE0_CLK] = &video_subcore0_clk.clkr,
3432 	[VIDEO_SUBCORE1_CLK] = &video_subcore1_clk.clkr,
3433 	[MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
3434 	[MDSS_HDMI_AHB_CLK] = &mdss_hdmi_ahb_clk.clkr,
3435 	[MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
3436 	[MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
3437 	[MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
3438 	[MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
3439 	[MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
3440 	[MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
3441 	[MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
3442 	[MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
3443 	[MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
3444 	[MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
3445 	[MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
3446 	[CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
3447 	[CAMSS_AHB_CLK] = &camss_ahb_clk.clkr,
3448 	[CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
3449 	[CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
3450 	[CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
3451 	[CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
3452 	[CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
3453 	[CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
3454 	[CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
3455 	[CAMSS_CCI_CLK] = &camss_cci_clk.clkr,
3456 	[CAMSS_CCI_AHB_CLK] = &camss_cci_ahb_clk.clkr,
3457 	[CAMSS_CSI0PHYTIMER_CLK] = &camss_csi0phytimer_clk.clkr,
3458 	[CAMSS_CSI1PHYTIMER_CLK] = &camss_csi1phytimer_clk.clkr,
3459 	[CAMSS_CSI2PHYTIMER_CLK] = &camss_csi2phytimer_clk.clkr,
3460 	[CAMSS_CSIPHY0_3P_CLK] = &camss_csiphy0_3p_clk.clkr,
3461 	[CAMSS_CSIPHY1_3P_CLK] = &camss_csiphy1_3p_clk.clkr,
3462 	[CAMSS_CSIPHY2_3P_CLK] = &camss_csiphy2_3p_clk.clkr,
3463 	[CAMSS_JPEG0_CLK] = &camss_jpeg0_clk.clkr,
3464 	[CAMSS_JPEG2_CLK] = &camss_jpeg2_clk.clkr,
3465 	[CAMSS_JPEG_DMA_CLK] = &camss_jpeg_dma_clk.clkr,
3466 	[CAMSS_JPEG_AHB_CLK] = &camss_jpeg_ahb_clk.clkr,
3467 	[CAMSS_JPEG_AXI_CLK] = &camss_jpeg_axi_clk.clkr,
3468 	[CAMSS_VFE_AHB_CLK] = &camss_vfe_ahb_clk.clkr,
3469 	[CAMSS_VFE_AXI_CLK] = &camss_vfe_axi_clk.clkr,
3470 	[CAMSS_VFE0_CLK] = &camss_vfe0_clk.clkr,
3471 	[CAMSS_VFE0_STREAM_CLK] = &camss_vfe0_stream_clk.clkr,
3472 	[CAMSS_VFE0_AHB_CLK] = &camss_vfe0_ahb_clk.clkr,
3473 	[CAMSS_VFE1_CLK] = &camss_vfe1_clk.clkr,
3474 	[CAMSS_VFE1_STREAM_CLK] = &camss_vfe1_stream_clk.clkr,
3475 	[CAMSS_VFE1_AHB_CLK] = &camss_vfe1_ahb_clk.clkr,
3476 	[CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
3477 	[CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
3478 	[CAMSS_CPP_VBIF_AHB_CLK] = &camss_cpp_vbif_ahb_clk.clkr,
3479 	[CAMSS_CPP_AXI_CLK] = &camss_cpp_axi_clk.clkr,
3480 	[CAMSS_CPP_CLK] = &camss_cpp_clk.clkr,
3481 	[CAMSS_CPP_AHB_CLK] = &camss_cpp_ahb_clk.clkr,
3482 	[CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
3483 	[CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
3484 	[CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
3485 	[CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
3486 	[CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
3487 	[CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
3488 	[CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
3489 	[CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
3490 	[CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
3491 	[CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
3492 	[CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
3493 	[CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
3494 	[CAMSS_CSI2PHY_CLK] = &camss_csi2phy_clk.clkr,
3495 	[CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
3496 	[CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
3497 	[CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
3498 	[CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
3499 	[CAMSS_CSI3PHY_CLK] = &camss_csi3phy_clk.clkr,
3500 	[CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
3501 	[CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
3502 	[CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
3503 	[FD_CORE_CLK] = &fd_core_clk.clkr,
3504 	[FD_CORE_UAR_CLK] = &fd_core_uar_clk.clkr,
3505 	[FD_AHB_CLK] = &fd_ahb_clk.clkr,
3506 };
3507 
3508 static struct gdsc *mmcc_msm8996_gdscs[] = {
3509 	[MMAGIC_BIMC_GDSC] = &mmagic_bimc_gdsc,
3510 	[MMAGIC_VIDEO_GDSC] = &mmagic_video_gdsc,
3511 	[MMAGIC_MDSS_GDSC] = &mmagic_mdss_gdsc,
3512 	[MMAGIC_CAMSS_GDSC] = &mmagic_camss_gdsc,
3513 	[VENUS_GDSC] = &venus_gdsc,
3514 	[VENUS_CORE0_GDSC] = &venus_core0_gdsc,
3515 	[VENUS_CORE1_GDSC] = &venus_core1_gdsc,
3516 	[CAMSS_GDSC] = &camss_gdsc,
3517 	[VFE0_GDSC] = &vfe0_gdsc,
3518 	[VFE1_GDSC] = &vfe1_gdsc,
3519 	[JPEG_GDSC] = &jpeg_gdsc,
3520 	[CPP_GDSC] = &cpp_gdsc,
3521 	[FD_GDSC] = &fd_gdsc,
3522 	[MDSS_GDSC] = &mdss_gdsc,
3523 	[GPU_GDSC] = &gpu_gdsc,
3524 	[GPU_GX_GDSC] = &gpu_gx_gdsc,
3525 };
3526 
3527 static const struct qcom_reset_map mmcc_msm8996_resets[] = {
3528 	[MMAGICAHB_BCR] = { 0x5020 },
3529 	[MMAGIC_CFG_BCR] = { 0x5050 },
3530 	[MISC_BCR] = { 0x5010 },
3531 	[BTO_BCR] = { 0x5030 },
3532 	[MMAGICAXI_BCR] = { 0x5060 },
3533 	[MMAGICMAXI_BCR] = { 0x5070 },
3534 	[DSA_BCR] = { 0x50a0 },
3535 	[MMAGIC_CAMSS_BCR] = { 0x3c40 },
3536 	[THROTTLE_CAMSS_BCR] = { 0x3c30 },
3537 	[SMMU_VFE_BCR] = { 0x3c00 },
3538 	[SMMU_CPP_BCR] = { 0x3c10 },
3539 	[SMMU_JPEG_BCR] = { 0x3c20 },
3540 	[MMAGIC_MDSS_BCR] = { 0x2470 },
3541 	[THROTTLE_MDSS_BCR] = { 0x2460 },
3542 	[SMMU_ROT_BCR] = { 0x2440 },
3543 	[SMMU_MDP_BCR] = { 0x2450 },
3544 	[MMAGIC_VIDEO_BCR] = { 0x1190 },
3545 	[THROTTLE_VIDEO_BCR] = { 0x1180 },
3546 	[SMMU_VIDEO_BCR] = { 0x1170 },
3547 	[MMAGIC_BIMC_BCR] = { 0x5290 },
3548 	[GPU_GX_BCR] = { 0x4020 },
3549 	[GPU_BCR] = { 0x4030 },
3550 	[GPU_AON_BCR] = { 0x4040 },
3551 	[VMEM_BCR] = { 0x1200 },
3552 	[MMSS_RBCPR_BCR] = { 0x4080 },
3553 	[VIDEO_BCR] = { 0x1020 },
3554 	[MDSS_BCR] = { 0x2300 },
3555 	[CAMSS_TOP_BCR] = { 0x3480 },
3556 	[CAMSS_AHB_BCR] = { 0x3488 },
3557 	[CAMSS_MICRO_BCR] = { 0x3490 },
3558 	[CAMSS_CCI_BCR] = { 0x3340 },
3559 	[CAMSS_PHY0_BCR] = { 0x3020 },
3560 	[CAMSS_PHY1_BCR] = { 0x3050 },
3561 	[CAMSS_PHY2_BCR] = { 0x3080 },
3562 	[CAMSS_CSIPHY0_3P_BCR] = { 0x3230 },
3563 	[CAMSS_CSIPHY1_3P_BCR] = { 0x3250 },
3564 	[CAMSS_CSIPHY2_3P_BCR] = { 0x3270 },
3565 	[CAMSS_JPEG_BCR] = { 0x35a0 },
3566 	[CAMSS_VFE_BCR] = { 0x36a0 },
3567 	[CAMSS_VFE0_BCR] = { 0x3660 },
3568 	[CAMSS_VFE1_BCR] = { 0x3670 },
3569 	[CAMSS_CSI_VFE0_BCR] = { 0x3700 },
3570 	[CAMSS_CSI_VFE1_BCR] = { 0x3710 },
3571 	[CAMSS_CPP_TOP_BCR] = { 0x36c0 },
3572 	[CAMSS_CPP_BCR] = { 0x36d0 },
3573 	[CAMSS_CSI0_BCR] = { 0x30b0 },
3574 	[CAMSS_CSI0RDI_BCR] = { 0x30d0 },
3575 	[CAMSS_CSI0PIX_BCR] = { 0x30e0 },
3576 	[CAMSS_CSI1_BCR] = { 0x3120 },
3577 	[CAMSS_CSI1RDI_BCR] = { 0x3140 },
3578 	[CAMSS_CSI1PIX_BCR] = { 0x3150 },
3579 	[CAMSS_CSI2_BCR] = { 0x3180 },
3580 	[CAMSS_CSI2RDI_BCR] = { 0x31a0 },
3581 	[CAMSS_CSI2PIX_BCR] = { 0x31b0 },
3582 	[CAMSS_CSI3_BCR] = { 0x31e0 },
3583 	[CAMSS_CSI3RDI_BCR] = { 0x3200 },
3584 	[CAMSS_CSI3PIX_BCR] = { 0x3210 },
3585 	[CAMSS_ISPIF_BCR] = { 0x3220 },
3586 	[FD_BCR] = { 0x3b60 },
3587 	[MMSS_SPDM_RM_BCR] = { 0x300 },
3588 };
3589 
3590 static const struct regmap_config mmcc_msm8996_regmap_config = {
3591 	.reg_bits	= 32,
3592 	.reg_stride	= 4,
3593 	.val_bits	= 32,
3594 	.max_register	= 0xb008,
3595 	.fast_io	= true,
3596 };
3597 
3598 static const struct qcom_cc_desc mmcc_msm8996_desc = {
3599 	.config = &mmcc_msm8996_regmap_config,
3600 	.clks = mmcc_msm8996_clocks,
3601 	.num_clks = ARRAY_SIZE(mmcc_msm8996_clocks),
3602 	.resets = mmcc_msm8996_resets,
3603 	.num_resets = ARRAY_SIZE(mmcc_msm8996_resets),
3604 	.gdscs = mmcc_msm8996_gdscs,
3605 	.num_gdscs = ARRAY_SIZE(mmcc_msm8996_gdscs),
3606 	.clk_hws = mmcc_msm8996_hws,
3607 	.num_clk_hws = ARRAY_SIZE(mmcc_msm8996_hws),
3608 };
3609 
3610 static const struct of_device_id mmcc_msm8996_match_table[] = {
3611 	{ .compatible = "qcom,mmcc-msm8996" },
3612 	{ }
3613 };
3614 MODULE_DEVICE_TABLE(of, mmcc_msm8996_match_table);
3615 
mmcc_msm8996_probe(struct platform_device * pdev)3616 static int mmcc_msm8996_probe(struct platform_device *pdev)
3617 {
3618 	struct regmap *regmap;
3619 
3620 	regmap = qcom_cc_map(pdev, &mmcc_msm8996_desc);
3621 	if (IS_ERR(regmap))
3622 		return PTR_ERR(regmap);
3623 
3624 	/* Disable the AHB DCD */
3625 	regmap_update_bits(regmap, 0x50d8, BIT(31), 0);
3626 	/* Disable the NoC FSM for mmss_mmagic_cfg_ahb_clk */
3627 	regmap_update_bits(regmap, 0x5054, BIT(15), 0);
3628 
3629 	return qcom_cc_really_probe(pdev, &mmcc_msm8996_desc, regmap);
3630 }
3631 
3632 static struct platform_driver mmcc_msm8996_driver = {
3633 	.probe		= mmcc_msm8996_probe,
3634 	.driver		= {
3635 		.name	= "mmcc-msm8996",
3636 		.of_match_table = mmcc_msm8996_match_table,
3637 	},
3638 };
3639 module_platform_driver(mmcc_msm8996_driver);
3640 
3641 MODULE_DESCRIPTION("QCOM MMCC MSM8996 Driver");
3642 MODULE_LICENSE("GPL v2");
3643 MODULE_ALIAS("platform:mmcc-msm8996");
3644