1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (c) 2014-2015, The Linux Foundation. All rights reserved.
4  */
5 
6 #include <linux/kernel.h>
7 #include <linux/platform_device.h>
8 #include <linux/module.h>
9 #include <linux/regmap.h>
10 #include <linux/reset-controller.h>
11 
12 #include <dt-bindings/clock/qcom,mmcc-apq8084.h>
13 #include <dt-bindings/reset/qcom,mmcc-apq8084.h>
14 
15 #include "common.h"
16 #include "clk-regmap.h"
17 #include "clk-pll.h"
18 #include "clk-rcg.h"
19 #include "clk-branch.h"
20 #include "reset.h"
21 #include "gdsc.h"
22 
23 enum {
24 	P_XO,
25 	P_MMPLL0,
26 	P_EDPLINK,
27 	P_MMPLL1,
28 	P_HDMIPLL,
29 	P_GPLL0,
30 	P_EDPVCO,
31 	P_MMPLL4,
32 	P_DSI0PLL,
33 	P_DSI0PLL_BYTE,
34 	P_MMPLL2,
35 	P_MMPLL3,
36 	P_GPLL1,
37 	P_DSI1PLL,
38 	P_DSI1PLL_BYTE,
39 	P_MMSLEEP,
40 };
41 
42 static const struct parent_map mmcc_xo_mmpll0_mmpll1_gpll0_map[] = {
43 	{ P_XO, 0 },
44 	{ P_MMPLL0, 1 },
45 	{ P_MMPLL1, 2 },
46 	{ P_GPLL0, 5 }
47 };
48 
49 static const char * const mmcc_xo_mmpll0_mmpll1_gpll0[] = {
50 	"xo",
51 	"mmpll0_vote",
52 	"mmpll1_vote",
53 	"mmss_gpll0_vote",
54 };
55 
56 static const struct parent_map mmcc_xo_mmpll0_dsi_hdmi_gpll0_map[] = {
57 	{ P_XO, 0 },
58 	{ P_MMPLL0, 1 },
59 	{ P_HDMIPLL, 4 },
60 	{ P_GPLL0, 5 },
61 	{ P_DSI0PLL, 2 },
62 	{ P_DSI1PLL, 3 }
63 };
64 
65 static const char * const mmcc_xo_mmpll0_dsi_hdmi_gpll0[] = {
66 	"xo",
67 	"mmpll0_vote",
68 	"hdmipll",
69 	"mmss_gpll0_vote",
70 	"dsi0pll",
71 	"dsi1pll",
72 };
73 
74 static const struct parent_map mmcc_xo_mmpll0_1_2_gpll0_map[] = {
75 	{ P_XO, 0 },
76 	{ P_MMPLL0, 1 },
77 	{ P_MMPLL1, 2 },
78 	{ P_GPLL0, 5 },
79 	{ P_MMPLL2, 3 }
80 };
81 
82 static const char * const mmcc_xo_mmpll0_1_2_gpll0[] = {
83 	"xo",
84 	"mmpll0_vote",
85 	"mmpll1_vote",
86 	"mmss_gpll0_vote",
87 	"mmpll2",
88 };
89 
90 static const struct parent_map mmcc_xo_mmpll0_1_3_gpll0_map[] = {
91 	{ P_XO, 0 },
92 	{ P_MMPLL0, 1 },
93 	{ P_MMPLL1, 2 },
94 	{ P_GPLL0, 5 },
95 	{ P_MMPLL3, 3 }
96 };
97 
98 static const char * const mmcc_xo_mmpll0_1_3_gpll0[] = {
99 	"xo",
100 	"mmpll0_vote",
101 	"mmpll1_vote",
102 	"mmss_gpll0_vote",
103 	"mmpll3",
104 };
105 
106 static const struct parent_map mmcc_xo_dsi_hdmi_edp_map[] = {
107 	{ P_XO, 0 },
108 	{ P_EDPLINK, 4 },
109 	{ P_HDMIPLL, 3 },
110 	{ P_EDPVCO, 5 },
111 	{ P_DSI0PLL, 1 },
112 	{ P_DSI1PLL, 2 }
113 };
114 
115 static const char * const mmcc_xo_dsi_hdmi_edp[] = {
116 	"xo",
117 	"edp_link_clk",
118 	"hdmipll",
119 	"edp_vco_div",
120 	"dsi0pll",
121 	"dsi1pll",
122 };
123 
124 static const struct parent_map mmcc_xo_dsi_hdmi_edp_gpll0_map[] = {
125 	{ P_XO, 0 },
126 	{ P_EDPLINK, 4 },
127 	{ P_HDMIPLL, 3 },
128 	{ P_GPLL0, 5 },
129 	{ P_DSI0PLL, 1 },
130 	{ P_DSI1PLL, 2 }
131 };
132 
133 static const char * const mmcc_xo_dsi_hdmi_edp_gpll0[] = {
134 	"xo",
135 	"edp_link_clk",
136 	"hdmipll",
137 	"gpll0_vote",
138 	"dsi0pll",
139 	"dsi1pll",
140 };
141 
142 static const struct parent_map mmcc_xo_dsibyte_hdmi_edp_gpll0_map[] = {
143 	{ P_XO, 0 },
144 	{ P_EDPLINK, 4 },
145 	{ P_HDMIPLL, 3 },
146 	{ P_GPLL0, 5 },
147 	{ P_DSI0PLL_BYTE, 1 },
148 	{ P_DSI1PLL_BYTE, 2 }
149 };
150 
151 static const char * const mmcc_xo_dsibyte_hdmi_edp_gpll0[] = {
152 	"xo",
153 	"edp_link_clk",
154 	"hdmipll",
155 	"gpll0_vote",
156 	"dsi0pllbyte",
157 	"dsi1pllbyte",
158 };
159 
160 static const struct parent_map mmcc_xo_mmpll0_1_4_gpll0_map[] = {
161 	{ P_XO, 0 },
162 	{ P_MMPLL0, 1 },
163 	{ P_MMPLL1, 2 },
164 	{ P_GPLL0, 5 },
165 	{ P_MMPLL4, 3 }
166 };
167 
168 static const char * const mmcc_xo_mmpll0_1_4_gpll0[] = {
169 	"xo",
170 	"mmpll0",
171 	"mmpll1",
172 	"mmpll4",
173 	"gpll0",
174 };
175 
176 static const struct parent_map mmcc_xo_mmpll0_1_4_gpll1_0_map[] = {
177 	{ P_XO, 0 },
178 	{ P_MMPLL0, 1 },
179 	{ P_MMPLL1, 2 },
180 	{ P_MMPLL4, 3 },
181 	{ P_GPLL0, 5 },
182 	{ P_GPLL1, 4 }
183 };
184 
185 static const char * const mmcc_xo_mmpll0_1_4_gpll1_0[] = {
186 	"xo",
187 	"mmpll0",
188 	"mmpll1",
189 	"mmpll4",
190 	"gpll1",
191 	"gpll0",
192 };
193 
194 static const struct parent_map mmcc_xo_mmpll0_1_4_gpll1_0_sleep_map[] = {
195 	{ P_XO, 0 },
196 	{ P_MMPLL0, 1 },
197 	{ P_MMPLL1, 2 },
198 	{ P_MMPLL4, 3 },
199 	{ P_GPLL0, 5 },
200 	{ P_GPLL1, 4 },
201 	{ P_MMSLEEP, 6 }
202 };
203 
204 static const char * const mmcc_xo_mmpll0_1_4_gpll1_0_sleep[] = {
205 	"xo",
206 	"mmpll0",
207 	"mmpll1",
208 	"mmpll4",
209 	"gpll1",
210 	"gpll0",
211 	"sleep_clk_src",
212 };
213 
214 static struct clk_pll mmpll0 = {
215 	.l_reg = 0x0004,
216 	.m_reg = 0x0008,
217 	.n_reg = 0x000c,
218 	.config_reg = 0x0014,
219 	.mode_reg = 0x0000,
220 	.status_reg = 0x001c,
221 	.status_bit = 17,
222 	.clkr.hw.init = &(struct clk_init_data){
223 		.name = "mmpll0",
224 		.parent_names = (const char *[]){ "xo" },
225 		.num_parents = 1,
226 		.ops = &clk_pll_ops,
227 	},
228 };
229 
230 static struct clk_regmap mmpll0_vote = {
231 	.enable_reg = 0x0100,
232 	.enable_mask = BIT(0),
233 	.hw.init = &(struct clk_init_data){
234 		.name = "mmpll0_vote",
235 		.parent_names = (const char *[]){ "mmpll0" },
236 		.num_parents = 1,
237 		.ops = &clk_pll_vote_ops,
238 	},
239 };
240 
241 static struct clk_pll mmpll1 = {
242 	.l_reg = 0x0044,
243 	.m_reg = 0x0048,
244 	.n_reg = 0x004c,
245 	.config_reg = 0x0050,
246 	.mode_reg = 0x0040,
247 	.status_reg = 0x005c,
248 	.status_bit = 17,
249 	.clkr.hw.init = &(struct clk_init_data){
250 		.name = "mmpll1",
251 		.parent_names = (const char *[]){ "xo" },
252 		.num_parents = 1,
253 		.ops = &clk_pll_ops,
254 	},
255 };
256 
257 static struct clk_regmap mmpll1_vote = {
258 	.enable_reg = 0x0100,
259 	.enable_mask = BIT(1),
260 	.hw.init = &(struct clk_init_data){
261 		.name = "mmpll1_vote",
262 		.parent_names = (const char *[]){ "mmpll1" },
263 		.num_parents = 1,
264 		.ops = &clk_pll_vote_ops,
265 	},
266 };
267 
268 static struct clk_pll mmpll2 = {
269 	.l_reg = 0x4104,
270 	.m_reg = 0x4108,
271 	.n_reg = 0x410c,
272 	.config_reg = 0x4110,
273 	.mode_reg = 0x4100,
274 	.status_reg = 0x411c,
275 	.clkr.hw.init = &(struct clk_init_data){
276 		.name = "mmpll2",
277 		.parent_names = (const char *[]){ "xo" },
278 		.num_parents = 1,
279 		.ops = &clk_pll_ops,
280 	},
281 };
282 
283 static struct clk_pll mmpll3 = {
284 	.l_reg = 0x0084,
285 	.m_reg = 0x0088,
286 	.n_reg = 0x008c,
287 	.config_reg = 0x0090,
288 	.mode_reg = 0x0080,
289 	.status_reg = 0x009c,
290 	.status_bit = 17,
291 	.clkr.hw.init = &(struct clk_init_data){
292 		.name = "mmpll3",
293 		.parent_names = (const char *[]){ "xo" },
294 		.num_parents = 1,
295 		.ops = &clk_pll_ops,
296 	},
297 };
298 
299 static struct clk_pll mmpll4 = {
300 	.l_reg = 0x00a4,
301 	.m_reg = 0x00a8,
302 	.n_reg = 0x00ac,
303 	.config_reg = 0x00b0,
304 	.mode_reg = 0x0080,
305 	.status_reg = 0x00bc,
306 	.clkr.hw.init = &(struct clk_init_data){
307 		.name = "mmpll4",
308 		.parent_names = (const char *[]){ "xo" },
309 		.num_parents = 1,
310 		.ops = &clk_pll_ops,
311 	},
312 };
313 
314 static struct clk_rcg2 mmss_ahb_clk_src = {
315 	.cmd_rcgr = 0x5000,
316 	.hid_width = 5,
317 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
318 	.clkr.hw.init = &(struct clk_init_data){
319 		.name = "mmss_ahb_clk_src",
320 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
321 		.num_parents = 4,
322 		.ops = &clk_rcg2_ops,
323 	},
324 };
325 
326 static struct freq_tbl ftbl_mmss_axi_clk[] = {
327 	F(19200000, P_XO, 1, 0, 0),
328 	F(37500000, P_GPLL0, 16, 0, 0),
329 	F(50000000, P_GPLL0, 12, 0, 0),
330 	F(75000000, P_GPLL0, 8, 0, 0),
331 	F(100000000, P_GPLL0, 6, 0, 0),
332 	F(150000000, P_GPLL0, 4, 0, 0),
333 	F(333430000, P_MMPLL1, 3.5, 0, 0),
334 	F(400000000, P_MMPLL0, 2, 0, 0),
335 	F(466800000, P_MMPLL1, 2.5, 0, 0),
336 };
337 
338 static struct clk_rcg2 mmss_axi_clk_src = {
339 	.cmd_rcgr = 0x5040,
340 	.hid_width = 5,
341 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
342 	.freq_tbl = ftbl_mmss_axi_clk,
343 	.clkr.hw.init = &(struct clk_init_data){
344 		.name = "mmss_axi_clk_src",
345 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
346 		.num_parents = 4,
347 		.ops = &clk_rcg2_ops,
348 	},
349 };
350 
351 static struct freq_tbl ftbl_ocmemnoc_clk[] = {
352 	F(19200000, P_XO, 1, 0, 0),
353 	F(37500000, P_GPLL0, 16, 0, 0),
354 	F(50000000, P_GPLL0, 12, 0, 0),
355 	F(75000000, P_GPLL0, 8, 0, 0),
356 	F(109090000, P_GPLL0, 5.5, 0, 0),
357 	F(150000000, P_GPLL0, 4, 0, 0),
358 	F(228570000, P_MMPLL0, 3.5, 0, 0),
359 	F(320000000, P_MMPLL0, 2.5, 0, 0),
360 };
361 
362 static struct clk_rcg2 ocmemnoc_clk_src = {
363 	.cmd_rcgr = 0x5090,
364 	.hid_width = 5,
365 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
366 	.freq_tbl = ftbl_ocmemnoc_clk,
367 	.clkr.hw.init = &(struct clk_init_data){
368 		.name = "ocmemnoc_clk_src",
369 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
370 		.num_parents = 4,
371 		.ops = &clk_rcg2_ops,
372 	},
373 };
374 
375 static struct freq_tbl ftbl_camss_csi0_3_clk[] = {
376 	F(100000000, P_GPLL0, 6, 0, 0),
377 	F(200000000, P_MMPLL0, 4, 0, 0),
378 	{ }
379 };
380 
381 static struct clk_rcg2 csi0_clk_src = {
382 	.cmd_rcgr = 0x3090,
383 	.hid_width = 5,
384 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
385 	.freq_tbl = ftbl_camss_csi0_3_clk,
386 	.clkr.hw.init = &(struct clk_init_data){
387 		.name = "csi0_clk_src",
388 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
389 		.num_parents = 5,
390 		.ops = &clk_rcg2_ops,
391 	},
392 };
393 
394 static struct clk_rcg2 csi1_clk_src = {
395 	.cmd_rcgr = 0x3100,
396 	.hid_width = 5,
397 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
398 	.freq_tbl = ftbl_camss_csi0_3_clk,
399 	.clkr.hw.init = &(struct clk_init_data){
400 		.name = "csi1_clk_src",
401 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
402 		.num_parents = 5,
403 		.ops = &clk_rcg2_ops,
404 	},
405 };
406 
407 static struct clk_rcg2 csi2_clk_src = {
408 	.cmd_rcgr = 0x3160,
409 	.hid_width = 5,
410 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
411 	.freq_tbl = ftbl_camss_csi0_3_clk,
412 	.clkr.hw.init = &(struct clk_init_data){
413 		.name = "csi2_clk_src",
414 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
415 		.num_parents = 5,
416 		.ops = &clk_rcg2_ops,
417 	},
418 };
419 
420 static struct clk_rcg2 csi3_clk_src = {
421 	.cmd_rcgr = 0x31c0,
422 	.hid_width = 5,
423 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
424 	.freq_tbl = ftbl_camss_csi0_3_clk,
425 	.clkr.hw.init = &(struct clk_init_data){
426 		.name = "csi3_clk_src",
427 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
428 		.num_parents = 5,
429 		.ops = &clk_rcg2_ops,
430 	},
431 };
432 
433 static struct freq_tbl ftbl_camss_vfe_vfe0_1_clk[] = {
434 	F(37500000, P_GPLL0, 16, 0, 0),
435 	F(50000000, P_GPLL0, 12, 0, 0),
436 	F(60000000, P_GPLL0, 10, 0, 0),
437 	F(80000000, P_GPLL0, 7.5, 0, 0),
438 	F(100000000, P_GPLL0, 6, 0, 0),
439 	F(109090000, P_GPLL0, 5.5, 0, 0),
440 	F(133330000, P_GPLL0, 4.5, 0, 0),
441 	F(200000000, P_GPLL0, 3, 0, 0),
442 	F(228570000, P_MMPLL0, 3.5, 0, 0),
443 	F(266670000, P_MMPLL0, 3, 0, 0),
444 	F(320000000, P_MMPLL0, 2.5, 0, 0),
445 	F(465000000, P_MMPLL4, 2, 0, 0),
446 	F(600000000, P_GPLL0, 1, 0, 0),
447 	{ }
448 };
449 
450 static struct clk_rcg2 vfe0_clk_src = {
451 	.cmd_rcgr = 0x3600,
452 	.hid_width = 5,
453 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
454 	.freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
455 	.clkr.hw.init = &(struct clk_init_data){
456 		.name = "vfe0_clk_src",
457 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
458 		.num_parents = 5,
459 		.ops = &clk_rcg2_ops,
460 	},
461 };
462 
463 static struct clk_rcg2 vfe1_clk_src = {
464 	.cmd_rcgr = 0x3620,
465 	.hid_width = 5,
466 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
467 	.freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
468 	.clkr.hw.init = &(struct clk_init_data){
469 		.name = "vfe1_clk_src",
470 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
471 		.num_parents = 5,
472 		.ops = &clk_rcg2_ops,
473 	},
474 };
475 
476 static struct freq_tbl ftbl_mdss_mdp_clk[] = {
477 	F(37500000, P_GPLL0, 16, 0, 0),
478 	F(60000000, P_GPLL0, 10, 0, 0),
479 	F(75000000, P_GPLL0, 8, 0, 0),
480 	F(85710000, P_GPLL0, 7, 0, 0),
481 	F(100000000, P_GPLL0, 6, 0, 0),
482 	F(150000000, P_GPLL0, 4, 0, 0),
483 	F(160000000, P_MMPLL0, 5, 0, 0),
484 	F(200000000, P_MMPLL0, 4, 0, 0),
485 	F(228570000, P_MMPLL0, 3.5, 0, 0),
486 	F(300000000, P_GPLL0, 2, 0, 0),
487 	F(320000000, P_MMPLL0, 2.5, 0, 0),
488 	{ }
489 };
490 
491 static struct clk_rcg2 mdp_clk_src = {
492 	.cmd_rcgr = 0x2040,
493 	.hid_width = 5,
494 	.parent_map = mmcc_xo_mmpll0_dsi_hdmi_gpll0_map,
495 	.freq_tbl = ftbl_mdss_mdp_clk,
496 	.clkr.hw.init = &(struct clk_init_data){
497 		.name = "mdp_clk_src",
498 		.parent_names = mmcc_xo_mmpll0_dsi_hdmi_gpll0,
499 		.num_parents = 6,
500 		.ops = &clk_rcg2_ops,
501 	},
502 };
503 
504 static struct clk_rcg2 gfx3d_clk_src = {
505 	.cmd_rcgr = 0x4000,
506 	.hid_width = 5,
507 	.parent_map = mmcc_xo_mmpll0_1_2_gpll0_map,
508 	.clkr.hw.init = &(struct clk_init_data){
509 		.name = "gfx3d_clk_src",
510 		.parent_names = mmcc_xo_mmpll0_1_2_gpll0,
511 		.num_parents = 5,
512 		.ops = &clk_rcg2_ops,
513 	},
514 };
515 
516 static struct freq_tbl ftbl_camss_jpeg_jpeg0_2_clk[] = {
517 	F(75000000, P_GPLL0, 8, 0, 0),
518 	F(133330000, P_GPLL0, 4.5, 0, 0),
519 	F(200000000, P_GPLL0, 3, 0, 0),
520 	F(228570000, P_MMPLL0, 3.5, 0, 0),
521 	F(266670000, P_MMPLL0, 3, 0, 0),
522 	F(320000000, P_MMPLL0, 2.5, 0, 0),
523 	{ }
524 };
525 
526 static struct clk_rcg2 jpeg0_clk_src = {
527 	.cmd_rcgr = 0x3500,
528 	.hid_width = 5,
529 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
530 	.freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
531 	.clkr.hw.init = &(struct clk_init_data){
532 		.name = "jpeg0_clk_src",
533 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
534 		.num_parents = 5,
535 		.ops = &clk_rcg2_ops,
536 	},
537 };
538 
539 static struct clk_rcg2 jpeg1_clk_src = {
540 	.cmd_rcgr = 0x3520,
541 	.hid_width = 5,
542 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
543 	.freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
544 	.clkr.hw.init = &(struct clk_init_data){
545 		.name = "jpeg1_clk_src",
546 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
547 		.num_parents = 5,
548 		.ops = &clk_rcg2_ops,
549 	},
550 };
551 
552 static struct clk_rcg2 jpeg2_clk_src = {
553 	.cmd_rcgr = 0x3540,
554 	.hid_width = 5,
555 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
556 	.freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
557 	.clkr.hw.init = &(struct clk_init_data){
558 		.name = "jpeg2_clk_src",
559 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
560 		.num_parents = 5,
561 		.ops = &clk_rcg2_ops,
562 	},
563 };
564 
565 static struct clk_rcg2 pclk0_clk_src = {
566 	.cmd_rcgr = 0x2000,
567 	.mnd_width = 8,
568 	.hid_width = 5,
569 	.parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
570 	.clkr.hw.init = &(struct clk_init_data){
571 		.name = "pclk0_clk_src",
572 		.parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
573 		.num_parents = 6,
574 		.ops = &clk_pixel_ops,
575 		.flags = CLK_SET_RATE_PARENT,
576 	},
577 };
578 
579 static struct clk_rcg2 pclk1_clk_src = {
580 	.cmd_rcgr = 0x2020,
581 	.mnd_width = 8,
582 	.hid_width = 5,
583 	.parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
584 	.clkr.hw.init = &(struct clk_init_data){
585 		.name = "pclk1_clk_src",
586 		.parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
587 		.num_parents = 6,
588 		.ops = &clk_pixel_ops,
589 		.flags = CLK_SET_RATE_PARENT,
590 	},
591 };
592 
593 static struct freq_tbl ftbl_venus0_vcodec0_clk[] = {
594 	F(50000000, P_GPLL0, 12, 0, 0),
595 	F(100000000, P_GPLL0, 6, 0, 0),
596 	F(133330000, P_GPLL0, 4.5, 0, 0),
597 	F(200000000, P_MMPLL0, 4, 0, 0),
598 	F(266670000, P_MMPLL0, 3, 0, 0),
599 	F(465000000, P_MMPLL3, 2, 0, 0),
600 	{ }
601 };
602 
603 static struct clk_rcg2 vcodec0_clk_src = {
604 	.cmd_rcgr = 0x1000,
605 	.mnd_width = 8,
606 	.hid_width = 5,
607 	.parent_map = mmcc_xo_mmpll0_1_3_gpll0_map,
608 	.freq_tbl = ftbl_venus0_vcodec0_clk,
609 	.clkr.hw.init = &(struct clk_init_data){
610 		.name = "vcodec0_clk_src",
611 		.parent_names = mmcc_xo_mmpll0_1_3_gpll0,
612 		.num_parents = 5,
613 		.ops = &clk_rcg2_ops,
614 	},
615 };
616 
617 static struct freq_tbl ftbl_avsync_vp_clk[] = {
618 	F(150000000, P_GPLL0, 4, 0, 0),
619 	F(320000000, P_MMPLL0, 2.5, 0, 0),
620 	{ }
621 };
622 
623 static struct clk_rcg2 vp_clk_src = {
624 	.cmd_rcgr = 0x2430,
625 	.hid_width = 5,
626 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
627 	.freq_tbl = ftbl_avsync_vp_clk,
628 	.clkr.hw.init = &(struct clk_init_data){
629 		.name = "vp_clk_src",
630 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
631 		.num_parents = 4,
632 		.ops = &clk_rcg2_ops,
633 	},
634 };
635 
636 static struct freq_tbl ftbl_camss_cci_cci_clk[] = {
637 	F(19200000, P_XO, 1, 0, 0),
638 	{ }
639 };
640 
641 static struct clk_rcg2 cci_clk_src = {
642 	.cmd_rcgr = 0x3300,
643 	.mnd_width = 8,
644 	.hid_width = 5,
645 	.parent_map = mmcc_xo_mmpll0_1_4_gpll1_0_map,
646 	.freq_tbl = ftbl_camss_cci_cci_clk,
647 	.clkr.hw.init = &(struct clk_init_data){
648 		.name = "cci_clk_src",
649 		.parent_names = mmcc_xo_mmpll0_1_4_gpll1_0,
650 		.num_parents = 6,
651 		.ops = &clk_rcg2_ops,
652 	},
653 };
654 
655 static struct freq_tbl ftbl_camss_gp0_1_clk[] = {
656 	F(10000, P_XO, 16, 1, 120),
657 	F(24000, P_XO, 16, 1, 50),
658 	F(6000000, P_GPLL0, 10, 1, 10),
659 	F(12000000, P_GPLL0, 10, 1, 5),
660 	F(13000000, P_GPLL0, 4, 13, 150),
661 	F(24000000, P_GPLL0, 5, 1, 5),
662 	{ }
663 };
664 
665 static struct clk_rcg2 camss_gp0_clk_src = {
666 	.cmd_rcgr = 0x3420,
667 	.mnd_width = 8,
668 	.hid_width = 5,
669 	.parent_map = mmcc_xo_mmpll0_1_4_gpll1_0_sleep_map,
670 	.freq_tbl = ftbl_camss_gp0_1_clk,
671 	.clkr.hw.init = &(struct clk_init_data){
672 		.name = "camss_gp0_clk_src",
673 		.parent_names = mmcc_xo_mmpll0_1_4_gpll1_0_sleep,
674 		.num_parents = 7,
675 		.ops = &clk_rcg2_ops,
676 	},
677 };
678 
679 static struct clk_rcg2 camss_gp1_clk_src = {
680 	.cmd_rcgr = 0x3450,
681 	.mnd_width = 8,
682 	.hid_width = 5,
683 	.parent_map = mmcc_xo_mmpll0_1_4_gpll1_0_sleep_map,
684 	.freq_tbl = ftbl_camss_gp0_1_clk,
685 	.clkr.hw.init = &(struct clk_init_data){
686 		.name = "camss_gp1_clk_src",
687 		.parent_names = mmcc_xo_mmpll0_1_4_gpll1_0_sleep,
688 		.num_parents = 7,
689 		.ops = &clk_rcg2_ops,
690 	},
691 };
692 
693 static struct freq_tbl ftbl_camss_mclk0_3_clk[] = {
694 	F(4800000, P_XO, 4, 0, 0),
695 	F(6000000, P_GPLL0, 10, 1, 10),
696 	F(8000000, P_GPLL0, 15, 1, 5),
697 	F(9600000, P_XO, 2, 0, 0),
698 	F(16000000, P_MMPLL0, 10, 1, 5),
699 	F(19200000, P_XO, 1, 0, 0),
700 	F(24000000, P_GPLL0, 5, 1, 5),
701 	F(32000000, P_MMPLL0, 5, 1, 5),
702 	F(48000000, P_GPLL0, 12.5, 0, 0),
703 	F(64000000, P_MMPLL0, 12.5, 0, 0),
704 	{ }
705 };
706 
707 static struct clk_rcg2 mclk0_clk_src = {
708 	.cmd_rcgr = 0x3360,
709 	.mnd_width = 8,
710 	.hid_width = 5,
711 	.parent_map = mmcc_xo_mmpll0_1_4_gpll1_0_map,
712 	.freq_tbl = ftbl_camss_mclk0_3_clk,
713 	.clkr.hw.init = &(struct clk_init_data){
714 		.name = "mclk0_clk_src",
715 		.parent_names = mmcc_xo_mmpll0_1_4_gpll1_0,
716 		.num_parents = 6,
717 		.ops = &clk_rcg2_ops,
718 	},
719 };
720 
721 static struct clk_rcg2 mclk1_clk_src = {
722 	.cmd_rcgr = 0x3390,
723 	.mnd_width = 8,
724 	.hid_width = 5,
725 	.parent_map = mmcc_xo_mmpll0_1_4_gpll1_0_map,
726 	.freq_tbl = ftbl_camss_mclk0_3_clk,
727 	.clkr.hw.init = &(struct clk_init_data){
728 		.name = "mclk1_clk_src",
729 		.parent_names = mmcc_xo_mmpll0_1_4_gpll1_0,
730 		.num_parents = 6,
731 		.ops = &clk_rcg2_ops,
732 	},
733 };
734 
735 static struct clk_rcg2 mclk2_clk_src = {
736 	.cmd_rcgr = 0x33c0,
737 	.mnd_width = 8,
738 	.hid_width = 5,
739 	.parent_map = mmcc_xo_mmpll0_1_4_gpll1_0_map,
740 	.freq_tbl = ftbl_camss_mclk0_3_clk,
741 	.clkr.hw.init = &(struct clk_init_data){
742 		.name = "mclk2_clk_src",
743 		.parent_names = mmcc_xo_mmpll0_1_4_gpll1_0,
744 		.num_parents = 6,
745 		.ops = &clk_rcg2_ops,
746 	},
747 };
748 
749 static struct clk_rcg2 mclk3_clk_src = {
750 	.cmd_rcgr = 0x33f0,
751 	.mnd_width = 8,
752 	.hid_width = 5,
753 	.parent_map = mmcc_xo_mmpll0_1_4_gpll1_0_map,
754 	.freq_tbl = ftbl_camss_mclk0_3_clk,
755 	.clkr.hw.init = &(struct clk_init_data){
756 		.name = "mclk3_clk_src",
757 		.parent_names = mmcc_xo_mmpll0_1_4_gpll1_0,
758 		.num_parents = 6,
759 		.ops = &clk_rcg2_ops,
760 	},
761 };
762 
763 static struct freq_tbl ftbl_camss_phy0_2_csi0_2phytimer_clk[] = {
764 	F(100000000, P_GPLL0, 6, 0, 0),
765 	F(200000000, P_MMPLL0, 4, 0, 0),
766 	{ }
767 };
768 
769 static struct clk_rcg2 csi0phytimer_clk_src = {
770 	.cmd_rcgr = 0x3000,
771 	.hid_width = 5,
772 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
773 	.freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
774 	.clkr.hw.init = &(struct clk_init_data){
775 		.name = "csi0phytimer_clk_src",
776 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
777 		.num_parents = 5,
778 		.ops = &clk_rcg2_ops,
779 	},
780 };
781 
782 static struct clk_rcg2 csi1phytimer_clk_src = {
783 	.cmd_rcgr = 0x3030,
784 	.hid_width = 5,
785 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
786 	.freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
787 	.clkr.hw.init = &(struct clk_init_data){
788 		.name = "csi1phytimer_clk_src",
789 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
790 		.num_parents = 5,
791 		.ops = &clk_rcg2_ops,
792 	},
793 };
794 
795 static struct clk_rcg2 csi2phytimer_clk_src = {
796 	.cmd_rcgr = 0x3060,
797 	.hid_width = 5,
798 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
799 	.freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
800 	.clkr.hw.init = &(struct clk_init_data){
801 		.name = "csi2phytimer_clk_src",
802 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
803 		.num_parents = 5,
804 		.ops = &clk_rcg2_ops,
805 	},
806 };
807 
808 static struct freq_tbl ftbl_camss_vfe_cpp_clk[] = {
809 	F(133330000, P_GPLL0, 4.5, 0, 0),
810 	F(266670000, P_MMPLL0, 3, 0, 0),
811 	F(320000000, P_MMPLL0, 2.5, 0, 0),
812 	F(372000000, P_MMPLL4, 2.5, 0, 0),
813 	F(465000000, P_MMPLL4, 2, 0, 0),
814 	F(600000000, P_GPLL0, 1, 0, 0),
815 	{ }
816 };
817 
818 static struct clk_rcg2 cpp_clk_src = {
819 	.cmd_rcgr = 0x3640,
820 	.hid_width = 5,
821 	.parent_map = mmcc_xo_mmpll0_1_4_gpll0_map,
822 	.freq_tbl = ftbl_camss_vfe_cpp_clk,
823 	.clkr.hw.init = &(struct clk_init_data){
824 		.name = "cpp_clk_src",
825 		.parent_names = mmcc_xo_mmpll0_1_4_gpll0,
826 		.num_parents = 5,
827 		.ops = &clk_rcg2_ops,
828 	},
829 };
830 
831 static struct clk_rcg2 byte0_clk_src = {
832 	.cmd_rcgr = 0x2120,
833 	.hid_width = 5,
834 	.parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
835 	.clkr.hw.init = &(struct clk_init_data){
836 		.name = "byte0_clk_src",
837 		.parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
838 		.num_parents = 6,
839 		.ops = &clk_byte2_ops,
840 		.flags = CLK_SET_RATE_PARENT,
841 	},
842 };
843 
844 static struct clk_rcg2 byte1_clk_src = {
845 	.cmd_rcgr = 0x2140,
846 	.hid_width = 5,
847 	.parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
848 	.clkr.hw.init = &(struct clk_init_data){
849 		.name = "byte1_clk_src",
850 		.parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
851 		.num_parents = 6,
852 		.ops = &clk_byte2_ops,
853 		.flags = CLK_SET_RATE_PARENT,
854 	},
855 };
856 
857 static struct freq_tbl ftbl_mdss_edpaux_clk[] = {
858 	F(19200000, P_XO, 1, 0, 0),
859 	{ }
860 };
861 
862 static struct clk_rcg2 edpaux_clk_src = {
863 	.cmd_rcgr = 0x20e0,
864 	.hid_width = 5,
865 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
866 	.freq_tbl = ftbl_mdss_edpaux_clk,
867 	.clkr.hw.init = &(struct clk_init_data){
868 		.name = "edpaux_clk_src",
869 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
870 		.num_parents = 4,
871 		.ops = &clk_rcg2_ops,
872 	},
873 };
874 
875 static struct freq_tbl ftbl_mdss_edplink_clk[] = {
876 	F(135000000, P_EDPLINK, 2, 0, 0),
877 	F(270000000, P_EDPLINK, 11, 0, 0),
878 	{ }
879 };
880 
881 static struct clk_rcg2 edplink_clk_src = {
882 	.cmd_rcgr = 0x20c0,
883 	.hid_width = 5,
884 	.parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
885 	.freq_tbl = ftbl_mdss_edplink_clk,
886 	.clkr.hw.init = &(struct clk_init_data){
887 		.name = "edplink_clk_src",
888 		.parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
889 		.num_parents = 6,
890 		.ops = &clk_rcg2_ops,
891 		.flags = CLK_SET_RATE_PARENT,
892 	},
893 };
894 
895 static struct freq_tbl edp_pixel_freq_tbl[] = {
896 	{ .src = P_EDPVCO },
897 	{ }
898 };
899 
900 static struct clk_rcg2 edppixel_clk_src = {
901 	.cmd_rcgr = 0x20a0,
902 	.mnd_width = 8,
903 	.hid_width = 5,
904 	.parent_map = mmcc_xo_dsi_hdmi_edp_map,
905 	.freq_tbl = edp_pixel_freq_tbl,
906 	.clkr.hw.init = &(struct clk_init_data){
907 		.name = "edppixel_clk_src",
908 		.parent_names = mmcc_xo_dsi_hdmi_edp,
909 		.num_parents = 6,
910 		.ops = &clk_edp_pixel_ops,
911 	},
912 };
913 
914 static struct freq_tbl ftbl_mdss_esc0_1_clk[] = {
915 	F(19200000, P_XO, 1, 0, 0),
916 	{ }
917 };
918 
919 static struct clk_rcg2 esc0_clk_src = {
920 	.cmd_rcgr = 0x2160,
921 	.hid_width = 5,
922 	.parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
923 	.freq_tbl = ftbl_mdss_esc0_1_clk,
924 	.clkr.hw.init = &(struct clk_init_data){
925 		.name = "esc0_clk_src",
926 		.parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
927 		.num_parents = 6,
928 		.ops = &clk_rcg2_ops,
929 	},
930 };
931 
932 static struct clk_rcg2 esc1_clk_src = {
933 	.cmd_rcgr = 0x2180,
934 	.hid_width = 5,
935 	.parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
936 	.freq_tbl = ftbl_mdss_esc0_1_clk,
937 	.clkr.hw.init = &(struct clk_init_data){
938 		.name = "esc1_clk_src",
939 		.parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
940 		.num_parents = 6,
941 		.ops = &clk_rcg2_ops,
942 	},
943 };
944 
945 static struct freq_tbl extpclk_freq_tbl[] = {
946 	{ .src = P_HDMIPLL },
947 	{ }
948 };
949 
950 static struct clk_rcg2 extpclk_clk_src = {
951 	.cmd_rcgr = 0x2060,
952 	.hid_width = 5,
953 	.parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
954 	.freq_tbl = extpclk_freq_tbl,
955 	.clkr.hw.init = &(struct clk_init_data){
956 		.name = "extpclk_clk_src",
957 		.parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
958 		.num_parents = 6,
959 		.ops = &clk_byte_ops,
960 		.flags = CLK_SET_RATE_PARENT,
961 	},
962 };
963 
964 static struct freq_tbl ftbl_mdss_hdmi_clk[] = {
965 	F(19200000, P_XO, 1, 0, 0),
966 	{ }
967 };
968 
969 static struct clk_rcg2 hdmi_clk_src = {
970 	.cmd_rcgr = 0x2100,
971 	.hid_width = 5,
972 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
973 	.freq_tbl = ftbl_mdss_hdmi_clk,
974 	.clkr.hw.init = &(struct clk_init_data){
975 		.name = "hdmi_clk_src",
976 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
977 		.num_parents = 4,
978 		.ops = &clk_rcg2_ops,
979 	},
980 };
981 
982 static struct freq_tbl ftbl_mdss_vsync_clk[] = {
983 	F(19200000, P_XO, 1, 0, 0),
984 	{ }
985 };
986 
987 static struct clk_rcg2 vsync_clk_src = {
988 	.cmd_rcgr = 0x2080,
989 	.hid_width = 5,
990 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
991 	.freq_tbl = ftbl_mdss_vsync_clk,
992 	.clkr.hw.init = &(struct clk_init_data){
993 		.name = "vsync_clk_src",
994 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
995 		.num_parents = 4,
996 		.ops = &clk_rcg2_ops,
997 	},
998 };
999 
1000 static struct freq_tbl ftbl_mmss_rbcpr_clk[] = {
1001 	F(50000000, P_GPLL0, 12, 0, 0),
1002 	{ }
1003 };
1004 
1005 static struct clk_rcg2 rbcpr_clk_src = {
1006 	.cmd_rcgr = 0x4060,
1007 	.hid_width = 5,
1008 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
1009 	.freq_tbl = ftbl_mmss_rbcpr_clk,
1010 	.clkr.hw.init = &(struct clk_init_data){
1011 		.name = "rbcpr_clk_src",
1012 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
1013 		.num_parents = 4,
1014 		.ops = &clk_rcg2_ops,
1015 	},
1016 };
1017 
1018 static struct freq_tbl ftbl_oxili_rbbmtimer_clk[] = {
1019 	F(19200000, P_XO, 1, 0, 0),
1020 	{ }
1021 };
1022 
1023 static struct clk_rcg2 rbbmtimer_clk_src = {
1024 	.cmd_rcgr = 0x4090,
1025 	.hid_width = 5,
1026 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
1027 	.freq_tbl = ftbl_oxili_rbbmtimer_clk,
1028 	.clkr.hw.init = &(struct clk_init_data){
1029 		.name = "rbbmtimer_clk_src",
1030 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
1031 		.num_parents = 4,
1032 		.ops = &clk_rcg2_ops,
1033 	},
1034 };
1035 
1036 static struct freq_tbl ftbl_vpu_maple_clk[] = {
1037 	F(50000000, P_GPLL0, 12, 0, 0),
1038 	F(100000000, P_GPLL0, 6, 0, 0),
1039 	F(133330000, P_GPLL0, 4.5, 0, 0),
1040 	F(200000000, P_MMPLL0, 4, 0, 0),
1041 	F(266670000, P_MMPLL0, 3, 0, 0),
1042 	F(465000000, P_MMPLL3, 2, 0, 0),
1043 	{ }
1044 };
1045 
1046 static struct clk_rcg2 maple_clk_src = {
1047 	.cmd_rcgr = 0x1320,
1048 	.hid_width = 5,
1049 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
1050 	.freq_tbl = ftbl_vpu_maple_clk,
1051 	.clkr.hw.init = &(struct clk_init_data){
1052 		.name = "maple_clk_src",
1053 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
1054 		.num_parents = 4,
1055 		.ops = &clk_rcg2_ops,
1056 	},
1057 };
1058 
1059 static struct freq_tbl ftbl_vpu_vdp_clk[] = {
1060 	F(50000000, P_GPLL0, 12, 0, 0),
1061 	F(100000000, P_GPLL0, 6, 0, 0),
1062 	F(200000000, P_MMPLL0, 4, 0, 0),
1063 	F(320000000, P_MMPLL0, 2.5, 0, 0),
1064 	F(400000000, P_MMPLL0, 2, 0, 0),
1065 	{ }
1066 };
1067 
1068 static struct clk_rcg2 vdp_clk_src = {
1069 	.cmd_rcgr = 0x1300,
1070 	.hid_width = 5,
1071 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
1072 	.freq_tbl = ftbl_vpu_vdp_clk,
1073 	.clkr.hw.init = &(struct clk_init_data){
1074 		.name = "vdp_clk_src",
1075 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
1076 		.num_parents = 4,
1077 		.ops = &clk_rcg2_ops,
1078 	},
1079 };
1080 
1081 static struct freq_tbl ftbl_vpu_bus_clk[] = {
1082 	F(40000000, P_GPLL0, 15, 0, 0),
1083 	F(80000000, P_MMPLL0, 10, 0, 0),
1084 	{ }
1085 };
1086 
1087 static struct clk_rcg2 vpu_bus_clk_src = {
1088 	.cmd_rcgr = 0x1340,
1089 	.hid_width = 5,
1090 	.parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
1091 	.freq_tbl = ftbl_vpu_bus_clk,
1092 	.clkr.hw.init = &(struct clk_init_data){
1093 		.name = "vpu_bus_clk_src",
1094 		.parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
1095 		.num_parents = 4,
1096 		.ops = &clk_rcg2_ops,
1097 	},
1098 };
1099 
1100 static struct clk_branch mmss_cxo_clk = {
1101 	.halt_reg = 0x5104,
1102 	.clkr = {
1103 		.enable_reg = 0x5104,
1104 		.enable_mask = BIT(0),
1105 		.hw.init = &(struct clk_init_data){
1106 			.name = "mmss_cxo_clk",
1107 			.parent_names = (const char *[]){ "xo" },
1108 			.num_parents = 1,
1109 			.flags = CLK_SET_RATE_PARENT,
1110 			.ops = &clk_branch2_ops,
1111 		},
1112 	},
1113 };
1114 
1115 static struct clk_branch mmss_sleepclk_clk = {
1116 	.halt_reg = 0x5100,
1117 	.clkr = {
1118 		.enable_reg = 0x5100,
1119 		.enable_mask = BIT(0),
1120 		.hw.init = &(struct clk_init_data){
1121 			.name = "mmss_sleepclk_clk",
1122 			.parent_names = (const char *[]){
1123 				"sleep_clk_src",
1124 			},
1125 			.num_parents = 1,
1126 			.flags = CLK_SET_RATE_PARENT,
1127 			.ops = &clk_branch2_ops,
1128 		},
1129 	},
1130 };
1131 
1132 static struct clk_branch avsync_ahb_clk = {
1133 	.halt_reg = 0x2414,
1134 	.clkr = {
1135 		.enable_reg = 0x2414,
1136 		.enable_mask = BIT(0),
1137 		.hw.init = &(struct clk_init_data){
1138 			.name = "avsync_ahb_clk",
1139 			.parent_names = (const char *[]){
1140 				"mmss_ahb_clk_src",
1141 			},
1142 			.num_parents = 1,
1143 			.flags = CLK_SET_RATE_PARENT,
1144 			.ops = &clk_branch2_ops,
1145 		},
1146 	},
1147 };
1148 
1149 static struct clk_branch avsync_edppixel_clk = {
1150 	.halt_reg = 0x2418,
1151 	.clkr = {
1152 		.enable_reg = 0x2418,
1153 		.enable_mask = BIT(0),
1154 		.hw.init = &(struct clk_init_data){
1155 			.name = "avsync_edppixel_clk",
1156 			.parent_names = (const char *[]){
1157 				"edppixel_clk_src",
1158 			},
1159 			.num_parents = 1,
1160 			.flags = CLK_SET_RATE_PARENT,
1161 			.ops = &clk_branch2_ops,
1162 		},
1163 	},
1164 };
1165 
1166 static struct clk_branch avsync_extpclk_clk = {
1167 	.halt_reg = 0x2410,
1168 	.clkr = {
1169 		.enable_reg = 0x2410,
1170 		.enable_mask = BIT(0),
1171 		.hw.init = &(struct clk_init_data){
1172 			.name = "avsync_extpclk_clk",
1173 			.parent_names = (const char *[]){
1174 				"extpclk_clk_src",
1175 			},
1176 			.num_parents = 1,
1177 			.flags = CLK_SET_RATE_PARENT,
1178 			.ops = &clk_branch2_ops,
1179 		},
1180 	},
1181 };
1182 
1183 static struct clk_branch avsync_pclk0_clk = {
1184 	.halt_reg = 0x241c,
1185 	.clkr = {
1186 		.enable_reg = 0x241c,
1187 		.enable_mask = BIT(0),
1188 		.hw.init = &(struct clk_init_data){
1189 			.name = "avsync_pclk0_clk",
1190 			.parent_names = (const char *[]){
1191 				"pclk0_clk_src",
1192 			},
1193 			.num_parents = 1,
1194 			.flags = CLK_SET_RATE_PARENT,
1195 			.ops = &clk_branch2_ops,
1196 		},
1197 	},
1198 };
1199 
1200 static struct clk_branch avsync_pclk1_clk = {
1201 	.halt_reg = 0x2420,
1202 	.clkr = {
1203 		.enable_reg = 0x2420,
1204 		.enable_mask = BIT(0),
1205 		.hw.init = &(struct clk_init_data){
1206 			.name = "avsync_pclk1_clk",
1207 			.parent_names = (const char *[]){
1208 				"pclk1_clk_src",
1209 			},
1210 			.num_parents = 1,
1211 			.flags = CLK_SET_RATE_PARENT,
1212 			.ops = &clk_branch2_ops,
1213 		},
1214 	},
1215 };
1216 
1217 static struct clk_branch avsync_vp_clk = {
1218 	.halt_reg = 0x2404,
1219 	.clkr = {
1220 		.enable_reg = 0x2404,
1221 		.enable_mask = BIT(0),
1222 		.hw.init = &(struct clk_init_data){
1223 			.name = "avsync_vp_clk",
1224 			.parent_names = (const char *[]){
1225 				"vp_clk_src",
1226 			},
1227 			.num_parents = 1,
1228 			.flags = CLK_SET_RATE_PARENT,
1229 			.ops = &clk_branch2_ops,
1230 		},
1231 	},
1232 };
1233 
1234 static struct clk_branch camss_ahb_clk = {
1235 	.halt_reg = 0x348c,
1236 	.clkr = {
1237 		.enable_reg = 0x348c,
1238 		.enable_mask = BIT(0),
1239 		.hw.init = &(struct clk_init_data){
1240 			.name = "camss_ahb_clk",
1241 			.parent_names = (const char *[]){
1242 				"mmss_ahb_clk_src",
1243 			},
1244 			.num_parents = 1,
1245 			.flags = CLK_SET_RATE_PARENT,
1246 			.ops = &clk_branch2_ops,
1247 		},
1248 	},
1249 };
1250 
1251 static struct clk_branch camss_cci_cci_ahb_clk = {
1252 	.halt_reg = 0x3348,
1253 	.clkr = {
1254 		.enable_reg = 0x3348,
1255 		.enable_mask = BIT(0),
1256 		.hw.init = &(struct clk_init_data){
1257 			.name = "camss_cci_cci_ahb_clk",
1258 			.parent_names = (const char *[]){
1259 				"mmss_ahb_clk_src",
1260 			},
1261 			.num_parents = 1,
1262 			.ops = &clk_branch2_ops,
1263 		},
1264 	},
1265 };
1266 
1267 static struct clk_branch camss_cci_cci_clk = {
1268 	.halt_reg = 0x3344,
1269 	.clkr = {
1270 		.enable_reg = 0x3344,
1271 		.enable_mask = BIT(0),
1272 		.hw.init = &(struct clk_init_data){
1273 			.name = "camss_cci_cci_clk",
1274 			.parent_names = (const char *[]){
1275 				"cci_clk_src",
1276 			},
1277 			.num_parents = 1,
1278 			.flags = CLK_SET_RATE_PARENT,
1279 			.ops = &clk_branch2_ops,
1280 		},
1281 	},
1282 };
1283 
1284 static struct clk_branch camss_csi0_ahb_clk = {
1285 	.halt_reg = 0x30bc,
1286 	.clkr = {
1287 		.enable_reg = 0x30bc,
1288 		.enable_mask = BIT(0),
1289 		.hw.init = &(struct clk_init_data){
1290 			.name = "camss_csi0_ahb_clk",
1291 			.parent_names = (const char *[]){
1292 				"mmss_ahb_clk_src",
1293 			},
1294 			.num_parents = 1,
1295 			.ops = &clk_branch2_ops,
1296 		},
1297 	},
1298 };
1299 
1300 static struct clk_branch camss_csi0_clk = {
1301 	.halt_reg = 0x30b4,
1302 	.clkr = {
1303 		.enable_reg = 0x30b4,
1304 		.enable_mask = BIT(0),
1305 		.hw.init = &(struct clk_init_data){
1306 			.name = "camss_csi0_clk",
1307 			.parent_names = (const char *[]){
1308 				"csi0_clk_src",
1309 			},
1310 			.num_parents = 1,
1311 			.flags = CLK_SET_RATE_PARENT,
1312 			.ops = &clk_branch2_ops,
1313 		},
1314 	},
1315 };
1316 
1317 static struct clk_branch camss_csi0phy_clk = {
1318 	.halt_reg = 0x30c4,
1319 	.clkr = {
1320 		.enable_reg = 0x30c4,
1321 		.enable_mask = BIT(0),
1322 		.hw.init = &(struct clk_init_data){
1323 			.name = "camss_csi0phy_clk",
1324 			.parent_names = (const char *[]){
1325 				"csi0_clk_src",
1326 			},
1327 			.num_parents = 1,
1328 			.flags = CLK_SET_RATE_PARENT,
1329 			.ops = &clk_branch2_ops,
1330 		},
1331 	},
1332 };
1333 
1334 static struct clk_branch camss_csi0pix_clk = {
1335 	.halt_reg = 0x30e4,
1336 	.clkr = {
1337 		.enable_reg = 0x30e4,
1338 		.enable_mask = BIT(0),
1339 		.hw.init = &(struct clk_init_data){
1340 			.name = "camss_csi0pix_clk",
1341 			.parent_names = (const char *[]){
1342 				"csi0_clk_src",
1343 			},
1344 			.num_parents = 1,
1345 			.flags = CLK_SET_RATE_PARENT,
1346 			.ops = &clk_branch2_ops,
1347 		},
1348 	},
1349 };
1350 
1351 static struct clk_branch camss_csi0rdi_clk = {
1352 	.halt_reg = 0x30d4,
1353 	.clkr = {
1354 		.enable_reg = 0x30d4,
1355 		.enable_mask = BIT(0),
1356 		.hw.init = &(struct clk_init_data){
1357 			.name = "camss_csi0rdi_clk",
1358 			.parent_names = (const char *[]){
1359 				"csi0_clk_src",
1360 			},
1361 			.num_parents = 1,
1362 			.flags = CLK_SET_RATE_PARENT,
1363 			.ops = &clk_branch2_ops,
1364 		},
1365 	},
1366 };
1367 
1368 static struct clk_branch camss_csi1_ahb_clk = {
1369 	.halt_reg = 0x3128,
1370 	.clkr = {
1371 		.enable_reg = 0x3128,
1372 		.enable_mask = BIT(0),
1373 		.hw.init = &(struct clk_init_data){
1374 			.name = "camss_csi1_ahb_clk",
1375 			.parent_names = (const char *[]){
1376 				"mmss_ahb_clk_src",
1377 			},
1378 			.num_parents = 1,
1379 			.flags = CLK_SET_RATE_PARENT,
1380 			.ops = &clk_branch2_ops,
1381 		},
1382 	},
1383 };
1384 
1385 static struct clk_branch camss_csi1_clk = {
1386 	.halt_reg = 0x3124,
1387 	.clkr = {
1388 		.enable_reg = 0x3124,
1389 		.enable_mask = BIT(0),
1390 		.hw.init = &(struct clk_init_data){
1391 			.name = "camss_csi1_clk",
1392 			.parent_names = (const char *[]){
1393 				"csi1_clk_src",
1394 			},
1395 			.num_parents = 1,
1396 			.flags = CLK_SET_RATE_PARENT,
1397 			.ops = &clk_branch2_ops,
1398 		},
1399 	},
1400 };
1401 
1402 static struct clk_branch camss_csi1phy_clk = {
1403 	.halt_reg = 0x3134,
1404 	.clkr = {
1405 		.enable_reg = 0x3134,
1406 		.enable_mask = BIT(0),
1407 		.hw.init = &(struct clk_init_data){
1408 			.name = "camss_csi1phy_clk",
1409 			.parent_names = (const char *[]){
1410 				"csi1_clk_src",
1411 			},
1412 			.num_parents = 1,
1413 			.flags = CLK_SET_RATE_PARENT,
1414 			.ops = &clk_branch2_ops,
1415 		},
1416 	},
1417 };
1418 
1419 static struct clk_branch camss_csi1pix_clk = {
1420 	.halt_reg = 0x3154,
1421 	.clkr = {
1422 		.enable_reg = 0x3154,
1423 		.enable_mask = BIT(0),
1424 		.hw.init = &(struct clk_init_data){
1425 			.name = "camss_csi1pix_clk",
1426 			.parent_names = (const char *[]){
1427 				"csi1_clk_src",
1428 			},
1429 			.num_parents = 1,
1430 			.flags = CLK_SET_RATE_PARENT,
1431 			.ops = &clk_branch2_ops,
1432 		},
1433 	},
1434 };
1435 
1436 static struct clk_branch camss_csi1rdi_clk = {
1437 	.halt_reg = 0x3144,
1438 	.clkr = {
1439 		.enable_reg = 0x3144,
1440 		.enable_mask = BIT(0),
1441 		.hw.init = &(struct clk_init_data){
1442 			.name = "camss_csi1rdi_clk",
1443 			.parent_names = (const char *[]){
1444 				"csi1_clk_src",
1445 			},
1446 			.num_parents = 1,
1447 			.flags = CLK_SET_RATE_PARENT,
1448 			.ops = &clk_branch2_ops,
1449 		},
1450 	},
1451 };
1452 
1453 static struct clk_branch camss_csi2_ahb_clk = {
1454 	.halt_reg = 0x3188,
1455 	.clkr = {
1456 		.enable_reg = 0x3188,
1457 		.enable_mask = BIT(0),
1458 		.hw.init = &(struct clk_init_data){
1459 			.name = "camss_csi2_ahb_clk",
1460 			.parent_names = (const char *[]){
1461 				"mmss_ahb_clk_src",
1462 			},
1463 			.num_parents = 1,
1464 			.ops = &clk_branch2_ops,
1465 		},
1466 	},
1467 };
1468 
1469 static struct clk_branch camss_csi2_clk = {
1470 	.halt_reg = 0x3184,
1471 	.clkr = {
1472 		.enable_reg = 0x3184,
1473 		.enable_mask = BIT(0),
1474 		.hw.init = &(struct clk_init_data){
1475 			.name = "camss_csi2_clk",
1476 			.parent_names = (const char *[]){
1477 				"csi2_clk_src",
1478 			},
1479 			.num_parents = 1,
1480 			.flags = CLK_SET_RATE_PARENT,
1481 			.ops = &clk_branch2_ops,
1482 		},
1483 	},
1484 };
1485 
1486 static struct clk_branch camss_csi2phy_clk = {
1487 	.halt_reg = 0x3194,
1488 	.clkr = {
1489 		.enable_reg = 0x3194,
1490 		.enable_mask = BIT(0),
1491 		.hw.init = &(struct clk_init_data){
1492 			.name = "camss_csi2phy_clk",
1493 			.parent_names = (const char *[]){
1494 				"csi2_clk_src",
1495 			},
1496 			.num_parents = 1,
1497 			.flags = CLK_SET_RATE_PARENT,
1498 			.ops = &clk_branch2_ops,
1499 		},
1500 	},
1501 };
1502 
1503 static struct clk_branch camss_csi2pix_clk = {
1504 	.halt_reg = 0x31b4,
1505 	.clkr = {
1506 		.enable_reg = 0x31b4,
1507 		.enable_mask = BIT(0),
1508 		.hw.init = &(struct clk_init_data){
1509 			.name = "camss_csi2pix_clk",
1510 			.parent_names = (const char *[]){
1511 				"csi2_clk_src",
1512 			},
1513 			.num_parents = 1,
1514 			.flags = CLK_SET_RATE_PARENT,
1515 			.ops = &clk_branch2_ops,
1516 		},
1517 	},
1518 };
1519 
1520 static struct clk_branch camss_csi2rdi_clk = {
1521 	.halt_reg = 0x31a4,
1522 	.clkr = {
1523 		.enable_reg = 0x31a4,
1524 		.enable_mask = BIT(0),
1525 		.hw.init = &(struct clk_init_data){
1526 			.name = "camss_csi2rdi_clk",
1527 			.parent_names = (const char *[]){
1528 				"csi2_clk_src",
1529 			},
1530 			.num_parents = 1,
1531 			.flags = CLK_SET_RATE_PARENT,
1532 			.ops = &clk_branch2_ops,
1533 		},
1534 	},
1535 };
1536 
1537 static struct clk_branch camss_csi3_ahb_clk = {
1538 	.halt_reg = 0x31e8,
1539 	.clkr = {
1540 		.enable_reg = 0x31e8,
1541 		.enable_mask = BIT(0),
1542 		.hw.init = &(struct clk_init_data){
1543 			.name = "camss_csi3_ahb_clk",
1544 			.parent_names = (const char *[]){
1545 				"mmss_ahb_clk_src",
1546 			},
1547 			.num_parents = 1,
1548 			.ops = &clk_branch2_ops,
1549 		},
1550 	},
1551 };
1552 
1553 static struct clk_branch camss_csi3_clk = {
1554 	.halt_reg = 0x31e4,
1555 	.clkr = {
1556 		.enable_reg = 0x31e4,
1557 		.enable_mask = BIT(0),
1558 		.hw.init = &(struct clk_init_data){
1559 			.name = "camss_csi3_clk",
1560 			.parent_names = (const char *[]){
1561 				"csi3_clk_src",
1562 			},
1563 			.num_parents = 1,
1564 			.flags = CLK_SET_RATE_PARENT,
1565 			.ops = &clk_branch2_ops,
1566 		},
1567 	},
1568 };
1569 
1570 static struct clk_branch camss_csi3phy_clk = {
1571 	.halt_reg = 0x31f4,
1572 	.clkr = {
1573 		.enable_reg = 0x31f4,
1574 		.enable_mask = BIT(0),
1575 		.hw.init = &(struct clk_init_data){
1576 			.name = "camss_csi3phy_clk",
1577 			.parent_names = (const char *[]){
1578 				"csi3_clk_src",
1579 			},
1580 			.num_parents = 1,
1581 			.flags = CLK_SET_RATE_PARENT,
1582 			.ops = &clk_branch2_ops,
1583 		},
1584 	},
1585 };
1586 
1587 static struct clk_branch camss_csi3pix_clk = {
1588 	.halt_reg = 0x3214,
1589 	.clkr = {
1590 		.enable_reg = 0x3214,
1591 		.enable_mask = BIT(0),
1592 		.hw.init = &(struct clk_init_data){
1593 			.name = "camss_csi3pix_clk",
1594 			.parent_names = (const char *[]){
1595 				"csi3_clk_src",
1596 			},
1597 			.num_parents = 1,
1598 			.flags = CLK_SET_RATE_PARENT,
1599 			.ops = &clk_branch2_ops,
1600 		},
1601 	},
1602 };
1603 
1604 static struct clk_branch camss_csi3rdi_clk = {
1605 	.halt_reg = 0x3204,
1606 	.clkr = {
1607 		.enable_reg = 0x3204,
1608 		.enable_mask = BIT(0),
1609 		.hw.init = &(struct clk_init_data){
1610 			.name = "camss_csi3rdi_clk",
1611 			.parent_names = (const char *[]){
1612 				"csi3_clk_src",
1613 			},
1614 			.num_parents = 1,
1615 			.flags = CLK_SET_RATE_PARENT,
1616 			.ops = &clk_branch2_ops,
1617 		},
1618 	},
1619 };
1620 
1621 static struct clk_branch camss_csi_vfe0_clk = {
1622 	.halt_reg = 0x3704,
1623 	.clkr = {
1624 		.enable_reg = 0x3704,
1625 		.enable_mask = BIT(0),
1626 		.hw.init = &(struct clk_init_data){
1627 			.name = "camss_csi_vfe0_clk",
1628 			.parent_names = (const char *[]){
1629 				"vfe0_clk_src",
1630 			},
1631 			.num_parents = 1,
1632 			.flags = CLK_SET_RATE_PARENT,
1633 			.ops = &clk_branch2_ops,
1634 		},
1635 	},
1636 };
1637 
1638 static struct clk_branch camss_csi_vfe1_clk = {
1639 	.halt_reg = 0x3714,
1640 	.clkr = {
1641 		.enable_reg = 0x3714,
1642 		.enable_mask = BIT(0),
1643 		.hw.init = &(struct clk_init_data){
1644 			.name = "camss_csi_vfe1_clk",
1645 			.parent_names = (const char *[]){
1646 				"vfe1_clk_src",
1647 			},
1648 			.num_parents = 1,
1649 			.flags = CLK_SET_RATE_PARENT,
1650 			.ops = &clk_branch2_ops,
1651 		},
1652 	},
1653 };
1654 
1655 static struct clk_branch camss_gp0_clk = {
1656 	.halt_reg = 0x3444,
1657 	.clkr = {
1658 		.enable_reg = 0x3444,
1659 		.enable_mask = BIT(0),
1660 		.hw.init = &(struct clk_init_data){
1661 			.name = "camss_gp0_clk",
1662 			.parent_names = (const char *[]){
1663 				"camss_gp0_clk_src",
1664 			},
1665 			.num_parents = 1,
1666 			.flags = CLK_SET_RATE_PARENT,
1667 			.ops = &clk_branch2_ops,
1668 		},
1669 	},
1670 };
1671 
1672 static struct clk_branch camss_gp1_clk = {
1673 	.halt_reg = 0x3474,
1674 	.clkr = {
1675 		.enable_reg = 0x3474,
1676 		.enable_mask = BIT(0),
1677 		.hw.init = &(struct clk_init_data){
1678 			.name = "camss_gp1_clk",
1679 			.parent_names = (const char *[]){
1680 				"camss_gp1_clk_src",
1681 			},
1682 			.num_parents = 1,
1683 			.flags = CLK_SET_RATE_PARENT,
1684 			.ops = &clk_branch2_ops,
1685 		},
1686 	},
1687 };
1688 
1689 static struct clk_branch camss_ispif_ahb_clk = {
1690 	.halt_reg = 0x3224,
1691 	.clkr = {
1692 		.enable_reg = 0x3224,
1693 		.enable_mask = BIT(0),
1694 		.hw.init = &(struct clk_init_data){
1695 			.name = "camss_ispif_ahb_clk",
1696 			.parent_names = (const char *[]){
1697 				"mmss_ahb_clk_src",
1698 			},
1699 			.num_parents = 1,
1700 			.flags = CLK_SET_RATE_PARENT,
1701 			.ops = &clk_branch2_ops,
1702 		},
1703 	},
1704 };
1705 
1706 static struct clk_branch camss_jpeg_jpeg0_clk = {
1707 	.halt_reg = 0x35a8,
1708 	.clkr = {
1709 		.enable_reg = 0x35a8,
1710 		.enable_mask = BIT(0),
1711 		.hw.init = &(struct clk_init_data){
1712 			.name = "camss_jpeg_jpeg0_clk",
1713 			.parent_names = (const char *[]){
1714 				"jpeg0_clk_src",
1715 			},
1716 			.num_parents = 1,
1717 			.flags = CLK_SET_RATE_PARENT,
1718 			.ops = &clk_branch2_ops,
1719 		},
1720 	},
1721 };
1722 
1723 static struct clk_branch camss_jpeg_jpeg1_clk = {
1724 	.halt_reg = 0x35ac,
1725 	.clkr = {
1726 		.enable_reg = 0x35ac,
1727 		.enable_mask = BIT(0),
1728 		.hw.init = &(struct clk_init_data){
1729 			.name = "camss_jpeg_jpeg1_clk",
1730 			.parent_names = (const char *[]){
1731 				"jpeg1_clk_src",
1732 			},
1733 			.num_parents = 1,
1734 			.flags = CLK_SET_RATE_PARENT,
1735 			.ops = &clk_branch2_ops,
1736 		},
1737 	},
1738 };
1739 
1740 static struct clk_branch camss_jpeg_jpeg2_clk = {
1741 	.halt_reg = 0x35b0,
1742 	.clkr = {
1743 		.enable_reg = 0x35b0,
1744 		.enable_mask = BIT(0),
1745 		.hw.init = &(struct clk_init_data){
1746 			.name = "camss_jpeg_jpeg2_clk",
1747 			.parent_names = (const char *[]){
1748 				"jpeg2_clk_src",
1749 			},
1750 			.num_parents = 1,
1751 			.flags = CLK_SET_RATE_PARENT,
1752 			.ops = &clk_branch2_ops,
1753 		},
1754 	},
1755 };
1756 
1757 static struct clk_branch camss_jpeg_jpeg_ahb_clk = {
1758 	.halt_reg = 0x35b4,
1759 	.clkr = {
1760 		.enable_reg = 0x35b4,
1761 		.enable_mask = BIT(0),
1762 		.hw.init = &(struct clk_init_data){
1763 			.name = "camss_jpeg_jpeg_ahb_clk",
1764 			.parent_names = (const char *[]){
1765 				"mmss_ahb_clk_src",
1766 			},
1767 			.num_parents = 1,
1768 			.ops = &clk_branch2_ops,
1769 		},
1770 	},
1771 };
1772 
1773 static struct clk_branch camss_jpeg_jpeg_axi_clk = {
1774 	.halt_reg = 0x35b8,
1775 	.clkr = {
1776 		.enable_reg = 0x35b8,
1777 		.enable_mask = BIT(0),
1778 		.hw.init = &(struct clk_init_data){
1779 			.name = "camss_jpeg_jpeg_axi_clk",
1780 			.parent_names = (const char *[]){
1781 				"mmss_axi_clk_src",
1782 			},
1783 			.num_parents = 1,
1784 			.ops = &clk_branch2_ops,
1785 		},
1786 	},
1787 };
1788 
1789 static struct clk_branch camss_mclk0_clk = {
1790 	.halt_reg = 0x3384,
1791 	.clkr = {
1792 		.enable_reg = 0x3384,
1793 		.enable_mask = BIT(0),
1794 		.hw.init = &(struct clk_init_data){
1795 			.name = "camss_mclk0_clk",
1796 			.parent_names = (const char *[]){
1797 				"mclk0_clk_src",
1798 			},
1799 			.num_parents = 1,
1800 			.flags = CLK_SET_RATE_PARENT,
1801 			.ops = &clk_branch2_ops,
1802 		},
1803 	},
1804 };
1805 
1806 static struct clk_branch camss_mclk1_clk = {
1807 	.halt_reg = 0x33b4,
1808 	.clkr = {
1809 		.enable_reg = 0x33b4,
1810 		.enable_mask = BIT(0),
1811 		.hw.init = &(struct clk_init_data){
1812 			.name = "camss_mclk1_clk",
1813 			.parent_names = (const char *[]){
1814 				"mclk1_clk_src",
1815 			},
1816 			.num_parents = 1,
1817 			.flags = CLK_SET_RATE_PARENT,
1818 			.ops = &clk_branch2_ops,
1819 		},
1820 	},
1821 };
1822 
1823 static struct clk_branch camss_mclk2_clk = {
1824 	.halt_reg = 0x33e4,
1825 	.clkr = {
1826 		.enable_reg = 0x33e4,
1827 		.enable_mask = BIT(0),
1828 		.hw.init = &(struct clk_init_data){
1829 			.name = "camss_mclk2_clk",
1830 			.parent_names = (const char *[]){
1831 				"mclk2_clk_src",
1832 			},
1833 			.num_parents = 1,
1834 			.flags = CLK_SET_RATE_PARENT,
1835 			.ops = &clk_branch2_ops,
1836 		},
1837 	},
1838 };
1839 
1840 static struct clk_branch camss_mclk3_clk = {
1841 	.halt_reg = 0x3414,
1842 	.clkr = {
1843 		.enable_reg = 0x3414,
1844 		.enable_mask = BIT(0),
1845 		.hw.init = &(struct clk_init_data){
1846 			.name = "camss_mclk3_clk",
1847 			.parent_names = (const char *[]){
1848 				"mclk3_clk_src",
1849 			},
1850 			.num_parents = 1,
1851 			.flags = CLK_SET_RATE_PARENT,
1852 			.ops = &clk_branch2_ops,
1853 		},
1854 	},
1855 };
1856 
1857 static struct clk_branch camss_micro_ahb_clk = {
1858 	.halt_reg = 0x3494,
1859 	.clkr = {
1860 		.enable_reg = 0x3494,
1861 		.enable_mask = BIT(0),
1862 		.hw.init = &(struct clk_init_data){
1863 			.name = "camss_micro_ahb_clk",
1864 			.parent_names = (const char *[]){
1865 				"mmss_ahb_clk_src",
1866 			},
1867 			.num_parents = 1,
1868 			.ops = &clk_branch2_ops,
1869 		},
1870 	},
1871 };
1872 
1873 static struct clk_branch camss_phy0_csi0phytimer_clk = {
1874 	.halt_reg = 0x3024,
1875 	.clkr = {
1876 		.enable_reg = 0x3024,
1877 		.enable_mask = BIT(0),
1878 		.hw.init = &(struct clk_init_data){
1879 			.name = "camss_phy0_csi0phytimer_clk",
1880 			.parent_names = (const char *[]){
1881 				"csi0phytimer_clk_src",
1882 			},
1883 			.num_parents = 1,
1884 			.flags = CLK_SET_RATE_PARENT,
1885 			.ops = &clk_branch2_ops,
1886 		},
1887 	},
1888 };
1889 
1890 static struct clk_branch camss_phy1_csi1phytimer_clk = {
1891 	.halt_reg = 0x3054,
1892 	.clkr = {
1893 		.enable_reg = 0x3054,
1894 		.enable_mask = BIT(0),
1895 		.hw.init = &(struct clk_init_data){
1896 			.name = "camss_phy1_csi1phytimer_clk",
1897 			.parent_names = (const char *[]){
1898 				"csi1phytimer_clk_src",
1899 			},
1900 			.num_parents = 1,
1901 			.flags = CLK_SET_RATE_PARENT,
1902 			.ops = &clk_branch2_ops,
1903 		},
1904 	},
1905 };
1906 
1907 static struct clk_branch camss_phy2_csi2phytimer_clk = {
1908 	.halt_reg = 0x3084,
1909 	.clkr = {
1910 		.enable_reg = 0x3084,
1911 		.enable_mask = BIT(0),
1912 		.hw.init = &(struct clk_init_data){
1913 			.name = "camss_phy2_csi2phytimer_clk",
1914 			.parent_names = (const char *[]){
1915 				"csi2phytimer_clk_src",
1916 			},
1917 			.num_parents = 1,
1918 			.flags = CLK_SET_RATE_PARENT,
1919 			.ops = &clk_branch2_ops,
1920 		},
1921 	},
1922 };
1923 
1924 static struct clk_branch camss_top_ahb_clk = {
1925 	.halt_reg = 0x3484,
1926 	.clkr = {
1927 		.enable_reg = 0x3484,
1928 		.enable_mask = BIT(0),
1929 		.hw.init = &(struct clk_init_data){
1930 			.name = "camss_top_ahb_clk",
1931 			.parent_names = (const char *[]){
1932 				"mmss_ahb_clk_src",
1933 			},
1934 			.num_parents = 1,
1935 			.flags = CLK_SET_RATE_PARENT,
1936 			.ops = &clk_branch2_ops,
1937 		},
1938 	},
1939 };
1940 
1941 static struct clk_branch camss_vfe_cpp_ahb_clk = {
1942 	.halt_reg = 0x36b4,
1943 	.clkr = {
1944 		.enable_reg = 0x36b4,
1945 		.enable_mask = BIT(0),
1946 		.hw.init = &(struct clk_init_data){
1947 			.name = "camss_vfe_cpp_ahb_clk",
1948 			.parent_names = (const char *[]){
1949 				"mmss_ahb_clk_src",
1950 			},
1951 			.num_parents = 1,
1952 			.flags = CLK_SET_RATE_PARENT,
1953 			.ops = &clk_branch2_ops,
1954 		},
1955 	},
1956 };
1957 
1958 static struct clk_branch camss_vfe_cpp_clk = {
1959 	.halt_reg = 0x36b0,
1960 	.clkr = {
1961 		.enable_reg = 0x36b0,
1962 		.enable_mask = BIT(0),
1963 		.hw.init = &(struct clk_init_data){
1964 			.name = "camss_vfe_cpp_clk",
1965 			.parent_names = (const char *[]){
1966 				"cpp_clk_src",
1967 			},
1968 			.num_parents = 1,
1969 			.flags = CLK_SET_RATE_PARENT,
1970 			.ops = &clk_branch2_ops,
1971 		},
1972 	},
1973 };
1974 
1975 static struct clk_branch camss_vfe_vfe0_clk = {
1976 	.halt_reg = 0x36a8,
1977 	.clkr = {
1978 		.enable_reg = 0x36a8,
1979 		.enable_mask = BIT(0),
1980 		.hw.init = &(struct clk_init_data){
1981 			.name = "camss_vfe_vfe0_clk",
1982 			.parent_names = (const char *[]){
1983 				"vfe0_clk_src",
1984 			},
1985 			.num_parents = 1,
1986 			.flags = CLK_SET_RATE_PARENT,
1987 			.ops = &clk_branch2_ops,
1988 		},
1989 	},
1990 };
1991 
1992 static struct clk_branch camss_vfe_vfe1_clk = {
1993 	.halt_reg = 0x36ac,
1994 	.clkr = {
1995 		.enable_reg = 0x36ac,
1996 		.enable_mask = BIT(0),
1997 		.hw.init = &(struct clk_init_data){
1998 			.name = "camss_vfe_vfe1_clk",
1999 			.parent_names = (const char *[]){
2000 				"vfe1_clk_src",
2001 			},
2002 			.num_parents = 1,
2003 			.flags = CLK_SET_RATE_PARENT,
2004 			.ops = &clk_branch2_ops,
2005 		},
2006 	},
2007 };
2008 
2009 static struct clk_branch camss_vfe_vfe_ahb_clk = {
2010 	.halt_reg = 0x36b8,
2011 	.clkr = {
2012 		.enable_reg = 0x36b8,
2013 		.enable_mask = BIT(0),
2014 		.hw.init = &(struct clk_init_data){
2015 			.name = "camss_vfe_vfe_ahb_clk",
2016 			.parent_names = (const char *[]){
2017 				"mmss_ahb_clk_src",
2018 			},
2019 			.num_parents = 1,
2020 			.flags = CLK_SET_RATE_PARENT,
2021 			.ops = &clk_branch2_ops,
2022 		},
2023 	},
2024 };
2025 
2026 static struct clk_branch camss_vfe_vfe_axi_clk = {
2027 	.halt_reg = 0x36bc,
2028 	.clkr = {
2029 		.enable_reg = 0x36bc,
2030 		.enable_mask = BIT(0),
2031 		.hw.init = &(struct clk_init_data){
2032 			.name = "camss_vfe_vfe_axi_clk",
2033 			.parent_names = (const char *[]){
2034 				"mmss_axi_clk_src",
2035 			},
2036 			.num_parents = 1,
2037 			.flags = CLK_SET_RATE_PARENT,
2038 			.ops = &clk_branch2_ops,
2039 		},
2040 	},
2041 };
2042 
2043 static struct clk_branch mdss_ahb_clk = {
2044 	.halt_reg = 0x2308,
2045 	.clkr = {
2046 		.enable_reg = 0x2308,
2047 		.enable_mask = BIT(0),
2048 		.hw.init = &(struct clk_init_data){
2049 			.name = "mdss_ahb_clk",
2050 			.parent_names = (const char *[]){
2051 				"mmss_ahb_clk_src",
2052 			},
2053 			.num_parents = 1,
2054 			.flags = CLK_SET_RATE_PARENT,
2055 			.ops = &clk_branch2_ops,
2056 		},
2057 	},
2058 };
2059 
2060 static struct clk_branch mdss_axi_clk = {
2061 	.halt_reg = 0x2310,
2062 	.clkr = {
2063 		.enable_reg = 0x2310,
2064 		.enable_mask = BIT(0),
2065 		.hw.init = &(struct clk_init_data){
2066 			.name = "mdss_axi_clk",
2067 			.parent_names = (const char *[]){
2068 				"mmss_axi_clk_src",
2069 			},
2070 			.num_parents = 1,
2071 			.flags = CLK_SET_RATE_PARENT,
2072 			.ops = &clk_branch2_ops,
2073 		},
2074 	},
2075 };
2076 
2077 static struct clk_branch mdss_byte0_clk = {
2078 	.halt_reg = 0x233c,
2079 	.clkr = {
2080 		.enable_reg = 0x233c,
2081 		.enable_mask = BIT(0),
2082 		.hw.init = &(struct clk_init_data){
2083 			.name = "mdss_byte0_clk",
2084 			.parent_names = (const char *[]){
2085 				"byte0_clk_src",
2086 			},
2087 			.num_parents = 1,
2088 			.flags = CLK_SET_RATE_PARENT,
2089 			.ops = &clk_branch2_ops,
2090 		},
2091 	},
2092 };
2093 
2094 static struct clk_branch mdss_byte1_clk = {
2095 	.halt_reg = 0x2340,
2096 	.clkr = {
2097 		.enable_reg = 0x2340,
2098 		.enable_mask = BIT(0),
2099 		.hw.init = &(struct clk_init_data){
2100 			.name = "mdss_byte1_clk",
2101 			.parent_names = (const char *[]){
2102 				"byte1_clk_src",
2103 			},
2104 			.num_parents = 1,
2105 			.flags = CLK_SET_RATE_PARENT,
2106 			.ops = &clk_branch2_ops,
2107 		},
2108 	},
2109 };
2110 
2111 static struct clk_branch mdss_edpaux_clk = {
2112 	.halt_reg = 0x2334,
2113 	.clkr = {
2114 		.enable_reg = 0x2334,
2115 		.enable_mask = BIT(0),
2116 		.hw.init = &(struct clk_init_data){
2117 			.name = "mdss_edpaux_clk",
2118 			.parent_names = (const char *[]){
2119 				"edpaux_clk_src",
2120 			},
2121 			.num_parents = 1,
2122 			.flags = CLK_SET_RATE_PARENT,
2123 			.ops = &clk_branch2_ops,
2124 		},
2125 	},
2126 };
2127 
2128 static struct clk_branch mdss_edplink_clk = {
2129 	.halt_reg = 0x2330,
2130 	.clkr = {
2131 		.enable_reg = 0x2330,
2132 		.enable_mask = BIT(0),
2133 		.hw.init = &(struct clk_init_data){
2134 			.name = "mdss_edplink_clk",
2135 			.parent_names = (const char *[]){
2136 				"edplink_clk_src",
2137 			},
2138 			.num_parents = 1,
2139 			.flags = CLK_SET_RATE_PARENT,
2140 			.ops = &clk_branch2_ops,
2141 		},
2142 	},
2143 };
2144 
2145 static struct clk_branch mdss_edppixel_clk = {
2146 	.halt_reg = 0x232c,
2147 	.clkr = {
2148 		.enable_reg = 0x232c,
2149 		.enable_mask = BIT(0),
2150 		.hw.init = &(struct clk_init_data){
2151 			.name = "mdss_edppixel_clk",
2152 			.parent_names = (const char *[]){
2153 				"edppixel_clk_src",
2154 			},
2155 			.num_parents = 1,
2156 			.flags = CLK_SET_RATE_PARENT,
2157 			.ops = &clk_branch2_ops,
2158 		},
2159 	},
2160 };
2161 
2162 static struct clk_branch mdss_esc0_clk = {
2163 	.halt_reg = 0x2344,
2164 	.clkr = {
2165 		.enable_reg = 0x2344,
2166 		.enable_mask = BIT(0),
2167 		.hw.init = &(struct clk_init_data){
2168 			.name = "mdss_esc0_clk",
2169 			.parent_names = (const char *[]){
2170 				"esc0_clk_src",
2171 			},
2172 			.num_parents = 1,
2173 			.flags = CLK_SET_RATE_PARENT,
2174 			.ops = &clk_branch2_ops,
2175 		},
2176 	},
2177 };
2178 
2179 static struct clk_branch mdss_esc1_clk = {
2180 	.halt_reg = 0x2348,
2181 	.clkr = {
2182 		.enable_reg = 0x2348,
2183 		.enable_mask = BIT(0),
2184 		.hw.init = &(struct clk_init_data){
2185 			.name = "mdss_esc1_clk",
2186 			.parent_names = (const char *[]){
2187 				"esc1_clk_src",
2188 			},
2189 			.num_parents = 1,
2190 			.flags = CLK_SET_RATE_PARENT,
2191 			.ops = &clk_branch2_ops,
2192 		},
2193 	},
2194 };
2195 
2196 static struct clk_branch mdss_extpclk_clk = {
2197 	.halt_reg = 0x2324,
2198 	.clkr = {
2199 		.enable_reg = 0x2324,
2200 		.enable_mask = BIT(0),
2201 		.hw.init = &(struct clk_init_data){
2202 			.name = "mdss_extpclk_clk",
2203 			.parent_names = (const char *[]){
2204 				"extpclk_clk_src",
2205 			},
2206 			.num_parents = 1,
2207 			.flags = CLK_SET_RATE_PARENT,
2208 			.ops = &clk_branch2_ops,
2209 		},
2210 	},
2211 };
2212 
2213 static struct clk_branch mdss_hdmi_ahb_clk = {
2214 	.halt_reg = 0x230c,
2215 	.clkr = {
2216 		.enable_reg = 0x230c,
2217 		.enable_mask = BIT(0),
2218 		.hw.init = &(struct clk_init_data){
2219 			.name = "mdss_hdmi_ahb_clk",
2220 			.parent_names = (const char *[]){
2221 				"mmss_ahb_clk_src",
2222 			},
2223 			.num_parents = 1,
2224 			.flags = CLK_SET_RATE_PARENT,
2225 			.ops = &clk_branch2_ops,
2226 		},
2227 	},
2228 };
2229 
2230 static struct clk_branch mdss_hdmi_clk = {
2231 	.halt_reg = 0x2338,
2232 	.clkr = {
2233 		.enable_reg = 0x2338,
2234 		.enable_mask = BIT(0),
2235 		.hw.init = &(struct clk_init_data){
2236 			.name = "mdss_hdmi_clk",
2237 			.parent_names = (const char *[]){
2238 				"hdmi_clk_src",
2239 			},
2240 			.num_parents = 1,
2241 			.flags = CLK_SET_RATE_PARENT,
2242 			.ops = &clk_branch2_ops,
2243 		},
2244 	},
2245 };
2246 
2247 static struct clk_branch mdss_mdp_clk = {
2248 	.halt_reg = 0x231c,
2249 	.clkr = {
2250 		.enable_reg = 0x231c,
2251 		.enable_mask = BIT(0),
2252 		.hw.init = &(struct clk_init_data){
2253 			.name = "mdss_mdp_clk",
2254 			.parent_names = (const char *[]){
2255 				"mdp_clk_src",
2256 			},
2257 			.num_parents = 1,
2258 			.flags = CLK_SET_RATE_PARENT,
2259 			.ops = &clk_branch2_ops,
2260 		},
2261 	},
2262 };
2263 
2264 static struct clk_branch mdss_mdp_lut_clk = {
2265 	.halt_reg = 0x2320,
2266 	.clkr = {
2267 		.enable_reg = 0x2320,
2268 		.enable_mask = BIT(0),
2269 		.hw.init = &(struct clk_init_data){
2270 			.name = "mdss_mdp_lut_clk",
2271 			.parent_names = (const char *[]){
2272 				"mdp_clk_src",
2273 			},
2274 			.num_parents = 1,
2275 			.flags = CLK_SET_RATE_PARENT,
2276 			.ops = &clk_branch2_ops,
2277 		},
2278 	},
2279 };
2280 
2281 static struct clk_branch mdss_pclk0_clk = {
2282 	.halt_reg = 0x2314,
2283 	.clkr = {
2284 		.enable_reg = 0x2314,
2285 		.enable_mask = BIT(0),
2286 		.hw.init = &(struct clk_init_data){
2287 			.name = "mdss_pclk0_clk",
2288 			.parent_names = (const char *[]){
2289 				"pclk0_clk_src",
2290 			},
2291 			.num_parents = 1,
2292 			.flags = CLK_SET_RATE_PARENT,
2293 			.ops = &clk_branch2_ops,
2294 		},
2295 	},
2296 };
2297 
2298 static struct clk_branch mdss_pclk1_clk = {
2299 	.halt_reg = 0x2318,
2300 	.clkr = {
2301 		.enable_reg = 0x2318,
2302 		.enable_mask = BIT(0),
2303 		.hw.init = &(struct clk_init_data){
2304 			.name = "mdss_pclk1_clk",
2305 			.parent_names = (const char *[]){
2306 				"pclk1_clk_src",
2307 			},
2308 			.num_parents = 1,
2309 			.flags = CLK_SET_RATE_PARENT,
2310 			.ops = &clk_branch2_ops,
2311 		},
2312 	},
2313 };
2314 
2315 static struct clk_branch mdss_vsync_clk = {
2316 	.halt_reg = 0x2328,
2317 	.clkr = {
2318 		.enable_reg = 0x2328,
2319 		.enable_mask = BIT(0),
2320 		.hw.init = &(struct clk_init_data){
2321 			.name = "mdss_vsync_clk",
2322 			.parent_names = (const char *[]){
2323 				"vsync_clk_src",
2324 			},
2325 			.num_parents = 1,
2326 			.flags = CLK_SET_RATE_PARENT,
2327 			.ops = &clk_branch2_ops,
2328 		},
2329 	},
2330 };
2331 
2332 static struct clk_branch mmss_rbcpr_ahb_clk = {
2333 	.halt_reg = 0x4088,
2334 	.clkr = {
2335 		.enable_reg = 0x4088,
2336 		.enable_mask = BIT(0),
2337 		.hw.init = &(struct clk_init_data){
2338 			.name = "mmss_rbcpr_ahb_clk",
2339 			.parent_names = (const char *[]){
2340 				"mmss_ahb_clk_src",
2341 			},
2342 			.num_parents = 1,
2343 			.flags = CLK_SET_RATE_PARENT,
2344 			.ops = &clk_branch2_ops,
2345 		},
2346 	},
2347 };
2348 
2349 static struct clk_branch mmss_rbcpr_clk = {
2350 	.halt_reg = 0x4084,
2351 	.clkr = {
2352 		.enable_reg = 0x4084,
2353 		.enable_mask = BIT(0),
2354 		.hw.init = &(struct clk_init_data){
2355 			.name = "mmss_rbcpr_clk",
2356 			.parent_names = (const char *[]){
2357 				"rbcpr_clk_src",
2358 			},
2359 			.num_parents = 1,
2360 			.flags = CLK_SET_RATE_PARENT,
2361 			.ops = &clk_branch2_ops,
2362 		},
2363 	},
2364 };
2365 
2366 static struct clk_branch mmss_spdm_ahb_clk = {
2367 	.halt_reg = 0x0230,
2368 	.clkr = {
2369 		.enable_reg = 0x0230,
2370 		.enable_mask = BIT(0),
2371 		.hw.init = &(struct clk_init_data){
2372 			.name = "mmss_spdm_ahb_clk",
2373 			.parent_names = (const char *[]){
2374 				"mmss_spdm_ahb_div_clk",
2375 			},
2376 			.num_parents = 1,
2377 			.flags = CLK_SET_RATE_PARENT,
2378 			.ops = &clk_branch2_ops,
2379 		},
2380 	},
2381 };
2382 
2383 static struct clk_branch mmss_spdm_axi_clk = {
2384 	.halt_reg = 0x0210,
2385 	.clkr = {
2386 		.enable_reg = 0x0210,
2387 		.enable_mask = BIT(0),
2388 		.hw.init = &(struct clk_init_data){
2389 			.name = "mmss_spdm_axi_clk",
2390 			.parent_names = (const char *[]){
2391 				"mmss_spdm_axi_div_clk",
2392 			},
2393 			.num_parents = 1,
2394 			.flags = CLK_SET_RATE_PARENT,
2395 			.ops = &clk_branch2_ops,
2396 		},
2397 	},
2398 };
2399 
2400 static struct clk_branch mmss_spdm_csi0_clk = {
2401 	.halt_reg = 0x023c,
2402 	.clkr = {
2403 		.enable_reg = 0x023c,
2404 		.enable_mask = BIT(0),
2405 		.hw.init = &(struct clk_init_data){
2406 			.name = "mmss_spdm_csi0_clk",
2407 			.parent_names = (const char *[]){
2408 				"mmss_spdm_csi0_div_clk",
2409 			},
2410 			.num_parents = 1,
2411 			.flags = CLK_SET_RATE_PARENT,
2412 			.ops = &clk_branch2_ops,
2413 		},
2414 	},
2415 };
2416 
2417 static struct clk_branch mmss_spdm_gfx3d_clk = {
2418 	.halt_reg = 0x022c,
2419 	.clkr = {
2420 		.enable_reg = 0x022c,
2421 		.enable_mask = BIT(0),
2422 		.hw.init = &(struct clk_init_data){
2423 			.name = "mmss_spdm_gfx3d_clk",
2424 			.parent_names = (const char *[]){
2425 				"mmss_spdm_gfx3d_div_clk",
2426 			},
2427 			.num_parents = 1,
2428 			.flags = CLK_SET_RATE_PARENT,
2429 			.ops = &clk_branch2_ops,
2430 		},
2431 	},
2432 };
2433 
2434 static struct clk_branch mmss_spdm_jpeg0_clk = {
2435 	.halt_reg = 0x0204,
2436 	.clkr = {
2437 		.enable_reg = 0x0204,
2438 		.enable_mask = BIT(0),
2439 		.hw.init = &(struct clk_init_data){
2440 			.name = "mmss_spdm_jpeg0_clk",
2441 			.parent_names = (const char *[]){
2442 				"mmss_spdm_jpeg0_div_clk",
2443 			},
2444 			.num_parents = 1,
2445 			.flags = CLK_SET_RATE_PARENT,
2446 			.ops = &clk_branch2_ops,
2447 		},
2448 	},
2449 };
2450 
2451 static struct clk_branch mmss_spdm_jpeg1_clk = {
2452 	.halt_reg = 0x0208,
2453 	.clkr = {
2454 		.enable_reg = 0x0208,
2455 		.enable_mask = BIT(0),
2456 		.hw.init = &(struct clk_init_data){
2457 			.name = "mmss_spdm_jpeg1_clk",
2458 			.parent_names = (const char *[]){
2459 				"mmss_spdm_jpeg1_div_clk",
2460 			},
2461 			.num_parents = 1,
2462 			.flags = CLK_SET_RATE_PARENT,
2463 			.ops = &clk_branch2_ops,
2464 		},
2465 	},
2466 };
2467 
2468 static struct clk_branch mmss_spdm_jpeg2_clk = {
2469 	.halt_reg = 0x0224,
2470 	.clkr = {
2471 		.enable_reg = 0x0224,
2472 		.enable_mask = BIT(0),
2473 		.hw.init = &(struct clk_init_data){
2474 			.name = "mmss_spdm_jpeg2_clk",
2475 			.parent_names = (const char *[]){
2476 				"mmss_spdm_jpeg2_div_clk",
2477 			},
2478 			.num_parents = 1,
2479 			.flags = CLK_SET_RATE_PARENT,
2480 			.ops = &clk_branch2_ops,
2481 		},
2482 	},
2483 };
2484 
2485 static struct clk_branch mmss_spdm_mdp_clk = {
2486 	.halt_reg = 0x020c,
2487 	.clkr = {
2488 		.enable_reg = 0x020c,
2489 		.enable_mask = BIT(0),
2490 		.hw.init = &(struct clk_init_data){
2491 			.name = "mmss_spdm_mdp_clk",
2492 			.parent_names = (const char *[]){
2493 				"mmss_spdm_mdp_div_clk",
2494 			},
2495 			.num_parents = 1,
2496 			.flags = CLK_SET_RATE_PARENT,
2497 			.ops = &clk_branch2_ops,
2498 		},
2499 	},
2500 };
2501 
2502 static struct clk_branch mmss_spdm_pclk0_clk = {
2503 	.halt_reg = 0x0234,
2504 	.clkr = {
2505 		.enable_reg = 0x0234,
2506 		.enable_mask = BIT(0),
2507 		.hw.init = &(struct clk_init_data){
2508 			.name = "mmss_spdm_pclk0_clk",
2509 			.parent_names = (const char *[]){
2510 				"mmss_spdm_pclk0_div_clk",
2511 			},
2512 			.num_parents = 1,
2513 			.flags = CLK_SET_RATE_PARENT,
2514 			.ops = &clk_branch2_ops,
2515 		},
2516 	},
2517 };
2518 
2519 static struct clk_branch mmss_spdm_pclk1_clk = {
2520 	.halt_reg = 0x0228,
2521 	.clkr = {
2522 		.enable_reg = 0x0228,
2523 		.enable_mask = BIT(0),
2524 		.hw.init = &(struct clk_init_data){
2525 			.name = "mmss_spdm_pclk1_clk",
2526 			.parent_names = (const char *[]){
2527 				"mmss_spdm_pclk1_div_clk",
2528 			},
2529 			.num_parents = 1,
2530 			.flags = CLK_SET_RATE_PARENT,
2531 			.ops = &clk_branch2_ops,
2532 		},
2533 	},
2534 };
2535 
2536 static struct clk_branch mmss_spdm_vcodec0_clk = {
2537 	.halt_reg = 0x0214,
2538 	.clkr = {
2539 		.enable_reg = 0x0214,
2540 		.enable_mask = BIT(0),
2541 		.hw.init = &(struct clk_init_data){
2542 			.name = "mmss_spdm_vcodec0_clk",
2543 			.parent_names = (const char *[]){
2544 				"mmss_spdm_vcodec0_div_clk",
2545 			},
2546 			.num_parents = 1,
2547 			.flags = CLK_SET_RATE_PARENT,
2548 			.ops = &clk_branch2_ops,
2549 		},
2550 	},
2551 };
2552 
2553 static struct clk_branch mmss_spdm_vfe0_clk = {
2554 	.halt_reg = 0x0218,
2555 	.clkr = {
2556 		.enable_reg = 0x0218,
2557 		.enable_mask = BIT(0),
2558 		.hw.init = &(struct clk_init_data){
2559 			.name = "mmss_spdm_vfe0_clk",
2560 			.parent_names = (const char *[]){
2561 				"mmss_spdm_vfe0_div_clk",
2562 			},
2563 			.num_parents = 1,
2564 			.flags = CLK_SET_RATE_PARENT,
2565 			.ops = &clk_branch2_ops,
2566 		},
2567 	},
2568 };
2569 
2570 static struct clk_branch mmss_spdm_vfe1_clk = {
2571 	.halt_reg = 0x021c,
2572 	.clkr = {
2573 		.enable_reg = 0x021c,
2574 		.enable_mask = BIT(0),
2575 		.hw.init = &(struct clk_init_data){
2576 			.name = "mmss_spdm_vfe1_clk",
2577 			.parent_names = (const char *[]){
2578 				"mmss_spdm_vfe1_div_clk",
2579 			},
2580 			.num_parents = 1,
2581 			.flags = CLK_SET_RATE_PARENT,
2582 			.ops = &clk_branch2_ops,
2583 		},
2584 	},
2585 };
2586 
2587 static struct clk_branch mmss_spdm_rm_axi_clk = {
2588 	.halt_reg = 0x0304,
2589 	.clkr = {
2590 		.enable_reg = 0x0304,
2591 		.enable_mask = BIT(0),
2592 		.hw.init = &(struct clk_init_data){
2593 			.name = "mmss_spdm_rm_axi_clk",
2594 			.parent_names = (const char *[]){
2595 				"mmss_axi_clk_src",
2596 			},
2597 			.num_parents = 1,
2598 			.flags = CLK_SET_RATE_PARENT,
2599 			.ops = &clk_branch2_ops,
2600 		},
2601 	},
2602 };
2603 
2604 static struct clk_branch mmss_spdm_rm_ocmemnoc_clk = {
2605 	.halt_reg = 0x0308,
2606 	.clkr = {
2607 		.enable_reg = 0x0308,
2608 		.enable_mask = BIT(0),
2609 		.hw.init = &(struct clk_init_data){
2610 			.name = "mmss_spdm_rm_ocmemnoc_clk",
2611 			.parent_names = (const char *[]){
2612 				"ocmemnoc_clk_src",
2613 			},
2614 			.num_parents = 1,
2615 			.flags = CLK_SET_RATE_PARENT,
2616 			.ops = &clk_branch2_ops,
2617 		},
2618 	},
2619 };
2620 
2621 
2622 static struct clk_branch mmss_misc_ahb_clk = {
2623 	.halt_reg = 0x502c,
2624 	.clkr = {
2625 		.enable_reg = 0x502c,
2626 		.enable_mask = BIT(0),
2627 		.hw.init = &(struct clk_init_data){
2628 			.name = "mmss_misc_ahb_clk",
2629 			.parent_names = (const char *[]){
2630 				"mmss_ahb_clk_src",
2631 			},
2632 			.num_parents = 1,
2633 			.flags = CLK_SET_RATE_PARENT,
2634 			.ops = &clk_branch2_ops,
2635 		},
2636 	},
2637 };
2638 
2639 static struct clk_branch mmss_mmssnoc_ahb_clk = {
2640 	.halt_reg = 0x5024,
2641 	.clkr = {
2642 		.enable_reg = 0x5024,
2643 		.enable_mask = BIT(0),
2644 		.hw.init = &(struct clk_init_data){
2645 			.name = "mmss_mmssnoc_ahb_clk",
2646 			.parent_names = (const char *[]){
2647 				"mmss_ahb_clk_src",
2648 			},
2649 			.num_parents = 1,
2650 			.ops = &clk_branch2_ops,
2651 			.flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2652 		},
2653 	},
2654 };
2655 
2656 static struct clk_branch mmss_mmssnoc_bto_ahb_clk = {
2657 	.halt_reg = 0x5028,
2658 	.clkr = {
2659 		.enable_reg = 0x5028,
2660 		.enable_mask = BIT(0),
2661 		.hw.init = &(struct clk_init_data){
2662 			.name = "mmss_mmssnoc_bto_ahb_clk",
2663 			.parent_names = (const char *[]){
2664 				"mmss_ahb_clk_src",
2665 			},
2666 			.num_parents = 1,
2667 			.ops = &clk_branch2_ops,
2668 			.flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2669 		},
2670 	},
2671 };
2672 
2673 static struct clk_branch mmss_mmssnoc_axi_clk = {
2674 	.halt_reg = 0x506c,
2675 	.clkr = {
2676 		.enable_reg = 0x506c,
2677 		.enable_mask = BIT(0),
2678 		.hw.init = &(struct clk_init_data){
2679 			.name = "mmss_mmssnoc_axi_clk",
2680 			.parent_names = (const char *[]){
2681 				"mmss_axi_clk_src",
2682 			},
2683 			.num_parents = 1,
2684 			.flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2685 			.ops = &clk_branch2_ops,
2686 		},
2687 	},
2688 };
2689 
2690 static struct clk_branch mmss_s0_axi_clk = {
2691 	.halt_reg = 0x5064,
2692 	.clkr = {
2693 		.enable_reg = 0x5064,
2694 		.enable_mask = BIT(0),
2695 		.hw.init = &(struct clk_init_data){
2696 			.name = "mmss_s0_axi_clk",
2697 			.parent_names = (const char *[]){
2698 				"mmss_axi_clk_src",
2699 			},
2700 			.num_parents = 1,
2701 			.ops = &clk_branch2_ops,
2702 			.flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2703 		},
2704 	},
2705 };
2706 
2707 static struct clk_branch ocmemcx_ahb_clk = {
2708 	.halt_reg = 0x405c,
2709 	.clkr = {
2710 		.enable_reg = 0x405c,
2711 		.enable_mask = BIT(0),
2712 		.hw.init = &(struct clk_init_data){
2713 			.name = "ocmemcx_ahb_clk",
2714 			.parent_names = (const char *[]){
2715 				"mmss_ahb_clk_src",
2716 			},
2717 			.num_parents = 1,
2718 			.flags = CLK_SET_RATE_PARENT,
2719 			.ops = &clk_branch2_ops,
2720 		},
2721 	},
2722 };
2723 
2724 static struct clk_branch ocmemcx_ocmemnoc_clk = {
2725 	.halt_reg = 0x4058,
2726 	.clkr = {
2727 		.enable_reg = 0x4058,
2728 		.enable_mask = BIT(0),
2729 		.hw.init = &(struct clk_init_data){
2730 			.name = "ocmemcx_ocmemnoc_clk",
2731 			.parent_names = (const char *[]){
2732 				"ocmemnoc_clk_src",
2733 			},
2734 			.num_parents = 1,
2735 			.flags = CLK_SET_RATE_PARENT,
2736 			.ops = &clk_branch2_ops,
2737 		},
2738 	},
2739 };
2740 
2741 static struct clk_branch oxili_ocmemgx_clk = {
2742 	.halt_reg = 0x402c,
2743 	.clkr = {
2744 		.enable_reg = 0x402c,
2745 		.enable_mask = BIT(0),
2746 		.hw.init = &(struct clk_init_data){
2747 			.name = "oxili_ocmemgx_clk",
2748 			.parent_names = (const char *[]){
2749 				"gfx3d_clk_src",
2750 			},
2751 			.num_parents = 1,
2752 			.flags = CLK_SET_RATE_PARENT,
2753 			.ops = &clk_branch2_ops,
2754 		},
2755 	},
2756 };
2757 
2758 static struct clk_branch oxili_gfx3d_clk = {
2759 	.halt_reg = 0x4028,
2760 	.clkr = {
2761 		.enable_reg = 0x4028,
2762 		.enable_mask = BIT(0),
2763 		.hw.init = &(struct clk_init_data){
2764 			.name = "oxili_gfx3d_clk",
2765 			.parent_names = (const char *[]){
2766 				"gfx3d_clk_src",
2767 			},
2768 			.num_parents = 1,
2769 			.flags = CLK_SET_RATE_PARENT,
2770 			.ops = &clk_branch2_ops,
2771 		},
2772 	},
2773 };
2774 
2775 static struct clk_branch oxili_rbbmtimer_clk = {
2776 	.halt_reg = 0x40b0,
2777 	.clkr = {
2778 		.enable_reg = 0x40b0,
2779 		.enable_mask = BIT(0),
2780 		.hw.init = &(struct clk_init_data){
2781 			.name = "oxili_rbbmtimer_clk",
2782 			.parent_names = (const char *[]){
2783 				"rbbmtimer_clk_src",
2784 			},
2785 			.num_parents = 1,
2786 			.flags = CLK_SET_RATE_PARENT,
2787 			.ops = &clk_branch2_ops,
2788 		},
2789 	},
2790 };
2791 
2792 static struct clk_branch oxilicx_ahb_clk = {
2793 	.halt_reg = 0x403c,
2794 	.clkr = {
2795 		.enable_reg = 0x403c,
2796 		.enable_mask = BIT(0),
2797 		.hw.init = &(struct clk_init_data){
2798 			.name = "oxilicx_ahb_clk",
2799 			.parent_names = (const char *[]){
2800 				"mmss_ahb_clk_src",
2801 			},
2802 			.num_parents = 1,
2803 			.flags = CLK_SET_RATE_PARENT,
2804 			.ops = &clk_branch2_ops,
2805 		},
2806 	},
2807 };
2808 
2809 static struct clk_branch venus0_ahb_clk = {
2810 	.halt_reg = 0x1030,
2811 	.clkr = {
2812 		.enable_reg = 0x1030,
2813 		.enable_mask = BIT(0),
2814 		.hw.init = &(struct clk_init_data){
2815 			.name = "venus0_ahb_clk",
2816 			.parent_names = (const char *[]){
2817 				"mmss_ahb_clk_src",
2818 			},
2819 			.num_parents = 1,
2820 			.flags = CLK_SET_RATE_PARENT,
2821 			.ops = &clk_branch2_ops,
2822 		},
2823 	},
2824 };
2825 
2826 static struct clk_branch venus0_axi_clk = {
2827 	.halt_reg = 0x1034,
2828 	.clkr = {
2829 		.enable_reg = 0x1034,
2830 		.enable_mask = BIT(0),
2831 		.hw.init = &(struct clk_init_data){
2832 			.name = "venus0_axi_clk",
2833 			.parent_names = (const char *[]){
2834 				"mmss_axi_clk_src",
2835 			},
2836 			.num_parents = 1,
2837 			.flags = CLK_SET_RATE_PARENT,
2838 			.ops = &clk_branch2_ops,
2839 		},
2840 	},
2841 };
2842 
2843 static struct clk_branch venus0_core0_vcodec_clk = {
2844 	.halt_reg = 0x1048,
2845 	.clkr = {
2846 		.enable_reg = 0x1048,
2847 		.enable_mask = BIT(0),
2848 		.hw.init = &(struct clk_init_data){
2849 			.name = "venus0_core0_vcodec_clk",
2850 			.parent_names = (const char *[]){
2851 				"vcodec0_clk_src",
2852 			},
2853 			.num_parents = 1,
2854 			.flags = CLK_SET_RATE_PARENT,
2855 			.ops = &clk_branch2_ops,
2856 		},
2857 	},
2858 };
2859 
2860 static struct clk_branch venus0_core1_vcodec_clk = {
2861 	.halt_reg = 0x104c,
2862 	.clkr = {
2863 		.enable_reg = 0x104c,
2864 		.enable_mask = BIT(0),
2865 		.hw.init = &(struct clk_init_data){
2866 			.name = "venus0_core1_vcodec_clk",
2867 			.parent_names = (const char *[]){
2868 				"vcodec0_clk_src",
2869 			},
2870 			.num_parents = 1,
2871 			.flags = CLK_SET_RATE_PARENT,
2872 			.ops = &clk_branch2_ops,
2873 		},
2874 	},
2875 };
2876 
2877 static struct clk_branch venus0_ocmemnoc_clk = {
2878 	.halt_reg = 0x1038,
2879 	.clkr = {
2880 		.enable_reg = 0x1038,
2881 		.enable_mask = BIT(0),
2882 		.hw.init = &(struct clk_init_data){
2883 			.name = "venus0_ocmemnoc_clk",
2884 			.parent_names = (const char *[]){
2885 				"ocmemnoc_clk_src",
2886 			},
2887 			.num_parents = 1,
2888 			.flags = CLK_SET_RATE_PARENT,
2889 			.ops = &clk_branch2_ops,
2890 		},
2891 	},
2892 };
2893 
2894 static struct clk_branch venus0_vcodec0_clk = {
2895 	.halt_reg = 0x1028,
2896 	.clkr = {
2897 		.enable_reg = 0x1028,
2898 		.enable_mask = BIT(0),
2899 		.hw.init = &(struct clk_init_data){
2900 			.name = "venus0_vcodec0_clk",
2901 			.parent_names = (const char *[]){
2902 				"vcodec0_clk_src",
2903 			},
2904 			.num_parents = 1,
2905 			.flags = CLK_SET_RATE_PARENT,
2906 			.ops = &clk_branch2_ops,
2907 		},
2908 	},
2909 };
2910 
2911 static struct clk_branch vpu_ahb_clk = {
2912 	.halt_reg = 0x1430,
2913 	.clkr = {
2914 		.enable_reg = 0x1430,
2915 		.enable_mask = BIT(0),
2916 		.hw.init = &(struct clk_init_data){
2917 			.name = "vpu_ahb_clk",
2918 			.parent_names = (const char *[]){
2919 				"mmss_ahb_clk_src",
2920 			},
2921 			.num_parents = 1,
2922 			.flags = CLK_SET_RATE_PARENT,
2923 			.ops = &clk_branch2_ops,
2924 		},
2925 	},
2926 };
2927 
2928 static struct clk_branch vpu_axi_clk = {
2929 	.halt_reg = 0x143c,
2930 	.clkr = {
2931 		.enable_reg = 0x143c,
2932 		.enable_mask = BIT(0),
2933 		.hw.init = &(struct clk_init_data){
2934 			.name = "vpu_axi_clk",
2935 			.parent_names = (const char *[]){
2936 				"mmss_axi_clk_src",
2937 			},
2938 			.num_parents = 1,
2939 			.flags = CLK_SET_RATE_PARENT,
2940 			.ops = &clk_branch2_ops,
2941 		},
2942 	},
2943 };
2944 
2945 static struct clk_branch vpu_bus_clk = {
2946 	.halt_reg = 0x1440,
2947 	.clkr = {
2948 		.enable_reg = 0x1440,
2949 		.enable_mask = BIT(0),
2950 		.hw.init = &(struct clk_init_data){
2951 			.name = "vpu_bus_clk",
2952 			.parent_names = (const char *[]){
2953 				"vpu_bus_clk_src",
2954 			},
2955 			.num_parents = 1,
2956 			.flags = CLK_SET_RATE_PARENT,
2957 			.ops = &clk_branch2_ops,
2958 		},
2959 	},
2960 };
2961 
2962 static struct clk_branch vpu_cxo_clk = {
2963 	.halt_reg = 0x1434,
2964 	.clkr = {
2965 		.enable_reg = 0x1434,
2966 		.enable_mask = BIT(0),
2967 		.hw.init = &(struct clk_init_data){
2968 			.name = "vpu_cxo_clk",
2969 			.parent_names = (const char *[]){ "xo" },
2970 			.num_parents = 1,
2971 			.flags = CLK_SET_RATE_PARENT,
2972 			.ops = &clk_branch2_ops,
2973 		},
2974 	},
2975 };
2976 
2977 static struct clk_branch vpu_maple_clk = {
2978 	.halt_reg = 0x142c,
2979 	.clkr = {
2980 		.enable_reg = 0x142c,
2981 		.enable_mask = BIT(0),
2982 		.hw.init = &(struct clk_init_data){
2983 			.name = "vpu_maple_clk",
2984 			.parent_names = (const char *[]){
2985 				"maple_clk_src",
2986 			},
2987 			.num_parents = 1,
2988 			.flags = CLK_SET_RATE_PARENT,
2989 			.ops = &clk_branch2_ops,
2990 		},
2991 	},
2992 };
2993 
2994 static struct clk_branch vpu_sleep_clk = {
2995 	.halt_reg = 0x1438,
2996 	.clkr = {
2997 		.enable_reg = 0x1438,
2998 		.enable_mask = BIT(0),
2999 		.hw.init = &(struct clk_init_data){
3000 			.name = "vpu_sleep_clk",
3001 			.parent_names = (const char *[]){
3002 				"sleep_clk_src",
3003 			},
3004 			.num_parents = 1,
3005 			.flags = CLK_SET_RATE_PARENT,
3006 			.ops = &clk_branch2_ops,
3007 		},
3008 	},
3009 };
3010 
3011 static struct clk_branch vpu_vdp_clk = {
3012 	.halt_reg = 0x1428,
3013 	.clkr = {
3014 		.enable_reg = 0x1428,
3015 		.enable_mask = BIT(0),
3016 		.hw.init = &(struct clk_init_data){
3017 			.name = "vpu_vdp_clk",
3018 			.parent_names = (const char *[]){
3019 				"vdp_clk_src",
3020 			},
3021 			.num_parents = 1,
3022 			.flags = CLK_SET_RATE_PARENT,
3023 			.ops = &clk_branch2_ops,
3024 		},
3025 	},
3026 };
3027 
3028 static const struct pll_config mmpll1_config = {
3029 	.l = 60,
3030 	.m = 25,
3031 	.n = 32,
3032 	.vco_val = 0x0,
3033 	.vco_mask = 0x3 << 20,
3034 	.pre_div_val = 0x0,
3035 	.pre_div_mask = 0x7 << 12,
3036 	.post_div_val = 0x0,
3037 	.post_div_mask = 0x3 << 8,
3038 	.mn_ena_mask = BIT(24),
3039 	.main_output_mask = BIT(0),
3040 };
3041 
3042 static const struct pll_config mmpll3_config = {
3043 	.l = 48,
3044 	.m = 7,
3045 	.n = 16,
3046 	.vco_val = 0x0,
3047 	.vco_mask = 0x3 << 20,
3048 	.pre_div_val = 0x0,
3049 	.pre_div_mask = 0x7 << 12,
3050 	.post_div_val = 0x0,
3051 	.post_div_mask = 0x3 << 8,
3052 	.mn_ena_mask = BIT(24),
3053 	.main_output_mask = BIT(0),
3054 	.aux_output_mask = BIT(1),
3055 };
3056 
3057 static struct gdsc venus0_gdsc = {
3058 	.gdscr = 0x1024,
3059 	.pd = {
3060 		.name = "venus0",
3061 	},
3062 	.pwrsts = PWRSTS_OFF_ON,
3063 };
3064 
3065 static struct gdsc venus0_core0_gdsc = {
3066 	.gdscr = 0x1040,
3067 	.pd = {
3068 		.name = "venus0_core0",
3069 	},
3070 	.pwrsts = PWRSTS_OFF_ON,
3071 };
3072 
3073 static struct gdsc venus0_core1_gdsc = {
3074 	.gdscr = 0x1044,
3075 	.pd = {
3076 		.name = "venus0_core1",
3077 	},
3078 	.pwrsts = PWRSTS_OFF_ON,
3079 };
3080 
3081 static struct gdsc mdss_gdsc = {
3082 	.gdscr = 0x2304,
3083 	.cxcs = (unsigned int []){ 0x231c, 0x2320 },
3084 	.cxc_count = 2,
3085 	.pd = {
3086 		.name = "mdss",
3087 	},
3088 	.pwrsts = PWRSTS_OFF_ON,
3089 };
3090 
3091 static struct gdsc camss_jpeg_gdsc = {
3092 	.gdscr = 0x35a4,
3093 	.pd = {
3094 		.name = "camss_jpeg",
3095 	},
3096 	.pwrsts = PWRSTS_OFF_ON,
3097 };
3098 
3099 static struct gdsc camss_vfe_gdsc = {
3100 	.gdscr = 0x36a4,
3101 	.cxcs = (unsigned int []){ 0x36a8, 0x36ac, 0x36b0 },
3102 	.cxc_count = 3,
3103 	.pd = {
3104 		.name = "camss_vfe",
3105 	},
3106 	.pwrsts = PWRSTS_OFF_ON,
3107 };
3108 
3109 static struct gdsc oxili_gdsc = {
3110 	.gdscr = 0x4024,
3111 	.cxcs = (unsigned int []){ 0x4028 },
3112 	.cxc_count = 1,
3113 	.pd = {
3114 		.name = "oxili",
3115 	},
3116 	.pwrsts = PWRSTS_OFF_ON,
3117 };
3118 
3119 static struct gdsc oxilicx_gdsc = {
3120 	.gdscr = 0x4034,
3121 	.pd = {
3122 		.name = "oxilicx",
3123 	},
3124 	.pwrsts = PWRSTS_OFF_ON,
3125 };
3126 
3127 static struct clk_regmap *mmcc_apq8084_clocks[] = {
3128 	[MMSS_AHB_CLK_SRC] = &mmss_ahb_clk_src.clkr,
3129 	[MMSS_AXI_CLK_SRC] = &mmss_axi_clk_src.clkr,
3130 	[MMPLL0] = &mmpll0.clkr,
3131 	[MMPLL0_VOTE] = &mmpll0_vote,
3132 	[MMPLL1] = &mmpll1.clkr,
3133 	[MMPLL1_VOTE] = &mmpll1_vote,
3134 	[MMPLL2] = &mmpll2.clkr,
3135 	[MMPLL3] = &mmpll3.clkr,
3136 	[MMPLL4] = &mmpll4.clkr,
3137 	[CSI0_CLK_SRC] = &csi0_clk_src.clkr,
3138 	[CSI1_CLK_SRC] = &csi1_clk_src.clkr,
3139 	[CSI2_CLK_SRC] = &csi2_clk_src.clkr,
3140 	[CSI3_CLK_SRC] = &csi3_clk_src.clkr,
3141 	[VCODEC0_CLK_SRC] = &vcodec0_clk_src.clkr,
3142 	[VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
3143 	[VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
3144 	[MDP_CLK_SRC] = &mdp_clk_src.clkr,
3145 	[PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
3146 	[PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
3147 	[OCMEMNOC_CLK_SRC] = &ocmemnoc_clk_src.clkr,
3148 	[GFX3D_CLK_SRC] = &gfx3d_clk_src.clkr,
3149 	[JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
3150 	[JPEG1_CLK_SRC] = &jpeg1_clk_src.clkr,
3151 	[JPEG2_CLK_SRC] = &jpeg2_clk_src.clkr,
3152 	[EDPPIXEL_CLK_SRC] = &edppixel_clk_src.clkr,
3153 	[EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
3154 	[VP_CLK_SRC] = &vp_clk_src.clkr,
3155 	[CCI_CLK_SRC] = &cci_clk_src.clkr,
3156 	[CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr,
3157 	[CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr,
3158 	[MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
3159 	[MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
3160 	[MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
3161 	[MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
3162 	[CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
3163 	[CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
3164 	[CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
3165 	[CPP_CLK_SRC] = &cpp_clk_src.clkr,
3166 	[BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
3167 	[BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
3168 	[EDPAUX_CLK_SRC] = &edpaux_clk_src.clkr,
3169 	[EDPLINK_CLK_SRC] = &edplink_clk_src.clkr,
3170 	[ESC0_CLK_SRC] = &esc0_clk_src.clkr,
3171 	[ESC1_CLK_SRC] = &esc1_clk_src.clkr,
3172 	[HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
3173 	[VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
3174 	[MMSS_RBCPR_CLK_SRC] = &rbcpr_clk_src.clkr,
3175 	[RBBMTIMER_CLK_SRC] = &rbbmtimer_clk_src.clkr,
3176 	[MAPLE_CLK_SRC] = &maple_clk_src.clkr,
3177 	[VDP_CLK_SRC] = &vdp_clk_src.clkr,
3178 	[VPU_BUS_CLK_SRC] = &vpu_bus_clk_src.clkr,
3179 	[MMSS_CXO_CLK] = &mmss_cxo_clk.clkr,
3180 	[MMSS_SLEEPCLK_CLK] = &mmss_sleepclk_clk.clkr,
3181 	[AVSYNC_AHB_CLK] = &avsync_ahb_clk.clkr,
3182 	[AVSYNC_EDPPIXEL_CLK] = &avsync_edppixel_clk.clkr,
3183 	[AVSYNC_EXTPCLK_CLK] = &avsync_extpclk_clk.clkr,
3184 	[AVSYNC_PCLK0_CLK] = &avsync_pclk0_clk.clkr,
3185 	[AVSYNC_PCLK1_CLK] = &avsync_pclk1_clk.clkr,
3186 	[AVSYNC_VP_CLK] = &avsync_vp_clk.clkr,
3187 	[CAMSS_AHB_CLK] = &camss_ahb_clk.clkr,
3188 	[CAMSS_CCI_CCI_AHB_CLK] = &camss_cci_cci_ahb_clk.clkr,
3189 	[CAMSS_CCI_CCI_CLK] = &camss_cci_cci_clk.clkr,
3190 	[CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
3191 	[CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
3192 	[CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
3193 	[CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
3194 	[CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
3195 	[CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
3196 	[CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
3197 	[CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
3198 	[CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
3199 	[CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
3200 	[CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
3201 	[CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
3202 	[CAMSS_CSI2PHY_CLK] = &camss_csi2phy_clk.clkr,
3203 	[CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
3204 	[CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
3205 	[CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
3206 	[CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
3207 	[CAMSS_CSI3PHY_CLK] = &camss_csi3phy_clk.clkr,
3208 	[CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
3209 	[CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
3210 	[CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
3211 	[CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
3212 	[CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
3213 	[CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
3214 	[CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
3215 	[CAMSS_JPEG_JPEG0_CLK] = &camss_jpeg_jpeg0_clk.clkr,
3216 	[CAMSS_JPEG_JPEG1_CLK] = &camss_jpeg_jpeg1_clk.clkr,
3217 	[CAMSS_JPEG_JPEG2_CLK] = &camss_jpeg_jpeg2_clk.clkr,
3218 	[CAMSS_JPEG_JPEG_AHB_CLK] = &camss_jpeg_jpeg_ahb_clk.clkr,
3219 	[CAMSS_JPEG_JPEG_AXI_CLK] = &camss_jpeg_jpeg_axi_clk.clkr,
3220 	[CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
3221 	[CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
3222 	[CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
3223 	[CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
3224 	[CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
3225 	[CAMSS_PHY0_CSI0PHYTIMER_CLK] = &camss_phy0_csi0phytimer_clk.clkr,
3226 	[CAMSS_PHY1_CSI1PHYTIMER_CLK] = &camss_phy1_csi1phytimer_clk.clkr,
3227 	[CAMSS_PHY2_CSI2PHYTIMER_CLK] = &camss_phy2_csi2phytimer_clk.clkr,
3228 	[CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
3229 	[CAMSS_VFE_CPP_AHB_CLK] = &camss_vfe_cpp_ahb_clk.clkr,
3230 	[CAMSS_VFE_CPP_CLK] = &camss_vfe_cpp_clk.clkr,
3231 	[CAMSS_VFE_VFE0_CLK] = &camss_vfe_vfe0_clk.clkr,
3232 	[CAMSS_VFE_VFE1_CLK] = &camss_vfe_vfe1_clk.clkr,
3233 	[CAMSS_VFE_VFE_AHB_CLK] = &camss_vfe_vfe_ahb_clk.clkr,
3234 	[CAMSS_VFE_VFE_AXI_CLK] = &camss_vfe_vfe_axi_clk.clkr,
3235 	[MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
3236 	[MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
3237 	[MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
3238 	[MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
3239 	[MDSS_EDPAUX_CLK] = &mdss_edpaux_clk.clkr,
3240 	[MDSS_EDPLINK_CLK] = &mdss_edplink_clk.clkr,
3241 	[MDSS_EDPPIXEL_CLK] = &mdss_edppixel_clk.clkr,
3242 	[MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
3243 	[MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
3244 	[MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
3245 	[MDSS_HDMI_AHB_CLK] = &mdss_hdmi_ahb_clk.clkr,
3246 	[MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
3247 	[MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
3248 	[MDSS_MDP_LUT_CLK] = &mdss_mdp_lut_clk.clkr,
3249 	[MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
3250 	[MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
3251 	[MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
3252 	[MMSS_RBCPR_AHB_CLK] = &mmss_rbcpr_ahb_clk.clkr,
3253 	[MMSS_RBCPR_CLK] = &mmss_rbcpr_clk.clkr,
3254 	[MMSS_SPDM_AHB_CLK] = &mmss_spdm_ahb_clk.clkr,
3255 	[MMSS_SPDM_AXI_CLK] = &mmss_spdm_axi_clk.clkr,
3256 	[MMSS_SPDM_CSI0_CLK] = &mmss_spdm_csi0_clk.clkr,
3257 	[MMSS_SPDM_GFX3D_CLK] = &mmss_spdm_gfx3d_clk.clkr,
3258 	[MMSS_SPDM_JPEG0_CLK] = &mmss_spdm_jpeg0_clk.clkr,
3259 	[MMSS_SPDM_JPEG1_CLK] = &mmss_spdm_jpeg1_clk.clkr,
3260 	[MMSS_SPDM_JPEG2_CLK] = &mmss_spdm_jpeg2_clk.clkr,
3261 	[MMSS_SPDM_MDP_CLK] = &mmss_spdm_mdp_clk.clkr,
3262 	[MMSS_SPDM_PCLK0_CLK] = &mmss_spdm_pclk0_clk.clkr,
3263 	[MMSS_SPDM_PCLK1_CLK] = &mmss_spdm_pclk1_clk.clkr,
3264 	[MMSS_SPDM_VCODEC0_CLK] = &mmss_spdm_vcodec0_clk.clkr,
3265 	[MMSS_SPDM_VFE0_CLK] = &mmss_spdm_vfe0_clk.clkr,
3266 	[MMSS_SPDM_VFE1_CLK] = &mmss_spdm_vfe1_clk.clkr,
3267 	[MMSS_SPDM_RM_AXI_CLK] = &mmss_spdm_rm_axi_clk.clkr,
3268 	[MMSS_SPDM_RM_OCMEMNOC_CLK] = &mmss_spdm_rm_ocmemnoc_clk.clkr,
3269 	[MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
3270 	[MMSS_MMSSNOC_AHB_CLK] = &mmss_mmssnoc_ahb_clk.clkr,
3271 	[MMSS_MMSSNOC_BTO_AHB_CLK] = &mmss_mmssnoc_bto_ahb_clk.clkr,
3272 	[MMSS_MMSSNOC_AXI_CLK] = &mmss_mmssnoc_axi_clk.clkr,
3273 	[MMSS_S0_AXI_CLK] = &mmss_s0_axi_clk.clkr,
3274 	[OCMEMCX_AHB_CLK] = &ocmemcx_ahb_clk.clkr,
3275 	[OCMEMCX_OCMEMNOC_CLK] = &ocmemcx_ocmemnoc_clk.clkr,
3276 	[OXILI_OCMEMGX_CLK] = &oxili_ocmemgx_clk.clkr,
3277 	[OXILI_GFX3D_CLK] = &oxili_gfx3d_clk.clkr,
3278 	[OXILI_RBBMTIMER_CLK] = &oxili_rbbmtimer_clk.clkr,
3279 	[OXILICX_AHB_CLK] = &oxilicx_ahb_clk.clkr,
3280 	[VENUS0_AHB_CLK] = &venus0_ahb_clk.clkr,
3281 	[VENUS0_AXI_CLK] = &venus0_axi_clk.clkr,
3282 	[VENUS0_CORE0_VCODEC_CLK] = &venus0_core0_vcodec_clk.clkr,
3283 	[VENUS0_CORE1_VCODEC_CLK] = &venus0_core1_vcodec_clk.clkr,
3284 	[VENUS0_OCMEMNOC_CLK] = &venus0_ocmemnoc_clk.clkr,
3285 	[VENUS0_VCODEC0_CLK] = &venus0_vcodec0_clk.clkr,
3286 	[VPU_AHB_CLK] = &vpu_ahb_clk.clkr,
3287 	[VPU_AXI_CLK] = &vpu_axi_clk.clkr,
3288 	[VPU_BUS_CLK] = &vpu_bus_clk.clkr,
3289 	[VPU_CXO_CLK] = &vpu_cxo_clk.clkr,
3290 	[VPU_MAPLE_CLK] = &vpu_maple_clk.clkr,
3291 	[VPU_SLEEP_CLK] = &vpu_sleep_clk.clkr,
3292 	[VPU_VDP_CLK] = &vpu_vdp_clk.clkr,
3293 };
3294 
3295 static const struct qcom_reset_map mmcc_apq8084_resets[] = {
3296 	[MMSS_SPDM_RESET] = { 0x0200 },
3297 	[MMSS_SPDM_RM_RESET] = { 0x0300 },
3298 	[VENUS0_RESET] = { 0x1020 },
3299 	[VPU_RESET] = { 0x1400 },
3300 	[MDSS_RESET] = { 0x2300 },
3301 	[AVSYNC_RESET] = { 0x2400 },
3302 	[CAMSS_PHY0_RESET] = { 0x3020 },
3303 	[CAMSS_PHY1_RESET] = { 0x3050 },
3304 	[CAMSS_PHY2_RESET] = { 0x3080 },
3305 	[CAMSS_CSI0_RESET] = { 0x30b0 },
3306 	[CAMSS_CSI0PHY_RESET] = { 0x30c0 },
3307 	[CAMSS_CSI0RDI_RESET] = { 0x30d0 },
3308 	[CAMSS_CSI0PIX_RESET] = { 0x30e0 },
3309 	[CAMSS_CSI1_RESET] = { 0x3120 },
3310 	[CAMSS_CSI1PHY_RESET] = { 0x3130 },
3311 	[CAMSS_CSI1RDI_RESET] = { 0x3140 },
3312 	[CAMSS_CSI1PIX_RESET] = { 0x3150 },
3313 	[CAMSS_CSI2_RESET] = { 0x3180 },
3314 	[CAMSS_CSI2PHY_RESET] = { 0x3190 },
3315 	[CAMSS_CSI2RDI_RESET] = { 0x31a0 },
3316 	[CAMSS_CSI2PIX_RESET] = { 0x31b0 },
3317 	[CAMSS_CSI3_RESET] = { 0x31e0 },
3318 	[CAMSS_CSI3PHY_RESET] = { 0x31f0 },
3319 	[CAMSS_CSI3RDI_RESET] = { 0x3200 },
3320 	[CAMSS_CSI3PIX_RESET] = { 0x3210 },
3321 	[CAMSS_ISPIF_RESET] = { 0x3220 },
3322 	[CAMSS_CCI_RESET] = { 0x3340 },
3323 	[CAMSS_MCLK0_RESET] = { 0x3380 },
3324 	[CAMSS_MCLK1_RESET] = { 0x33b0 },
3325 	[CAMSS_MCLK2_RESET] = { 0x33e0 },
3326 	[CAMSS_MCLK3_RESET] = { 0x3410 },
3327 	[CAMSS_GP0_RESET] = { 0x3440 },
3328 	[CAMSS_GP1_RESET] = { 0x3470 },
3329 	[CAMSS_TOP_RESET] = { 0x3480 },
3330 	[CAMSS_AHB_RESET] = { 0x3488 },
3331 	[CAMSS_MICRO_RESET] = { 0x3490 },
3332 	[CAMSS_JPEG_RESET] = { 0x35a0 },
3333 	[CAMSS_VFE_RESET] = { 0x36a0 },
3334 	[CAMSS_CSI_VFE0_RESET] = { 0x3700 },
3335 	[CAMSS_CSI_VFE1_RESET] = { 0x3710 },
3336 	[OXILI_RESET] = { 0x4020 },
3337 	[OXILICX_RESET] = { 0x4030 },
3338 	[OCMEMCX_RESET] = { 0x4050 },
3339 	[MMSS_RBCRP_RESET] = { 0x4080 },
3340 	[MMSSNOCAHB_RESET] = { 0x5020 },
3341 	[MMSSNOCAXI_RESET] = { 0x5060 },
3342 };
3343 
3344 static struct gdsc *mmcc_apq8084_gdscs[] = {
3345 	[VENUS0_GDSC] = &venus0_gdsc,
3346 	[VENUS0_CORE0_GDSC] = &venus0_core0_gdsc,
3347 	[VENUS0_CORE1_GDSC] = &venus0_core1_gdsc,
3348 	[MDSS_GDSC] = &mdss_gdsc,
3349 	[CAMSS_JPEG_GDSC] = &camss_jpeg_gdsc,
3350 	[CAMSS_VFE_GDSC] = &camss_vfe_gdsc,
3351 	[OXILI_GDSC] = &oxili_gdsc,
3352 	[OXILICX_GDSC] = &oxilicx_gdsc,
3353 };
3354 
3355 static const struct regmap_config mmcc_apq8084_regmap_config = {
3356 	.reg_bits	= 32,
3357 	.reg_stride	= 4,
3358 	.val_bits	= 32,
3359 	.max_register	= 0x5104,
3360 	.fast_io	= true,
3361 };
3362 
3363 static const struct qcom_cc_desc mmcc_apq8084_desc = {
3364 	.config = &mmcc_apq8084_regmap_config,
3365 	.clks = mmcc_apq8084_clocks,
3366 	.num_clks = ARRAY_SIZE(mmcc_apq8084_clocks),
3367 	.resets = mmcc_apq8084_resets,
3368 	.num_resets = ARRAY_SIZE(mmcc_apq8084_resets),
3369 	.gdscs = mmcc_apq8084_gdscs,
3370 	.num_gdscs = ARRAY_SIZE(mmcc_apq8084_gdscs),
3371 };
3372 
3373 static const struct of_device_id mmcc_apq8084_match_table[] = {
3374 	{ .compatible = "qcom,mmcc-apq8084" },
3375 	{ }
3376 };
3377 MODULE_DEVICE_TABLE(of, mmcc_apq8084_match_table);
3378 
mmcc_apq8084_probe(struct platform_device * pdev)3379 static int mmcc_apq8084_probe(struct platform_device *pdev)
3380 {
3381 	int ret;
3382 	struct regmap *regmap;
3383 
3384 	ret = qcom_cc_probe(pdev, &mmcc_apq8084_desc);
3385 	if (ret)
3386 		return ret;
3387 
3388 	regmap = dev_get_regmap(&pdev->dev, NULL);
3389 	clk_pll_configure_sr_hpm_lp(&mmpll1, regmap, &mmpll1_config, true);
3390 	clk_pll_configure_sr_hpm_lp(&mmpll3, regmap, &mmpll3_config, false);
3391 
3392 	return 0;
3393 }
3394 
3395 static struct platform_driver mmcc_apq8084_driver = {
3396 	.probe		= mmcc_apq8084_probe,
3397 	.driver		= {
3398 		.name	= "mmcc-apq8084",
3399 		.of_match_table = mmcc_apq8084_match_table,
3400 	},
3401 };
3402 module_platform_driver(mmcc_apq8084_driver);
3403 
3404 MODULE_DESCRIPTION("QCOM MMCC APQ8084 Driver");
3405 MODULE_LICENSE("GPL v2");
3406 MODULE_ALIAS("platform:mmcc-apq8084");
3407