xref: /linux/drivers/clk/qcom/camcc-sm8550.c (revision 59cb902371227c2cd7932a565eda97ac7e4707bf)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (c) 2023, Qualcomm Innovation Center, Inc. All rights reserved.
4  */
5 
6 #include <linux/clk-provider.h>
7 #include <linux/mod_devicetable.h>
8 #include <linux/module.h>
9 #include <linux/platform_device.h>
10 #include <linux/regmap.h>
11 
12 #include <dt-bindings/clock/qcom,sm8550-camcc.h>
13 
14 #include "clk-alpha-pll.h"
15 #include "clk-branch.h"
16 #include "clk-rcg.h"
17 #include "clk-regmap.h"
18 #include "common.h"
19 #include "gdsc.h"
20 #include "reset.h"
21 
22 enum {
23 	DT_IFACE,
24 	DT_BI_TCXO,
25 	DT_BI_TCXO_AO,
26 	DT_SLEEP_CLK,
27 };
28 
29 enum {
30 	P_BI_TCXO,
31 	P_BI_TCXO_AO,
32 	P_CAM_CC_PLL0_OUT_EVEN,
33 	P_CAM_CC_PLL0_OUT_MAIN,
34 	P_CAM_CC_PLL0_OUT_ODD,
35 	P_CAM_CC_PLL1_OUT_EVEN,
36 	P_CAM_CC_PLL2_OUT_EVEN,
37 	P_CAM_CC_PLL2_OUT_MAIN,
38 	P_CAM_CC_PLL3_OUT_EVEN,
39 	P_CAM_CC_PLL4_OUT_EVEN,
40 	P_CAM_CC_PLL5_OUT_EVEN,
41 	P_CAM_CC_PLL6_OUT_EVEN,
42 	P_CAM_CC_PLL7_OUT_EVEN,
43 	P_CAM_CC_PLL8_OUT_EVEN,
44 	P_CAM_CC_PLL9_OUT_EVEN,
45 	P_CAM_CC_PLL9_OUT_ODD,
46 	P_CAM_CC_PLL10_OUT_EVEN,
47 	P_CAM_CC_PLL11_OUT_EVEN,
48 	P_CAM_CC_PLL12_OUT_EVEN,
49 	P_SLEEP_CLK,
50 };
51 
52 static const struct pll_vco lucid_ole_vco[] = {
53 	{ 249600000, 2300000000, 0 },
54 };
55 
56 static const struct pll_vco rivian_ole_vco[] = {
57 	{ 777000000, 1285000000, 0 },
58 };
59 
60 static const struct alpha_pll_config cam_cc_pll0_config = {
61 	.l = 0x3e,
62 	.alpha = 0x8000,
63 	.config_ctl_val = 0x20485699,
64 	.config_ctl_hi_val = 0x00182261,
65 	.config_ctl_hi1_val = 0x82aa299c,
66 	.test_ctl_val = 0x00000000,
67 	.test_ctl_hi_val = 0x00000003,
68 	.test_ctl_hi1_val = 0x00009000,
69 	.test_ctl_hi2_val = 0x00000034,
70 	.user_ctl_val = 0x00008400,
71 	.user_ctl_hi_val = 0x00000005,
72 };
73 
74 static struct clk_alpha_pll cam_cc_pll0 = {
75 	.offset = 0x0,
76 	.config = &cam_cc_pll0_config,
77 	.vco_table = lucid_ole_vco,
78 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
79 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
80 	.clkr = {
81 		.hw.init = &(const struct clk_init_data) {
82 			.name = "cam_cc_pll0",
83 			.parent_data = &(const struct clk_parent_data) {
84 				.index = DT_BI_TCXO,
85 			},
86 			.num_parents = 1,
87 			.ops = &clk_alpha_pll_lucid_evo_ops,
88 		},
89 	},
90 };
91 
92 static const struct clk_div_table post_div_table_cam_cc_pll0_out_even[] = {
93 	{ 0x1, 2 },
94 	{ }
95 };
96 
97 static struct clk_alpha_pll_postdiv cam_cc_pll0_out_even = {
98 	.offset = 0x0,
99 	.post_div_shift = 10,
100 	.post_div_table = post_div_table_cam_cc_pll0_out_even,
101 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll0_out_even),
102 	.width = 4,
103 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
104 	.clkr.hw.init = &(const struct clk_init_data) {
105 		.name = "cam_cc_pll0_out_even",
106 		.parent_hws = (const struct clk_hw*[]) {
107 			&cam_cc_pll0.clkr.hw,
108 		},
109 		.num_parents = 1,
110 		.flags = CLK_SET_RATE_PARENT,
111 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
112 	},
113 };
114 
115 static const struct clk_div_table post_div_table_cam_cc_pll0_out_odd[] = {
116 	{ 0x2, 3 },
117 	{ }
118 };
119 
120 static struct clk_alpha_pll_postdiv cam_cc_pll0_out_odd = {
121 	.offset = 0x0,
122 	.post_div_shift = 14,
123 	.post_div_table = post_div_table_cam_cc_pll0_out_odd,
124 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll0_out_odd),
125 	.width = 4,
126 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
127 	.clkr.hw.init = &(const struct clk_init_data) {
128 		.name = "cam_cc_pll0_out_odd",
129 		.parent_hws = (const struct clk_hw*[]) {
130 			&cam_cc_pll0.clkr.hw,
131 		},
132 		.num_parents = 1,
133 		.flags = CLK_SET_RATE_PARENT,
134 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
135 	},
136 };
137 
138 static const struct alpha_pll_config cam_cc_pll1_config = {
139 	.l = 0x2f,
140 	.alpha = 0x6555,
141 	.config_ctl_val = 0x20485699,
142 	.config_ctl_hi_val = 0x00182261,
143 	.config_ctl_hi1_val = 0x82aa299c,
144 	.test_ctl_val = 0x00000000,
145 	.test_ctl_hi_val = 0x00000003,
146 	.test_ctl_hi1_val = 0x00009000,
147 	.test_ctl_hi2_val = 0x00000034,
148 	.user_ctl_val = 0x00000400,
149 	.user_ctl_hi_val = 0x00000005,
150 };
151 
152 static struct clk_alpha_pll cam_cc_pll1 = {
153 	.offset = 0x1000,
154 	.config = &cam_cc_pll1_config,
155 	.vco_table = lucid_ole_vco,
156 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
157 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
158 	.clkr = {
159 		.hw.init = &(const struct clk_init_data) {
160 			.name = "cam_cc_pll1",
161 			.parent_data = &(const struct clk_parent_data) {
162 				.index = DT_BI_TCXO,
163 			},
164 			.num_parents = 1,
165 			.ops = &clk_alpha_pll_lucid_evo_ops,
166 		},
167 	},
168 };
169 
170 static const struct clk_div_table post_div_table_cam_cc_pll1_out_even[] = {
171 	{ 0x1, 2 },
172 	{ }
173 };
174 
175 static struct clk_alpha_pll_postdiv cam_cc_pll1_out_even = {
176 	.offset = 0x1000,
177 	.post_div_shift = 10,
178 	.post_div_table = post_div_table_cam_cc_pll1_out_even,
179 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll1_out_even),
180 	.width = 4,
181 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
182 	.clkr.hw.init = &(const struct clk_init_data) {
183 		.name = "cam_cc_pll1_out_even",
184 		.parent_hws = (const struct clk_hw*[]) {
185 			&cam_cc_pll1.clkr.hw,
186 		},
187 		.num_parents = 1,
188 		.flags = CLK_SET_RATE_PARENT,
189 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
190 	},
191 };
192 
193 static const struct alpha_pll_config cam_cc_pll2_config = {
194 	.l = 0x32,
195 	.alpha = 0x0,
196 	.config_ctl_val = 0x10000030,
197 	.config_ctl_hi_val = 0x80890263,
198 	.config_ctl_hi1_val = 0x00000217,
199 	.user_ctl_val = 0x00000000,
200 	.user_ctl_hi_val = 0x00100000,
201 };
202 
203 static struct clk_alpha_pll cam_cc_pll2 = {
204 	.offset = 0x2000,
205 	.config = &cam_cc_pll2_config,
206 	.vco_table = rivian_ole_vco,
207 	.num_vco = ARRAY_SIZE(rivian_ole_vco),
208 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_RIVIAN_EVO],
209 	.clkr = {
210 		.hw.init = &(const struct clk_init_data) {
211 			.name = "cam_cc_pll2",
212 			.parent_data = &(const struct clk_parent_data) {
213 				.index = DT_BI_TCXO,
214 			},
215 			.num_parents = 1,
216 			.ops = &clk_alpha_pll_rivian_evo_ops,
217 		},
218 	},
219 };
220 
221 static const struct alpha_pll_config cam_cc_pll3_config = {
222 	.l = 0x30,
223 	.alpha = 0x8aaa,
224 	.config_ctl_val = 0x20485699,
225 	.config_ctl_hi_val = 0x00182261,
226 	.config_ctl_hi1_val = 0x82aa299c,
227 	.test_ctl_val = 0x00000000,
228 	.test_ctl_hi_val = 0x00000003,
229 	.test_ctl_hi1_val = 0x00009000,
230 	.test_ctl_hi2_val = 0x00000034,
231 	.user_ctl_val = 0x00000400,
232 	.user_ctl_hi_val = 0x00000005,
233 };
234 
235 static struct clk_alpha_pll cam_cc_pll3 = {
236 	.offset = 0x3000,
237 	.config = &cam_cc_pll3_config,
238 	.vco_table = lucid_ole_vco,
239 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
240 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
241 	.clkr = {
242 		.hw.init = &(const struct clk_init_data) {
243 			.name = "cam_cc_pll3",
244 			.parent_data = &(const struct clk_parent_data) {
245 				.index = DT_BI_TCXO,
246 			},
247 			.num_parents = 1,
248 			.ops = &clk_alpha_pll_lucid_evo_ops,
249 		},
250 	},
251 };
252 
253 static const struct clk_div_table post_div_table_cam_cc_pll3_out_even[] = {
254 	{ 0x1, 2 },
255 	{ }
256 };
257 
258 static struct clk_alpha_pll_postdiv cam_cc_pll3_out_even = {
259 	.offset = 0x3000,
260 	.post_div_shift = 10,
261 	.post_div_table = post_div_table_cam_cc_pll3_out_even,
262 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll3_out_even),
263 	.width = 4,
264 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
265 	.clkr.hw.init = &(const struct clk_init_data) {
266 		.name = "cam_cc_pll3_out_even",
267 		.parent_hws = (const struct clk_hw*[]) {
268 			&cam_cc_pll3.clkr.hw,
269 		},
270 		.num_parents = 1,
271 		.flags = CLK_SET_RATE_PARENT,
272 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
273 	},
274 };
275 
276 static const struct alpha_pll_config cam_cc_pll4_config = {
277 	.l = 0x30,
278 	.alpha = 0x8aaa,
279 	.config_ctl_val = 0x20485699,
280 	.config_ctl_hi_val = 0x00182261,
281 	.config_ctl_hi1_val = 0x82aa299c,
282 	.test_ctl_val = 0x00000000,
283 	.test_ctl_hi_val = 0x00000003,
284 	.test_ctl_hi1_val = 0x00009000,
285 	.test_ctl_hi2_val = 0x00000034,
286 	.user_ctl_val = 0x00000400,
287 	.user_ctl_hi_val = 0x00000005,
288 };
289 
290 static struct clk_alpha_pll cam_cc_pll4 = {
291 	.offset = 0x4000,
292 	.config = &cam_cc_pll4_config,
293 	.vco_table = lucid_ole_vco,
294 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
295 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
296 	.clkr = {
297 		.hw.init = &(const struct clk_init_data) {
298 			.name = "cam_cc_pll4",
299 			.parent_data = &(const struct clk_parent_data) {
300 				.index = DT_BI_TCXO,
301 			},
302 			.num_parents = 1,
303 			.ops = &clk_alpha_pll_lucid_evo_ops,
304 		},
305 	},
306 };
307 
308 static const struct clk_div_table post_div_table_cam_cc_pll4_out_even[] = {
309 	{ 0x1, 2 },
310 	{ }
311 };
312 
313 static struct clk_alpha_pll_postdiv cam_cc_pll4_out_even = {
314 	.offset = 0x4000,
315 	.post_div_shift = 10,
316 	.post_div_table = post_div_table_cam_cc_pll4_out_even,
317 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll4_out_even),
318 	.width = 4,
319 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
320 	.clkr.hw.init = &(const struct clk_init_data) {
321 		.name = "cam_cc_pll4_out_even",
322 		.parent_hws = (const struct clk_hw*[]) {
323 			&cam_cc_pll4.clkr.hw,
324 		},
325 		.num_parents = 1,
326 		.flags = CLK_SET_RATE_PARENT,
327 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
328 	},
329 };
330 
331 static const struct alpha_pll_config cam_cc_pll5_config = {
332 	.l = 0x30,
333 	.alpha = 0x8aaa,
334 	.config_ctl_val = 0x20485699,
335 	.config_ctl_hi_val = 0x00182261,
336 	.config_ctl_hi1_val = 0x82aa299c,
337 	.test_ctl_val = 0x00000000,
338 	.test_ctl_hi_val = 0x00000003,
339 	.test_ctl_hi1_val = 0x00009000,
340 	.test_ctl_hi2_val = 0x00000034,
341 	.user_ctl_val = 0x00000400,
342 	.user_ctl_hi_val = 0x00000005,
343 };
344 
345 static struct clk_alpha_pll cam_cc_pll5 = {
346 	.offset = 0x5000,
347 	.config = &cam_cc_pll5_config,
348 	.vco_table = lucid_ole_vco,
349 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
350 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
351 	.clkr = {
352 		.hw.init = &(const struct clk_init_data) {
353 			.name = "cam_cc_pll5",
354 			.parent_data = &(const struct clk_parent_data) {
355 				.index = DT_BI_TCXO,
356 			},
357 			.num_parents = 1,
358 			.ops = &clk_alpha_pll_lucid_evo_ops,
359 		},
360 	},
361 };
362 
363 static const struct clk_div_table post_div_table_cam_cc_pll5_out_even[] = {
364 	{ 0x1, 2 },
365 	{ }
366 };
367 
368 static struct clk_alpha_pll_postdiv cam_cc_pll5_out_even = {
369 	.offset = 0x5000,
370 	.post_div_shift = 10,
371 	.post_div_table = post_div_table_cam_cc_pll5_out_even,
372 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll5_out_even),
373 	.width = 4,
374 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
375 	.clkr.hw.init = &(const struct clk_init_data) {
376 		.name = "cam_cc_pll5_out_even",
377 		.parent_hws = (const struct clk_hw*[]) {
378 			&cam_cc_pll5.clkr.hw,
379 		},
380 		.num_parents = 1,
381 		.flags = CLK_SET_RATE_PARENT,
382 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
383 	},
384 };
385 
386 static const struct alpha_pll_config cam_cc_pll6_config = {
387 	.l = 0x30,
388 	.alpha = 0x8aaa,
389 	.config_ctl_val = 0x20485699,
390 	.config_ctl_hi_val = 0x00182261,
391 	.config_ctl_hi1_val = 0x82aa299c,
392 	.test_ctl_val = 0x00000000,
393 	.test_ctl_hi_val = 0x00000003,
394 	.test_ctl_hi1_val = 0x00009000,
395 	.test_ctl_hi2_val = 0x00000034,
396 	.user_ctl_val = 0x00000400,
397 	.user_ctl_hi_val = 0x00000005,
398 };
399 
400 static struct clk_alpha_pll cam_cc_pll6 = {
401 	.offset = 0x6000,
402 	.config = &cam_cc_pll6_config,
403 	.vco_table = lucid_ole_vco,
404 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
405 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
406 	.clkr = {
407 		.hw.init = &(const struct clk_init_data) {
408 			.name = "cam_cc_pll6",
409 			.parent_data = &(const struct clk_parent_data) {
410 				.index = DT_BI_TCXO,
411 			},
412 			.num_parents = 1,
413 			.ops = &clk_alpha_pll_lucid_evo_ops,
414 		},
415 	},
416 };
417 
418 static const struct clk_div_table post_div_table_cam_cc_pll6_out_even[] = {
419 	{ 0x1, 2 },
420 	{ }
421 };
422 
423 static struct clk_alpha_pll_postdiv cam_cc_pll6_out_even = {
424 	.offset = 0x6000,
425 	.post_div_shift = 10,
426 	.post_div_table = post_div_table_cam_cc_pll6_out_even,
427 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll6_out_even),
428 	.width = 4,
429 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
430 	.clkr.hw.init = &(const struct clk_init_data) {
431 		.name = "cam_cc_pll6_out_even",
432 		.parent_hws = (const struct clk_hw*[]) {
433 			&cam_cc_pll6.clkr.hw,
434 		},
435 		.num_parents = 1,
436 		.flags = CLK_SET_RATE_PARENT,
437 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
438 	},
439 };
440 
441 static const struct alpha_pll_config cam_cc_pll7_config = {
442 	.l = 0x30,
443 	.alpha = 0x8aaa,
444 	.config_ctl_val = 0x20485699,
445 	.config_ctl_hi_val = 0x00182261,
446 	.config_ctl_hi1_val = 0x82aa299c,
447 	.test_ctl_val = 0x00000000,
448 	.test_ctl_hi_val = 0x00000003,
449 	.test_ctl_hi1_val = 0x00009000,
450 	.test_ctl_hi2_val = 0x00000034,
451 	.user_ctl_val = 0x00000400,
452 	.user_ctl_hi_val = 0x00000005,
453 };
454 
455 static struct clk_alpha_pll cam_cc_pll7 = {
456 	.offset = 0x7000,
457 	.config = &cam_cc_pll7_config,
458 	.vco_table = lucid_ole_vco,
459 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
460 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
461 	.clkr = {
462 		.hw.init = &(const struct clk_init_data) {
463 			.name = "cam_cc_pll7",
464 			.parent_data = &(const struct clk_parent_data) {
465 				.index = DT_BI_TCXO,
466 			},
467 			.num_parents = 1,
468 			.ops = &clk_alpha_pll_lucid_evo_ops,
469 		},
470 	},
471 };
472 
473 static const struct clk_div_table post_div_table_cam_cc_pll7_out_even[] = {
474 	{ 0x1, 2 },
475 	{ }
476 };
477 
478 static struct clk_alpha_pll_postdiv cam_cc_pll7_out_even = {
479 	.offset = 0x7000,
480 	.post_div_shift = 10,
481 	.post_div_table = post_div_table_cam_cc_pll7_out_even,
482 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll7_out_even),
483 	.width = 4,
484 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
485 	.clkr.hw.init = &(const struct clk_init_data) {
486 		.name = "cam_cc_pll7_out_even",
487 		.parent_hws = (const struct clk_hw*[]) {
488 			&cam_cc_pll7.clkr.hw,
489 		},
490 		.num_parents = 1,
491 		.flags = CLK_SET_RATE_PARENT,
492 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
493 	},
494 };
495 
496 static const struct alpha_pll_config cam_cc_pll8_config = {
497 	.l = 0x14,
498 	.alpha = 0xd555,
499 	.config_ctl_val = 0x20485699,
500 	.config_ctl_hi_val = 0x00182261,
501 	.config_ctl_hi1_val = 0x82aa299c,
502 	.test_ctl_val = 0x00000000,
503 	.test_ctl_hi_val = 0x00000003,
504 	.test_ctl_hi1_val = 0x00009000,
505 	.test_ctl_hi2_val = 0x00000034,
506 	.user_ctl_val = 0x00000400,
507 	.user_ctl_hi_val = 0x00000005,
508 };
509 
510 static struct clk_alpha_pll cam_cc_pll8 = {
511 	.offset = 0x8000,
512 	.config = &cam_cc_pll8_config,
513 	.vco_table = lucid_ole_vco,
514 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
515 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
516 	.clkr = {
517 		.hw.init = &(const struct clk_init_data) {
518 			.name = "cam_cc_pll8",
519 			.parent_data = &(const struct clk_parent_data) {
520 				.index = DT_BI_TCXO,
521 			},
522 			.num_parents = 1,
523 			.ops = &clk_alpha_pll_lucid_evo_ops,
524 		},
525 	},
526 };
527 
528 static const struct clk_div_table post_div_table_cam_cc_pll8_out_even[] = {
529 	{ 0x1, 2 },
530 	{ }
531 };
532 
533 static struct clk_alpha_pll_postdiv cam_cc_pll8_out_even = {
534 	.offset = 0x8000,
535 	.post_div_shift = 10,
536 	.post_div_table = post_div_table_cam_cc_pll8_out_even,
537 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll8_out_even),
538 	.width = 4,
539 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
540 	.clkr.hw.init = &(const struct clk_init_data) {
541 		.name = "cam_cc_pll8_out_even",
542 		.parent_hws = (const struct clk_hw*[]) {
543 			&cam_cc_pll8.clkr.hw,
544 		},
545 		.num_parents = 1,
546 		.flags = CLK_SET_RATE_PARENT,
547 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
548 	},
549 };
550 
551 static const struct alpha_pll_config cam_cc_pll9_config = {
552 	.l = 0x32,
553 	.alpha = 0x0,
554 	.config_ctl_val = 0x20485699,
555 	.config_ctl_hi_val = 0x00182261,
556 	.config_ctl_hi1_val = 0x82aa299c,
557 	.test_ctl_val = 0x00000000,
558 	.test_ctl_hi_val = 0x00000003,
559 	.test_ctl_hi1_val = 0x00009000,
560 	.test_ctl_hi2_val = 0x00000034,
561 	.user_ctl_val = 0x00000400,
562 	.user_ctl_hi_val = 0x00000005,
563 };
564 
565 static struct clk_alpha_pll cam_cc_pll9 = {
566 	.offset = 0x9000,
567 	.config = &cam_cc_pll9_config,
568 	.vco_table = lucid_ole_vco,
569 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
570 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
571 	.clkr = {
572 		.hw.init = &(const struct clk_init_data) {
573 			.name = "cam_cc_pll9",
574 			.parent_data = &(const struct clk_parent_data) {
575 				.index = DT_BI_TCXO,
576 			},
577 			.num_parents = 1,
578 			.ops = &clk_alpha_pll_lucid_evo_ops,
579 		},
580 	},
581 };
582 
583 static const struct clk_div_table post_div_table_cam_cc_pll9_out_even[] = {
584 	{ 0x1, 2 },
585 	{ }
586 };
587 
588 static struct clk_alpha_pll_postdiv cam_cc_pll9_out_even = {
589 	.offset = 0x9000,
590 	.post_div_shift = 10,
591 	.post_div_table = post_div_table_cam_cc_pll9_out_even,
592 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll9_out_even),
593 	.width = 4,
594 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
595 	.clkr.hw.init = &(const struct clk_init_data) {
596 		.name = "cam_cc_pll9_out_even",
597 		.parent_hws = (const struct clk_hw*[]) {
598 			&cam_cc_pll9.clkr.hw,
599 		},
600 		.num_parents = 1,
601 		.flags = CLK_SET_RATE_PARENT,
602 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
603 	},
604 };
605 
606 static const struct alpha_pll_config cam_cc_pll10_config = {
607 	.l = 0x30,
608 	.alpha = 0x8aaa,
609 	.config_ctl_val = 0x20485699,
610 	.config_ctl_hi_val = 0x00182261,
611 	.config_ctl_hi1_val = 0x82aa299c,
612 	.test_ctl_val = 0x00000000,
613 	.test_ctl_hi_val = 0x00000003,
614 	.test_ctl_hi1_val = 0x00009000,
615 	.test_ctl_hi2_val = 0x00000034,
616 	.user_ctl_val = 0x00000400,
617 	.user_ctl_hi_val = 0x00000005,
618 };
619 
620 static struct clk_alpha_pll cam_cc_pll10 = {
621 	.offset = 0xa000,
622 	.config = &cam_cc_pll10_config,
623 	.vco_table = lucid_ole_vco,
624 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
625 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
626 	.clkr = {
627 		.hw.init = &(const struct clk_init_data) {
628 			.name = "cam_cc_pll10",
629 			.parent_data = &(const struct clk_parent_data) {
630 				.index = DT_BI_TCXO,
631 			},
632 			.num_parents = 1,
633 			.ops = &clk_alpha_pll_lucid_evo_ops,
634 		},
635 	},
636 };
637 
638 static const struct clk_div_table post_div_table_cam_cc_pll10_out_even[] = {
639 	{ 0x1, 2 },
640 	{ }
641 };
642 
643 static struct clk_alpha_pll_postdiv cam_cc_pll10_out_even = {
644 	.offset = 0xa000,
645 	.post_div_shift = 10,
646 	.post_div_table = post_div_table_cam_cc_pll10_out_even,
647 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll10_out_even),
648 	.width = 4,
649 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
650 	.clkr.hw.init = &(const struct clk_init_data) {
651 		.name = "cam_cc_pll10_out_even",
652 		.parent_hws = (const struct clk_hw*[]) {
653 			&cam_cc_pll10.clkr.hw,
654 		},
655 		.num_parents = 1,
656 		.flags = CLK_SET_RATE_PARENT,
657 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
658 	},
659 };
660 
661 static const struct alpha_pll_config cam_cc_pll11_config = {
662 	.l = 0x30,
663 	.alpha = 0x8aaa,
664 	.config_ctl_val = 0x20485699,
665 	.config_ctl_hi_val = 0x00182261,
666 	.config_ctl_hi1_val = 0x82aa299c,
667 	.test_ctl_val = 0x00000000,
668 	.test_ctl_hi_val = 0x00000003,
669 	.test_ctl_hi1_val = 0x00009000,
670 	.test_ctl_hi2_val = 0x00000034,
671 	.user_ctl_val = 0x00000400,
672 	.user_ctl_hi_val = 0x00000005,
673 };
674 
675 static struct clk_alpha_pll cam_cc_pll11 = {
676 	.offset = 0xb000,
677 	.config = &cam_cc_pll11_config,
678 	.vco_table = lucid_ole_vco,
679 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
680 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
681 	.clkr = {
682 		.hw.init = &(const struct clk_init_data) {
683 			.name = "cam_cc_pll11",
684 			.parent_data = &(const struct clk_parent_data) {
685 				.index = DT_BI_TCXO,
686 			},
687 			.num_parents = 1,
688 			.ops = &clk_alpha_pll_lucid_evo_ops,
689 		},
690 	},
691 };
692 
693 static const struct clk_div_table post_div_table_cam_cc_pll11_out_even[] = {
694 	{ 0x1, 2 },
695 	{ }
696 };
697 
698 static struct clk_alpha_pll_postdiv cam_cc_pll11_out_even = {
699 	.offset = 0xb000,
700 	.post_div_shift = 10,
701 	.post_div_table = post_div_table_cam_cc_pll11_out_even,
702 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll11_out_even),
703 	.width = 4,
704 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
705 	.clkr.hw.init = &(const struct clk_init_data) {
706 		.name = "cam_cc_pll11_out_even",
707 		.parent_hws = (const struct clk_hw*[]) {
708 			&cam_cc_pll11.clkr.hw,
709 		},
710 		.num_parents = 1,
711 		.flags = CLK_SET_RATE_PARENT,
712 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
713 	},
714 };
715 
716 static const struct alpha_pll_config cam_cc_pll12_config = {
717 	.l = 0x30,
718 	.alpha = 0x8aaa,
719 	.config_ctl_val = 0x20485699,
720 	.config_ctl_hi_val = 0x00182261,
721 	.config_ctl_hi1_val = 0x82aa299c,
722 	.test_ctl_val = 0x00000000,
723 	.test_ctl_hi_val = 0x00000003,
724 	.test_ctl_hi1_val = 0x00009000,
725 	.test_ctl_hi2_val = 0x00000034,
726 	.user_ctl_val = 0x00000400,
727 	.user_ctl_hi_val = 0x00000005,
728 };
729 
730 static struct clk_alpha_pll cam_cc_pll12 = {
731 	.offset = 0xc000,
732 	.config = &cam_cc_pll12_config,
733 	.vco_table = lucid_ole_vco,
734 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
735 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
736 	.clkr = {
737 		.hw.init = &(const struct clk_init_data) {
738 			.name = "cam_cc_pll12",
739 			.parent_data = &(const struct clk_parent_data) {
740 				.index = DT_BI_TCXO,
741 			},
742 			.num_parents = 1,
743 			.ops = &clk_alpha_pll_lucid_evo_ops,
744 		},
745 	},
746 };
747 
748 static const struct clk_div_table post_div_table_cam_cc_pll12_out_even[] = {
749 	{ 0x1, 2 },
750 	{ }
751 };
752 
753 static struct clk_alpha_pll_postdiv cam_cc_pll12_out_even = {
754 	.offset = 0xc000,
755 	.post_div_shift = 10,
756 	.post_div_table = post_div_table_cam_cc_pll12_out_even,
757 	.num_post_div = ARRAY_SIZE(post_div_table_cam_cc_pll12_out_even),
758 	.width = 4,
759 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
760 	.clkr.hw.init = &(const struct clk_init_data) {
761 		.name = "cam_cc_pll12_out_even",
762 		.parent_hws = (const struct clk_hw*[]) {
763 			&cam_cc_pll12.clkr.hw,
764 		},
765 		.num_parents = 1,
766 		.flags = CLK_SET_RATE_PARENT,
767 		.ops = &clk_alpha_pll_postdiv_lucid_ole_ops,
768 	},
769 };
770 
771 static const struct parent_map cam_cc_parent_map_0[] = {
772 	{ P_BI_TCXO, 0 },
773 	{ P_CAM_CC_PLL0_OUT_MAIN, 1 },
774 	{ P_CAM_CC_PLL0_OUT_EVEN, 2 },
775 	{ P_CAM_CC_PLL0_OUT_ODD, 3 },
776 	{ P_CAM_CC_PLL9_OUT_ODD, 4 },
777 	{ P_CAM_CC_PLL9_OUT_EVEN, 5 },
778 };
779 
780 static const struct clk_parent_data cam_cc_parent_data_0[] = {
781 	{ .index = DT_BI_TCXO },
782 	{ .hw = &cam_cc_pll0.clkr.hw },
783 	{ .hw = &cam_cc_pll0_out_even.clkr.hw },
784 	{ .hw = &cam_cc_pll0_out_odd.clkr.hw },
785 	{ .hw = &cam_cc_pll9.clkr.hw },
786 	{ .hw = &cam_cc_pll9_out_even.clkr.hw },
787 };
788 
789 static const struct parent_map cam_cc_parent_map_1[] = {
790 	{ P_BI_TCXO, 0 },
791 	{ P_CAM_CC_PLL2_OUT_EVEN, 3 },
792 	{ P_CAM_CC_PLL2_OUT_MAIN, 5 },
793 };
794 
795 static const struct clk_parent_data cam_cc_parent_data_1[] = {
796 	{ .index = DT_BI_TCXO },
797 	{ .hw = &cam_cc_pll2.clkr.hw },
798 	{ .hw = &cam_cc_pll2.clkr.hw },
799 };
800 
801 static const struct parent_map cam_cc_parent_map_2[] = {
802 	{ P_BI_TCXO, 0 },
803 	{ P_CAM_CC_PLL8_OUT_EVEN, 6 },
804 };
805 
806 static const struct clk_parent_data cam_cc_parent_data_2[] = {
807 	{ .index = DT_BI_TCXO },
808 	{ .hw = &cam_cc_pll8_out_even.clkr.hw },
809 };
810 
811 static const struct parent_map cam_cc_parent_map_3[] = {
812 	{ P_BI_TCXO, 0 },
813 	{ P_CAM_CC_PLL3_OUT_EVEN, 6 },
814 };
815 
816 static const struct clk_parent_data cam_cc_parent_data_3[] = {
817 	{ .index = DT_BI_TCXO },
818 	{ .hw = &cam_cc_pll3_out_even.clkr.hw },
819 };
820 
821 static const struct parent_map cam_cc_parent_map_4[] = {
822 	{ P_BI_TCXO, 0 },
823 	{ P_CAM_CC_PLL10_OUT_EVEN, 6 },
824 };
825 
826 static const struct clk_parent_data cam_cc_parent_data_4[] = {
827 	{ .index = DT_BI_TCXO },
828 	{ .hw = &cam_cc_pll10_out_even.clkr.hw },
829 };
830 
831 static const struct parent_map cam_cc_parent_map_5[] = {
832 	{ P_BI_TCXO, 0 },
833 	{ P_CAM_CC_PLL4_OUT_EVEN, 6 },
834 };
835 
836 static const struct clk_parent_data cam_cc_parent_data_5[] = {
837 	{ .index = DT_BI_TCXO },
838 	{ .hw = &cam_cc_pll4_out_even.clkr.hw },
839 };
840 
841 static const struct parent_map cam_cc_parent_map_6[] = {
842 	{ P_BI_TCXO, 0 },
843 	{ P_CAM_CC_PLL11_OUT_EVEN, 6 },
844 };
845 
846 static const struct clk_parent_data cam_cc_parent_data_6[] = {
847 	{ .index = DT_BI_TCXO },
848 	{ .hw = &cam_cc_pll11_out_even.clkr.hw },
849 };
850 
851 static const struct parent_map cam_cc_parent_map_7[] = {
852 	{ P_BI_TCXO, 0 },
853 	{ P_CAM_CC_PLL5_OUT_EVEN, 6 },
854 };
855 
856 static const struct clk_parent_data cam_cc_parent_data_7[] = {
857 	{ .index = DT_BI_TCXO },
858 	{ .hw = &cam_cc_pll5_out_even.clkr.hw },
859 };
860 
861 static const struct parent_map cam_cc_parent_map_8[] = {
862 	{ P_BI_TCXO, 0 },
863 	{ P_CAM_CC_PLL12_OUT_EVEN, 6 },
864 };
865 
866 static const struct clk_parent_data cam_cc_parent_data_8[] = {
867 	{ .index = DT_BI_TCXO },
868 	{ .hw = &cam_cc_pll12_out_even.clkr.hw },
869 };
870 
871 static const struct parent_map cam_cc_parent_map_9[] = {
872 	{ P_BI_TCXO, 0 },
873 	{ P_CAM_CC_PLL1_OUT_EVEN, 4 },
874 };
875 
876 static const struct clk_parent_data cam_cc_parent_data_9[] = {
877 	{ .index = DT_BI_TCXO },
878 	{ .hw = &cam_cc_pll1_out_even.clkr.hw },
879 };
880 
881 static const struct parent_map cam_cc_parent_map_10[] = {
882 	{ P_BI_TCXO, 0 },
883 	{ P_CAM_CC_PLL6_OUT_EVEN, 6 },
884 };
885 
886 static const struct clk_parent_data cam_cc_parent_data_10[] = {
887 	{ .index = DT_BI_TCXO },
888 	{ .hw = &cam_cc_pll6_out_even.clkr.hw },
889 };
890 
891 static const struct parent_map cam_cc_parent_map_11[] = {
892 	{ P_BI_TCXO, 0 },
893 	{ P_CAM_CC_PLL7_OUT_EVEN, 6 },
894 };
895 
896 static const struct clk_parent_data cam_cc_parent_data_11[] = {
897 	{ .index = DT_BI_TCXO },
898 	{ .hw = &cam_cc_pll7_out_even.clkr.hw },
899 };
900 
901 static const struct parent_map cam_cc_parent_map_12[] = {
902 	{ P_SLEEP_CLK, 0 },
903 };
904 
905 static const struct clk_parent_data cam_cc_parent_data_12[] = {
906 	{ .index = DT_SLEEP_CLK },
907 };
908 
909 static const struct parent_map cam_cc_parent_map_13_ao[] = {
910 	{ P_BI_TCXO_AO, 0 },
911 };
912 
913 static const struct clk_parent_data cam_cc_parent_data_13_ao[] = {
914 	{ .index = DT_BI_TCXO_AO },
915 };
916 
917 static const struct freq_tbl ftbl_cam_cc_bps_clk_src[] = {
918 	F(19200000, P_BI_TCXO, 1, 0, 0),
919 	F(200000000, P_CAM_CC_PLL8_OUT_EVEN, 1, 0, 0),
920 	F(400000000, P_CAM_CC_PLL8_OUT_EVEN, 1, 0, 0),
921 	F(480000000, P_CAM_CC_PLL8_OUT_EVEN, 1, 0, 0),
922 	F(785000000, P_CAM_CC_PLL8_OUT_EVEN, 1, 0, 0),
923 	{ }
924 };
925 
926 static struct clk_rcg2 cam_cc_bps_clk_src = {
927 	.cmd_rcgr = 0x10278,
928 	.mnd_width = 0,
929 	.hid_width = 5,
930 	.parent_map = cam_cc_parent_map_2,
931 	.freq_tbl = ftbl_cam_cc_bps_clk_src,
932 	.clkr.hw.init = &(const struct clk_init_data) {
933 		.name = "cam_cc_bps_clk_src",
934 		.parent_data = cam_cc_parent_data_2,
935 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_2),
936 		.flags = CLK_SET_RATE_PARENT,
937 		.ops = &clk_rcg2_shared_ops,
938 	},
939 };
940 
941 static const struct freq_tbl ftbl_cam_cc_camnoc_axi_clk_src[] = {
942 	F(19200000, P_BI_TCXO, 1, 0, 0),
943 	F(300000000, P_CAM_CC_PLL0_OUT_EVEN, 2, 0, 0),
944 	F(400000000, P_CAM_CC_PLL0_OUT_ODD, 1, 0, 0),
945 	{ }
946 };
947 
948 static struct clk_rcg2 cam_cc_camnoc_axi_clk_src = {
949 	.cmd_rcgr = 0x13de0,
950 	.mnd_width = 0,
951 	.hid_width = 5,
952 	.parent_map = cam_cc_parent_map_0,
953 	.freq_tbl = ftbl_cam_cc_camnoc_axi_clk_src,
954 	.clkr.hw.init = &(const struct clk_init_data) {
955 		.name = "cam_cc_camnoc_axi_clk_src",
956 		.parent_data = cam_cc_parent_data_0,
957 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
958 		.flags = CLK_SET_RATE_PARENT,
959 		.ops = &clk_rcg2_shared_ops,
960 	},
961 };
962 
963 static const struct freq_tbl ftbl_cam_cc_cci_0_clk_src[] = {
964 	F(19200000, P_BI_TCXO, 1, 0, 0),
965 	F(37500000, P_CAM_CC_PLL0_OUT_EVEN, 16, 0, 0),
966 	{ }
967 };
968 
969 static struct clk_rcg2 cam_cc_cci_0_clk_src = {
970 	.cmd_rcgr = 0x13900,
971 	.mnd_width = 8,
972 	.hid_width = 5,
973 	.parent_map = cam_cc_parent_map_0,
974 	.freq_tbl = ftbl_cam_cc_cci_0_clk_src,
975 	.clkr.hw.init = &(const struct clk_init_data) {
976 		.name = "cam_cc_cci_0_clk_src",
977 		.parent_data = cam_cc_parent_data_0,
978 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
979 		.flags = CLK_SET_RATE_PARENT,
980 		.ops = &clk_rcg2_shared_ops,
981 	},
982 };
983 
984 static struct clk_rcg2 cam_cc_cci_1_clk_src = {
985 	.cmd_rcgr = 0x13a30,
986 	.mnd_width = 8,
987 	.hid_width = 5,
988 	.parent_map = cam_cc_parent_map_0,
989 	.freq_tbl = ftbl_cam_cc_cci_0_clk_src,
990 	.clkr.hw.init = &(const struct clk_init_data) {
991 		.name = "cam_cc_cci_1_clk_src",
992 		.parent_data = cam_cc_parent_data_0,
993 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
994 		.flags = CLK_SET_RATE_PARENT,
995 		.ops = &clk_rcg2_shared_ops,
996 	},
997 };
998 
999 static struct clk_rcg2 cam_cc_cci_2_clk_src = {
1000 	.cmd_rcgr = 0x13b60,
1001 	.mnd_width = 8,
1002 	.hid_width = 5,
1003 	.parent_map = cam_cc_parent_map_0,
1004 	.freq_tbl = ftbl_cam_cc_cci_0_clk_src,
1005 	.clkr.hw.init = &(const struct clk_init_data) {
1006 		.name = "cam_cc_cci_2_clk_src",
1007 		.parent_data = cam_cc_parent_data_0,
1008 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1009 		.flags = CLK_SET_RATE_PARENT,
1010 		.ops = &clk_rcg2_shared_ops,
1011 	},
1012 };
1013 
1014 static const struct freq_tbl ftbl_cam_cc_cphy_rx_clk_src[] = {
1015 	F(19200000, P_BI_TCXO, 1, 0, 0),
1016 	F(400000000, P_CAM_CC_PLL0_OUT_MAIN, 3, 0, 0),
1017 	F(480000000, P_CAM_CC_PLL0_OUT_MAIN, 2.5, 0, 0),
1018 	{ }
1019 };
1020 
1021 static struct clk_rcg2 cam_cc_cphy_rx_clk_src = {
1022 	.cmd_rcgr = 0x11290,
1023 	.mnd_width = 0,
1024 	.hid_width = 5,
1025 	.parent_map = cam_cc_parent_map_0,
1026 	.freq_tbl = ftbl_cam_cc_cphy_rx_clk_src,
1027 	.clkr.hw.init = &(const struct clk_init_data) {
1028 		.name = "cam_cc_cphy_rx_clk_src",
1029 		.parent_data = cam_cc_parent_data_0,
1030 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1031 		.flags = CLK_SET_RATE_PARENT,
1032 		.ops = &clk_rcg2_shared_ops,
1033 	},
1034 };
1035 
1036 static const struct freq_tbl ftbl_cam_cc_cre_clk_src[] = {
1037 	F(200000000, P_CAM_CC_PLL0_OUT_ODD, 2, 0, 0),
1038 	F(400000000, P_CAM_CC_PLL0_OUT_ODD, 1, 0, 0),
1039 	F(480000000, P_CAM_CC_PLL9_OUT_EVEN, 1, 0, 0),
1040 	F(600000000, P_CAM_CC_PLL0_OUT_EVEN, 1, 0, 0),
1041 	{ }
1042 };
1043 
1044 static struct clk_rcg2 cam_cc_cre_clk_src = {
1045 	.cmd_rcgr = 0x1353c,
1046 	.mnd_width = 0,
1047 	.hid_width = 5,
1048 	.parent_map = cam_cc_parent_map_0,
1049 	.freq_tbl = ftbl_cam_cc_cre_clk_src,
1050 	.clkr.hw.init = &(const struct clk_init_data) {
1051 		.name = "cam_cc_cre_clk_src",
1052 		.parent_data = cam_cc_parent_data_0,
1053 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1054 		.flags = CLK_SET_RATE_PARENT,
1055 		.ops = &clk_rcg2_shared_ops,
1056 	},
1057 };
1058 
1059 static const struct freq_tbl ftbl_cam_cc_csi0phytimer_clk_src[] = {
1060 	F(19200000, P_BI_TCXO, 1, 0, 0),
1061 	F(400000000, P_CAM_CC_PLL0_OUT_EVEN, 1.5, 0, 0),
1062 	{ }
1063 };
1064 
1065 static struct clk_rcg2 cam_cc_csi0phytimer_clk_src = {
1066 	.cmd_rcgr = 0x15980,
1067 	.mnd_width = 0,
1068 	.hid_width = 5,
1069 	.parent_map = cam_cc_parent_map_0,
1070 	.freq_tbl = ftbl_cam_cc_csi0phytimer_clk_src,
1071 	.clkr.hw.init = &(const struct clk_init_data) {
1072 		.name = "cam_cc_csi0phytimer_clk_src",
1073 		.parent_data = cam_cc_parent_data_0,
1074 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1075 		.flags = CLK_SET_RATE_PARENT,
1076 		.ops = &clk_rcg2_shared_ops,
1077 	},
1078 };
1079 
1080 static struct clk_rcg2 cam_cc_csi1phytimer_clk_src = {
1081 	.cmd_rcgr = 0x15ab8,
1082 	.mnd_width = 0,
1083 	.hid_width = 5,
1084 	.parent_map = cam_cc_parent_map_0,
1085 	.freq_tbl = ftbl_cam_cc_csi0phytimer_clk_src,
1086 	.clkr.hw.init = &(const struct clk_init_data) {
1087 		.name = "cam_cc_csi1phytimer_clk_src",
1088 		.parent_data = cam_cc_parent_data_0,
1089 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1090 		.flags = CLK_SET_RATE_PARENT,
1091 		.ops = &clk_rcg2_shared_ops,
1092 	},
1093 };
1094 
1095 static struct clk_rcg2 cam_cc_csi2phytimer_clk_src = {
1096 	.cmd_rcgr = 0x15bec,
1097 	.mnd_width = 0,
1098 	.hid_width = 5,
1099 	.parent_map = cam_cc_parent_map_0,
1100 	.freq_tbl = ftbl_cam_cc_csi0phytimer_clk_src,
1101 	.clkr.hw.init = &(const struct clk_init_data) {
1102 		.name = "cam_cc_csi2phytimer_clk_src",
1103 		.parent_data = cam_cc_parent_data_0,
1104 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1105 		.flags = CLK_SET_RATE_PARENT,
1106 		.ops = &clk_rcg2_shared_ops,
1107 	},
1108 };
1109 
1110 static struct clk_rcg2 cam_cc_csi3phytimer_clk_src = {
1111 	.cmd_rcgr = 0x15d20,
1112 	.mnd_width = 0,
1113 	.hid_width = 5,
1114 	.parent_map = cam_cc_parent_map_0,
1115 	.freq_tbl = ftbl_cam_cc_csi0phytimer_clk_src,
1116 	.clkr.hw.init = &(const struct clk_init_data) {
1117 		.name = "cam_cc_csi3phytimer_clk_src",
1118 		.parent_data = cam_cc_parent_data_0,
1119 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1120 		.flags = CLK_SET_RATE_PARENT,
1121 		.ops = &clk_rcg2_shared_ops,
1122 	},
1123 };
1124 
1125 static const struct freq_tbl ftbl_cam_cc_csi4phytimer_clk_src[] = {
1126 	F(19200000, P_BI_TCXO, 1, 0, 0),
1127 	F(400000000, P_CAM_CC_PLL0_OUT_ODD, 1, 0, 0),
1128 	{ }
1129 };
1130 
1131 static struct clk_rcg2 cam_cc_csi4phytimer_clk_src = {
1132 	.cmd_rcgr = 0x15e54,
1133 	.mnd_width = 0,
1134 	.hid_width = 5,
1135 	.parent_map = cam_cc_parent_map_0,
1136 	.freq_tbl = ftbl_cam_cc_csi4phytimer_clk_src,
1137 	.clkr.hw.init = &(const struct clk_init_data) {
1138 		.name = "cam_cc_csi4phytimer_clk_src",
1139 		.parent_data = cam_cc_parent_data_0,
1140 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1141 		.flags = CLK_SET_RATE_PARENT,
1142 		.ops = &clk_rcg2_shared_ops,
1143 	},
1144 };
1145 
1146 static struct clk_rcg2 cam_cc_csi5phytimer_clk_src = {
1147 	.cmd_rcgr = 0x15f88,
1148 	.mnd_width = 0,
1149 	.hid_width = 5,
1150 	.parent_map = cam_cc_parent_map_0,
1151 	.freq_tbl = ftbl_cam_cc_csi0phytimer_clk_src,
1152 	.clkr.hw.init = &(const struct clk_init_data) {
1153 		.name = "cam_cc_csi5phytimer_clk_src",
1154 		.parent_data = cam_cc_parent_data_0,
1155 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1156 		.flags = CLK_SET_RATE_PARENT,
1157 		.ops = &clk_rcg2_shared_ops,
1158 	},
1159 };
1160 
1161 static struct clk_rcg2 cam_cc_csi6phytimer_clk_src = {
1162 	.cmd_rcgr = 0x160bc,
1163 	.mnd_width = 0,
1164 	.hid_width = 5,
1165 	.parent_map = cam_cc_parent_map_0,
1166 	.freq_tbl = ftbl_cam_cc_csi0phytimer_clk_src,
1167 	.clkr.hw.init = &(const struct clk_init_data) {
1168 		.name = "cam_cc_csi6phytimer_clk_src",
1169 		.parent_data = cam_cc_parent_data_0,
1170 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1171 		.flags = CLK_SET_RATE_PARENT,
1172 		.ops = &clk_rcg2_shared_ops,
1173 	},
1174 };
1175 
1176 static struct clk_rcg2 cam_cc_csi7phytimer_clk_src = {
1177 	.cmd_rcgr = 0x161f0,
1178 	.mnd_width = 0,
1179 	.hid_width = 5,
1180 	.parent_map = cam_cc_parent_map_0,
1181 	.freq_tbl = ftbl_cam_cc_csi0phytimer_clk_src,
1182 	.clkr.hw.init = &(const struct clk_init_data) {
1183 		.name = "cam_cc_csi7phytimer_clk_src",
1184 		.parent_data = cam_cc_parent_data_0,
1185 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1186 		.flags = CLK_SET_RATE_PARENT,
1187 		.ops = &clk_rcg2_shared_ops,
1188 	},
1189 };
1190 
1191 static const struct freq_tbl ftbl_cam_cc_csid_clk_src[] = {
1192 	F(400000000, P_CAM_CC_PLL0_OUT_MAIN, 3, 0, 0),
1193 	F(480000000, P_CAM_CC_PLL0_OUT_MAIN, 2.5, 0, 0),
1194 	{ }
1195 };
1196 
1197 static struct clk_rcg2 cam_cc_csid_clk_src = {
1198 	.cmd_rcgr = 0x13ca8,
1199 	.mnd_width = 0,
1200 	.hid_width = 5,
1201 	.parent_map = cam_cc_parent_map_0,
1202 	.freq_tbl = ftbl_cam_cc_csid_clk_src,
1203 	.clkr.hw.init = &(const struct clk_init_data) {
1204 		.name = "cam_cc_csid_clk_src",
1205 		.parent_data = cam_cc_parent_data_0,
1206 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1207 		.flags = CLK_SET_RATE_PARENT,
1208 		.ops = &clk_rcg2_shared_ops,
1209 	},
1210 };
1211 
1212 static const struct freq_tbl ftbl_cam_cc_fast_ahb_clk_src[] = {
1213 	F(19200000, P_BI_TCXO, 1, 0, 0),
1214 	F(300000000, P_CAM_CC_PLL0_OUT_EVEN, 2, 0, 0),
1215 	F(400000000, P_CAM_CC_PLL0_OUT_MAIN, 3, 0, 0),
1216 	{ }
1217 };
1218 
1219 static struct clk_rcg2 cam_cc_fast_ahb_clk_src = {
1220 	.cmd_rcgr = 0x10018,
1221 	.mnd_width = 0,
1222 	.hid_width = 5,
1223 	.parent_map = cam_cc_parent_map_0,
1224 	.freq_tbl = ftbl_cam_cc_fast_ahb_clk_src,
1225 	.clkr.hw.init = &(const struct clk_init_data) {
1226 		.name = "cam_cc_fast_ahb_clk_src",
1227 		.parent_data = cam_cc_parent_data_0,
1228 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1229 		.flags = CLK_SET_RATE_PARENT,
1230 		.ops = &clk_rcg2_shared_ops,
1231 	},
1232 };
1233 
1234 static const struct freq_tbl ftbl_cam_cc_icp_clk_src[] = {
1235 	F(19200000, P_BI_TCXO, 1, 0, 0),
1236 	F(400000000, P_CAM_CC_PLL0_OUT_ODD, 1, 0, 0),
1237 	F(480000000, P_CAM_CC_PLL9_OUT_EVEN, 1, 0, 0),
1238 	F(600000000, P_CAM_CC_PLL0_OUT_MAIN, 2, 0, 0),
1239 	{ }
1240 };
1241 
1242 static struct clk_rcg2 cam_cc_icp_clk_src = {
1243 	.cmd_rcgr = 0x137c4,
1244 	.mnd_width = 0,
1245 	.hid_width = 5,
1246 	.parent_map = cam_cc_parent_map_0,
1247 	.freq_tbl = ftbl_cam_cc_icp_clk_src,
1248 	.clkr.hw.init = &(const struct clk_init_data) {
1249 		.name = "cam_cc_icp_clk_src",
1250 		.parent_data = cam_cc_parent_data_0,
1251 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1252 		.flags = CLK_SET_RATE_PARENT,
1253 		.ops = &clk_rcg2_shared_ops,
1254 	},
1255 };
1256 
1257 static const struct freq_tbl ftbl_cam_cc_ife_0_clk_src[] = {
1258 	F(19200000, P_BI_TCXO, 1, 0, 0),
1259 	F(466000000, P_CAM_CC_PLL3_OUT_EVEN, 1, 0, 0),
1260 	F(594000000, P_CAM_CC_PLL3_OUT_EVEN, 1, 0, 0),
1261 	F(675000000, P_CAM_CC_PLL3_OUT_EVEN, 1, 0, 0),
1262 	F(785000000, P_CAM_CC_PLL3_OUT_EVEN, 1, 0, 0),
1263 	{ }
1264 };
1265 
1266 static struct clk_rcg2 cam_cc_ife_0_clk_src = {
1267 	.cmd_rcgr = 0x11018,
1268 	.mnd_width = 0,
1269 	.hid_width = 5,
1270 	.parent_map = cam_cc_parent_map_3,
1271 	.freq_tbl = ftbl_cam_cc_ife_0_clk_src,
1272 	.clkr.hw.init = &(const struct clk_init_data) {
1273 		.name = "cam_cc_ife_0_clk_src",
1274 		.parent_data = cam_cc_parent_data_3,
1275 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_3),
1276 		.flags = CLK_SET_RATE_PARENT,
1277 		.ops = &clk_rcg2_shared_ops,
1278 	},
1279 };
1280 
1281 static const struct freq_tbl ftbl_cam_cc_ife_0_dsp_clk_src[] = {
1282 	F(466000000, P_CAM_CC_PLL10_OUT_EVEN, 1, 0, 0),
1283 	F(594000000, P_CAM_CC_PLL10_OUT_EVEN, 1, 0, 0),
1284 	F(675000000, P_CAM_CC_PLL10_OUT_EVEN, 1, 0, 0),
1285 	F(785000000, P_CAM_CC_PLL10_OUT_EVEN, 1, 0, 0),
1286 	{ }
1287 };
1288 
1289 static struct clk_rcg2 cam_cc_ife_0_dsp_clk_src = {
1290 	.cmd_rcgr = 0x11154,
1291 	.mnd_width = 0,
1292 	.hid_width = 5,
1293 	.parent_map = cam_cc_parent_map_4,
1294 	.freq_tbl = ftbl_cam_cc_ife_0_dsp_clk_src,
1295 	.clkr.hw.init = &(const struct clk_init_data) {
1296 		.name = "cam_cc_ife_0_dsp_clk_src",
1297 		.parent_data = cam_cc_parent_data_4,
1298 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_4),
1299 		.flags = CLK_SET_RATE_PARENT,
1300 		.ops = &clk_rcg2_shared_ops,
1301 	},
1302 };
1303 
1304 static const struct freq_tbl ftbl_cam_cc_ife_1_clk_src[] = {
1305 	F(19200000, P_BI_TCXO, 1, 0, 0),
1306 	F(466000000, P_CAM_CC_PLL4_OUT_EVEN, 1, 0, 0),
1307 	F(594000000, P_CAM_CC_PLL4_OUT_EVEN, 1, 0, 0),
1308 	F(675000000, P_CAM_CC_PLL4_OUT_EVEN, 1, 0, 0),
1309 	F(785000000, P_CAM_CC_PLL4_OUT_EVEN, 1, 0, 0),
1310 	{ }
1311 };
1312 
1313 static struct clk_rcg2 cam_cc_ife_1_clk_src = {
1314 	.cmd_rcgr = 0x12018,
1315 	.mnd_width = 0,
1316 	.hid_width = 5,
1317 	.parent_map = cam_cc_parent_map_5,
1318 	.freq_tbl = ftbl_cam_cc_ife_1_clk_src,
1319 	.clkr.hw.init = &(const struct clk_init_data) {
1320 		.name = "cam_cc_ife_1_clk_src",
1321 		.parent_data = cam_cc_parent_data_5,
1322 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_5),
1323 		.flags = CLK_SET_RATE_PARENT,
1324 		.ops = &clk_rcg2_shared_ops,
1325 	},
1326 };
1327 
1328 static const struct freq_tbl ftbl_cam_cc_ife_1_dsp_clk_src[] = {
1329 	F(466000000, P_CAM_CC_PLL11_OUT_EVEN, 1, 0, 0),
1330 	F(594000000, P_CAM_CC_PLL11_OUT_EVEN, 1, 0, 0),
1331 	F(675000000, P_CAM_CC_PLL11_OUT_EVEN, 1, 0, 0),
1332 	F(785000000, P_CAM_CC_PLL11_OUT_EVEN, 1, 0, 0),
1333 	{ }
1334 };
1335 
1336 static struct clk_rcg2 cam_cc_ife_1_dsp_clk_src = {
1337 	.cmd_rcgr = 0x12154,
1338 	.mnd_width = 0,
1339 	.hid_width = 5,
1340 	.parent_map = cam_cc_parent_map_6,
1341 	.freq_tbl = ftbl_cam_cc_ife_1_dsp_clk_src,
1342 	.clkr.hw.init = &(const struct clk_init_data) {
1343 		.name = "cam_cc_ife_1_dsp_clk_src",
1344 		.parent_data = cam_cc_parent_data_6,
1345 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_6),
1346 		.flags = CLK_SET_RATE_PARENT,
1347 		.ops = &clk_rcg2_shared_ops,
1348 	},
1349 };
1350 
1351 static const struct freq_tbl ftbl_cam_cc_ife_2_clk_src[] = {
1352 	F(466000000, P_CAM_CC_PLL5_OUT_EVEN, 1, 0, 0),
1353 	F(594000000, P_CAM_CC_PLL5_OUT_EVEN, 1, 0, 0),
1354 	F(675000000, P_CAM_CC_PLL5_OUT_EVEN, 1, 0, 0),
1355 	F(785000000, P_CAM_CC_PLL5_OUT_EVEN, 1, 0, 0),
1356 	{ }
1357 };
1358 
1359 static struct clk_rcg2 cam_cc_ife_2_clk_src = {
1360 	.cmd_rcgr = 0x122a8,
1361 	.mnd_width = 0,
1362 	.hid_width = 5,
1363 	.parent_map = cam_cc_parent_map_7,
1364 	.freq_tbl = ftbl_cam_cc_ife_2_clk_src,
1365 	.clkr.hw.init = &(const struct clk_init_data) {
1366 		.name = "cam_cc_ife_2_clk_src",
1367 		.parent_data = cam_cc_parent_data_7,
1368 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_7),
1369 		.flags = CLK_SET_RATE_PARENT,
1370 		.ops = &clk_rcg2_shared_ops,
1371 	},
1372 };
1373 
1374 static const struct freq_tbl ftbl_cam_cc_ife_2_dsp_clk_src[] = {
1375 	F(466000000, P_CAM_CC_PLL12_OUT_EVEN, 1, 0, 0),
1376 	F(594000000, P_CAM_CC_PLL12_OUT_EVEN, 1, 0, 0),
1377 	F(675000000, P_CAM_CC_PLL12_OUT_EVEN, 1, 0, 0),
1378 	F(785000000, P_CAM_CC_PLL12_OUT_EVEN, 1, 0, 0),
1379 	{ }
1380 };
1381 
1382 static struct clk_rcg2 cam_cc_ife_2_dsp_clk_src = {
1383 	.cmd_rcgr = 0x123e4,
1384 	.mnd_width = 0,
1385 	.hid_width = 5,
1386 	.parent_map = cam_cc_parent_map_8,
1387 	.freq_tbl = ftbl_cam_cc_ife_2_dsp_clk_src,
1388 	.clkr.hw.init = &(const struct clk_init_data) {
1389 		.name = "cam_cc_ife_2_dsp_clk_src",
1390 		.parent_data = cam_cc_parent_data_8,
1391 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_8),
1392 		.flags = CLK_SET_RATE_PARENT,
1393 		.ops = &clk_rcg2_shared_ops,
1394 	},
1395 };
1396 
1397 static struct clk_rcg2 cam_cc_ife_lite_clk_src = {
1398 	.cmd_rcgr = 0x13000,
1399 	.mnd_width = 0,
1400 	.hid_width = 5,
1401 	.parent_map = cam_cc_parent_map_0,
1402 	.freq_tbl = ftbl_cam_cc_csid_clk_src,
1403 	.clkr.hw.init = &(const struct clk_init_data) {
1404 		.name = "cam_cc_ife_lite_clk_src",
1405 		.parent_data = cam_cc_parent_data_0,
1406 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1407 		.flags = CLK_SET_RATE_PARENT,
1408 		.ops = &clk_rcg2_shared_ops,
1409 	},
1410 };
1411 
1412 static struct clk_rcg2 cam_cc_ife_lite_csid_clk_src = {
1413 	.cmd_rcgr = 0x1313c,
1414 	.mnd_width = 0,
1415 	.hid_width = 5,
1416 	.parent_map = cam_cc_parent_map_0,
1417 	.freq_tbl = ftbl_cam_cc_csid_clk_src,
1418 	.clkr.hw.init = &(const struct clk_init_data) {
1419 		.name = "cam_cc_ife_lite_csid_clk_src",
1420 		.parent_data = cam_cc_parent_data_0,
1421 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1422 		.flags = CLK_SET_RATE_PARENT,
1423 		.ops = &clk_rcg2_shared_ops,
1424 	},
1425 };
1426 
1427 static const struct freq_tbl ftbl_cam_cc_ipe_nps_clk_src[] = {
1428 	F(455000000, P_CAM_CC_PLL1_OUT_EVEN, 1, 0, 0),
1429 	F(575000000, P_CAM_CC_PLL1_OUT_EVEN, 1, 0, 0),
1430 	F(675000000, P_CAM_CC_PLL1_OUT_EVEN, 1, 0, 0),
1431 	F(825000000, P_CAM_CC_PLL1_OUT_EVEN, 1, 0, 0),
1432 	{ }
1433 };
1434 
1435 static struct clk_rcg2 cam_cc_ipe_nps_clk_src = {
1436 	.cmd_rcgr = 0x103cc,
1437 	.mnd_width = 0,
1438 	.hid_width = 5,
1439 	.parent_map = cam_cc_parent_map_9,
1440 	.freq_tbl = ftbl_cam_cc_ipe_nps_clk_src,
1441 	.clkr.hw.init = &(const struct clk_init_data) {
1442 		.name = "cam_cc_ipe_nps_clk_src",
1443 		.parent_data = cam_cc_parent_data_9,
1444 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_9),
1445 		.flags = CLK_SET_RATE_PARENT,
1446 		.ops = &clk_rcg2_shared_ops,
1447 	},
1448 };
1449 
1450 static const struct freq_tbl ftbl_cam_cc_jpeg_clk_src[] = {
1451 	F(19200000, P_BI_TCXO, 1, 0, 0),
1452 	F(200000000, P_CAM_CC_PLL0_OUT_ODD, 2, 0, 0),
1453 	F(400000000, P_CAM_CC_PLL0_OUT_ODD, 1, 0, 0),
1454 	F(480000000, P_CAM_CC_PLL9_OUT_EVEN, 1, 0, 0),
1455 	F(600000000, P_CAM_CC_PLL0_OUT_EVEN, 1, 0, 0),
1456 	{ }
1457 };
1458 
1459 static struct clk_rcg2 cam_cc_jpeg_clk_src = {
1460 	.cmd_rcgr = 0x13674,
1461 	.mnd_width = 0,
1462 	.hid_width = 5,
1463 	.parent_map = cam_cc_parent_map_0,
1464 	.freq_tbl = ftbl_cam_cc_jpeg_clk_src,
1465 	.clkr.hw.init = &(const struct clk_init_data) {
1466 		.name = "cam_cc_jpeg_clk_src",
1467 		.parent_data = cam_cc_parent_data_0,
1468 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1469 		.flags = CLK_SET_RATE_PARENT,
1470 		.ops = &clk_rcg2_shared_ops,
1471 	},
1472 };
1473 
1474 static const struct freq_tbl ftbl_cam_cc_mclk0_clk_src[] = {
1475 	F(19200000, P_BI_TCXO, 1, 0, 0),
1476 	F(24000000, P_CAM_CC_PLL2_OUT_MAIN, 10, 1, 4),
1477 	F(68571429, P_CAM_CC_PLL2_OUT_MAIN, 14, 0, 0),
1478 	{ }
1479 };
1480 
1481 static struct clk_rcg2 cam_cc_mclk0_clk_src = {
1482 	.cmd_rcgr = 0x15000,
1483 	.mnd_width = 8,
1484 	.hid_width = 5,
1485 	.parent_map = cam_cc_parent_map_1,
1486 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1487 	.clkr.hw.init = &(const struct clk_init_data) {
1488 		.name = "cam_cc_mclk0_clk_src",
1489 		.parent_data = cam_cc_parent_data_1,
1490 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1491 		.flags = CLK_SET_RATE_PARENT,
1492 		.ops = &clk_rcg2_shared_ops,
1493 	},
1494 };
1495 
1496 static struct clk_rcg2 cam_cc_mclk1_clk_src = {
1497 	.cmd_rcgr = 0x15130,
1498 	.mnd_width = 8,
1499 	.hid_width = 5,
1500 	.parent_map = cam_cc_parent_map_1,
1501 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1502 	.clkr.hw.init = &(const struct clk_init_data) {
1503 		.name = "cam_cc_mclk1_clk_src",
1504 		.parent_data = cam_cc_parent_data_1,
1505 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1506 		.flags = CLK_SET_RATE_PARENT,
1507 		.ops = &clk_rcg2_shared_ops,
1508 	},
1509 };
1510 
1511 static struct clk_rcg2 cam_cc_mclk2_clk_src = {
1512 	.cmd_rcgr = 0x15260,
1513 	.mnd_width = 8,
1514 	.hid_width = 5,
1515 	.parent_map = cam_cc_parent_map_1,
1516 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1517 	.clkr.hw.init = &(const struct clk_init_data) {
1518 		.name = "cam_cc_mclk2_clk_src",
1519 		.parent_data = cam_cc_parent_data_1,
1520 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1521 		.flags = CLK_SET_RATE_PARENT,
1522 		.ops = &clk_rcg2_shared_ops,
1523 	},
1524 };
1525 
1526 static struct clk_rcg2 cam_cc_mclk3_clk_src = {
1527 	.cmd_rcgr = 0x15390,
1528 	.mnd_width = 8,
1529 	.hid_width = 5,
1530 	.parent_map = cam_cc_parent_map_1,
1531 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1532 	.clkr.hw.init = &(const struct clk_init_data) {
1533 		.name = "cam_cc_mclk3_clk_src",
1534 		.parent_data = cam_cc_parent_data_1,
1535 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1536 		.flags = CLK_SET_RATE_PARENT,
1537 		.ops = &clk_rcg2_shared_ops,
1538 	},
1539 };
1540 
1541 static struct clk_rcg2 cam_cc_mclk4_clk_src = {
1542 	.cmd_rcgr = 0x154c0,
1543 	.mnd_width = 8,
1544 	.hid_width = 5,
1545 	.parent_map = cam_cc_parent_map_1,
1546 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1547 	.clkr.hw.init = &(const struct clk_init_data) {
1548 		.name = "cam_cc_mclk4_clk_src",
1549 		.parent_data = cam_cc_parent_data_1,
1550 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1551 		.flags = CLK_SET_RATE_PARENT,
1552 		.ops = &clk_rcg2_shared_ops,
1553 	},
1554 };
1555 
1556 static struct clk_rcg2 cam_cc_mclk5_clk_src = {
1557 	.cmd_rcgr = 0x155f0,
1558 	.mnd_width = 8,
1559 	.hid_width = 5,
1560 	.parent_map = cam_cc_parent_map_1,
1561 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1562 	.clkr.hw.init = &(const struct clk_init_data) {
1563 		.name = "cam_cc_mclk5_clk_src",
1564 		.parent_data = cam_cc_parent_data_1,
1565 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1566 		.flags = CLK_SET_RATE_PARENT,
1567 		.ops = &clk_rcg2_shared_ops,
1568 	},
1569 };
1570 
1571 static struct clk_rcg2 cam_cc_mclk6_clk_src = {
1572 	.cmd_rcgr = 0x15720,
1573 	.mnd_width = 8,
1574 	.hid_width = 5,
1575 	.parent_map = cam_cc_parent_map_1,
1576 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1577 	.clkr.hw.init = &(const struct clk_init_data) {
1578 		.name = "cam_cc_mclk6_clk_src",
1579 		.parent_data = cam_cc_parent_data_1,
1580 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1581 		.flags = CLK_SET_RATE_PARENT,
1582 		.ops = &clk_rcg2_shared_ops,
1583 	},
1584 };
1585 
1586 static struct clk_rcg2 cam_cc_mclk7_clk_src = {
1587 	.cmd_rcgr = 0x15850,
1588 	.mnd_width = 8,
1589 	.hid_width = 5,
1590 	.parent_map = cam_cc_parent_map_1,
1591 	.freq_tbl = ftbl_cam_cc_mclk0_clk_src,
1592 	.clkr.hw.init = &(const struct clk_init_data) {
1593 		.name = "cam_cc_mclk7_clk_src",
1594 		.parent_data = cam_cc_parent_data_1,
1595 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_1),
1596 		.flags = CLK_SET_RATE_PARENT,
1597 		.ops = &clk_rcg2_shared_ops,
1598 	},
1599 };
1600 
1601 static const struct freq_tbl ftbl_cam_cc_qdss_debug_clk_src[] = {
1602 	F(19200000, P_BI_TCXO, 1, 0, 0),
1603 	F(75000000, P_CAM_CC_PLL0_OUT_EVEN, 8, 0, 0),
1604 	F(150000000, P_CAM_CC_PLL0_OUT_EVEN, 4, 0, 0),
1605 	F(300000000, P_CAM_CC_PLL0_OUT_MAIN, 4, 0, 0),
1606 	{ }
1607 };
1608 
1609 static struct clk_rcg2 cam_cc_qdss_debug_clk_src = {
1610 	.cmd_rcgr = 0x13f24,
1611 	.mnd_width = 0,
1612 	.hid_width = 5,
1613 	.parent_map = cam_cc_parent_map_0,
1614 	.freq_tbl = ftbl_cam_cc_qdss_debug_clk_src,
1615 	.clkr.hw.init = &(const struct clk_init_data) {
1616 		.name = "cam_cc_qdss_debug_clk_src",
1617 		.parent_data = cam_cc_parent_data_0,
1618 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1619 		.flags = CLK_SET_RATE_PARENT,
1620 		.ops = &clk_rcg2_shared_ops,
1621 	},
1622 };
1623 
1624 static const struct freq_tbl ftbl_cam_cc_sfe_0_clk_src[] = {
1625 	F(466000000, P_CAM_CC_PLL6_OUT_EVEN, 1, 0, 0),
1626 	F(594000000, P_CAM_CC_PLL6_OUT_EVEN, 1, 0, 0),
1627 	F(675000000, P_CAM_CC_PLL6_OUT_EVEN, 1, 0, 0),
1628 	F(785000000, P_CAM_CC_PLL6_OUT_EVEN, 1, 0, 0),
1629 	{ }
1630 };
1631 
1632 static struct clk_rcg2 cam_cc_sfe_0_clk_src = {
1633 	.cmd_rcgr = 0x13294,
1634 	.mnd_width = 0,
1635 	.hid_width = 5,
1636 	.parent_map = cam_cc_parent_map_10,
1637 	.freq_tbl = ftbl_cam_cc_sfe_0_clk_src,
1638 	.clkr.hw.init = &(const struct clk_init_data) {
1639 		.name = "cam_cc_sfe_0_clk_src",
1640 		.parent_data = cam_cc_parent_data_10,
1641 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_10),
1642 		.flags = CLK_SET_RATE_PARENT,
1643 		.ops = &clk_rcg2_shared_ops,
1644 	},
1645 };
1646 
1647 static const struct freq_tbl ftbl_cam_cc_sfe_1_clk_src[] = {
1648 	F(466000000, P_CAM_CC_PLL7_OUT_EVEN, 1, 0, 0),
1649 	F(594000000, P_CAM_CC_PLL7_OUT_EVEN, 1, 0, 0),
1650 	F(675000000, P_CAM_CC_PLL7_OUT_EVEN, 1, 0, 0),
1651 	F(785000000, P_CAM_CC_PLL7_OUT_EVEN, 1, 0, 0),
1652 	{ }
1653 };
1654 
1655 static struct clk_rcg2 cam_cc_sfe_1_clk_src = {
1656 	.cmd_rcgr = 0x133f4,
1657 	.mnd_width = 0,
1658 	.hid_width = 5,
1659 	.parent_map = cam_cc_parent_map_11,
1660 	.freq_tbl = ftbl_cam_cc_sfe_1_clk_src,
1661 	.clkr.hw.init = &(const struct clk_init_data) {
1662 		.name = "cam_cc_sfe_1_clk_src",
1663 		.parent_data = cam_cc_parent_data_11,
1664 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_11),
1665 		.flags = CLK_SET_RATE_PARENT,
1666 		.ops = &clk_rcg2_shared_ops,
1667 	},
1668 };
1669 
1670 static const struct freq_tbl ftbl_cam_cc_sleep_clk_src[] = {
1671 	F(32000, P_SLEEP_CLK, 1, 0, 0),
1672 	{ }
1673 };
1674 
1675 static struct clk_rcg2 cam_cc_sleep_clk_src = {
1676 	.cmd_rcgr = 0x141a0,
1677 	.mnd_width = 0,
1678 	.hid_width = 5,
1679 	.parent_map = cam_cc_parent_map_12,
1680 	.freq_tbl = ftbl_cam_cc_sleep_clk_src,
1681 	.clkr.hw.init = &(const struct clk_init_data) {
1682 		.name = "cam_cc_sleep_clk_src",
1683 		.parent_data = cam_cc_parent_data_12,
1684 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_12),
1685 		.flags = CLK_SET_RATE_PARENT,
1686 		.ops = &clk_rcg2_shared_ops,
1687 	},
1688 };
1689 
1690 static const struct freq_tbl ftbl_cam_cc_slow_ahb_clk_src[] = {
1691 	F(19200000, P_BI_TCXO, 1, 0, 0),
1692 	F(80000000, P_CAM_CC_PLL0_OUT_EVEN, 7.5, 0, 0),
1693 	{ }
1694 };
1695 
1696 static struct clk_rcg2 cam_cc_slow_ahb_clk_src = {
1697 	.cmd_rcgr = 0x10148,
1698 	.mnd_width = 8,
1699 	.hid_width = 5,
1700 	.parent_map = cam_cc_parent_map_0,
1701 	.freq_tbl = ftbl_cam_cc_slow_ahb_clk_src,
1702 	.clkr.hw.init = &(const struct clk_init_data) {
1703 		.name = "cam_cc_slow_ahb_clk_src",
1704 		.parent_data = cam_cc_parent_data_0,
1705 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_0),
1706 		.flags = CLK_SET_RATE_PARENT,
1707 		.ops = &clk_rcg2_shared_ops,
1708 	},
1709 };
1710 
1711 static const struct freq_tbl ftbl_cam_cc_xo_clk_src[] = {
1712 	F(19200000, P_BI_TCXO_AO, 1, 0, 0),
1713 	{ }
1714 };
1715 
1716 static struct clk_rcg2 cam_cc_xo_clk_src = {
1717 	.cmd_rcgr = 0x14070,
1718 	.mnd_width = 0,
1719 	.hid_width = 5,
1720 	.parent_map = cam_cc_parent_map_13_ao,
1721 	.freq_tbl = ftbl_cam_cc_xo_clk_src,
1722 	.clkr.hw.init = &(const struct clk_init_data) {
1723 		.name = "cam_cc_xo_clk_src",
1724 		.parent_data = cam_cc_parent_data_13_ao,
1725 		.num_parents = ARRAY_SIZE(cam_cc_parent_data_13_ao),
1726 		.flags = CLK_SET_RATE_PARENT,
1727 		.ops = &clk_rcg2_shared_ops,
1728 	},
1729 };
1730 
1731 static struct clk_branch cam_cc_bps_ahb_clk = {
1732 	.halt_reg = 0x10274,
1733 	.halt_check = BRANCH_HALT,
1734 	.clkr = {
1735 		.enable_reg = 0x10274,
1736 		.enable_mask = BIT(0),
1737 		.hw.init = &(const struct clk_init_data) {
1738 			.name = "cam_cc_bps_ahb_clk",
1739 			.parent_hws = (const struct clk_hw*[]) {
1740 				&cam_cc_slow_ahb_clk_src.clkr.hw,
1741 			},
1742 			.num_parents = 1,
1743 			.flags = CLK_SET_RATE_PARENT,
1744 			.ops = &clk_branch2_ops,
1745 		},
1746 	},
1747 };
1748 
1749 static struct clk_branch cam_cc_bps_clk = {
1750 	.halt_reg = 0x103a4,
1751 	.halt_check = BRANCH_HALT,
1752 	.clkr = {
1753 		.enable_reg = 0x103a4,
1754 		.enable_mask = BIT(0),
1755 		.hw.init = &(const struct clk_init_data) {
1756 			.name = "cam_cc_bps_clk",
1757 			.parent_hws = (const struct clk_hw*[]) {
1758 				&cam_cc_bps_clk_src.clkr.hw,
1759 			},
1760 			.num_parents = 1,
1761 			.flags = CLK_SET_RATE_PARENT,
1762 			.ops = &clk_branch2_ops,
1763 		},
1764 	},
1765 };
1766 
1767 static struct clk_branch cam_cc_bps_fast_ahb_clk = {
1768 	.halt_reg = 0x10144,
1769 	.halt_check = BRANCH_HALT,
1770 	.clkr = {
1771 		.enable_reg = 0x10144,
1772 		.enable_mask = BIT(0),
1773 		.hw.init = &(const struct clk_init_data) {
1774 			.name = "cam_cc_bps_fast_ahb_clk",
1775 			.parent_hws = (const struct clk_hw*[]) {
1776 				&cam_cc_fast_ahb_clk_src.clkr.hw,
1777 			},
1778 			.num_parents = 1,
1779 			.flags = CLK_SET_RATE_PARENT,
1780 			.ops = &clk_branch2_ops,
1781 		},
1782 	},
1783 };
1784 
1785 static struct clk_branch cam_cc_camnoc_axi_clk = {
1786 	.halt_reg = 0x13f0c,
1787 	.halt_check = BRANCH_HALT,
1788 	.clkr = {
1789 		.enable_reg = 0x13f0c,
1790 		.enable_mask = BIT(0),
1791 		.hw.init = &(const struct clk_init_data) {
1792 			.name = "cam_cc_camnoc_axi_clk",
1793 			.parent_hws = (const struct clk_hw*[]) {
1794 				&cam_cc_camnoc_axi_clk_src.clkr.hw,
1795 			},
1796 			.num_parents = 1,
1797 			.flags = CLK_SET_RATE_PARENT,
1798 			.ops = &clk_branch2_ops,
1799 		},
1800 	},
1801 };
1802 
1803 static struct clk_branch cam_cc_camnoc_dcd_xo_clk = {
1804 	.halt_reg = 0x13f18,
1805 	.halt_check = BRANCH_HALT,
1806 	.clkr = {
1807 		.enable_reg = 0x13f18,
1808 		.enable_mask = BIT(0),
1809 		.hw.init = &(const struct clk_init_data) {
1810 			.name = "cam_cc_camnoc_dcd_xo_clk",
1811 			.parent_hws = (const struct clk_hw*[]) {
1812 				&cam_cc_xo_clk_src.clkr.hw,
1813 			},
1814 			.num_parents = 1,
1815 			.flags = CLK_SET_RATE_PARENT,
1816 			.ops = &clk_branch2_ops,
1817 		},
1818 	},
1819 };
1820 
1821 static struct clk_branch cam_cc_camnoc_xo_clk = {
1822 	.halt_reg = 0x13f1c,
1823 	.halt_check = BRANCH_HALT,
1824 	.clkr = {
1825 		.enable_reg = 0x13f1c,
1826 		.enable_mask = BIT(0),
1827 		.hw.init = &(const struct clk_init_data) {
1828 			.name = "cam_cc_camnoc_xo_clk",
1829 			.parent_hws = (const struct clk_hw*[]) {
1830 				&cam_cc_xo_clk_src.clkr.hw,
1831 			},
1832 			.num_parents = 1,
1833 			.flags = CLK_SET_RATE_PARENT,
1834 			.ops = &clk_branch2_ops,
1835 		},
1836 	},
1837 };
1838 
1839 static struct clk_branch cam_cc_cci_0_clk = {
1840 	.halt_reg = 0x13a2c,
1841 	.halt_check = BRANCH_HALT,
1842 	.clkr = {
1843 		.enable_reg = 0x13a2c,
1844 		.enable_mask = BIT(0),
1845 		.hw.init = &(const struct clk_init_data) {
1846 			.name = "cam_cc_cci_0_clk",
1847 			.parent_hws = (const struct clk_hw*[]) {
1848 				&cam_cc_cci_0_clk_src.clkr.hw,
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 cam_cc_cci_1_clk = {
1858 	.halt_reg = 0x13b5c,
1859 	.halt_check = BRANCH_HALT,
1860 	.clkr = {
1861 		.enable_reg = 0x13b5c,
1862 		.enable_mask = BIT(0),
1863 		.hw.init = &(const struct clk_init_data) {
1864 			.name = "cam_cc_cci_1_clk",
1865 			.parent_hws = (const struct clk_hw*[]) {
1866 				&cam_cc_cci_1_clk_src.clkr.hw,
1867 			},
1868 			.num_parents = 1,
1869 			.flags = CLK_SET_RATE_PARENT,
1870 			.ops = &clk_branch2_ops,
1871 		},
1872 	},
1873 };
1874 
1875 static struct clk_branch cam_cc_cci_2_clk = {
1876 	.halt_reg = 0x13c8c,
1877 	.halt_check = BRANCH_HALT,
1878 	.clkr = {
1879 		.enable_reg = 0x13c8c,
1880 		.enable_mask = BIT(0),
1881 		.hw.init = &(const struct clk_init_data) {
1882 			.name = "cam_cc_cci_2_clk",
1883 			.parent_hws = (const struct clk_hw*[]) {
1884 				&cam_cc_cci_2_clk_src.clkr.hw,
1885 			},
1886 			.num_parents = 1,
1887 			.flags = CLK_SET_RATE_PARENT,
1888 			.ops = &clk_branch2_ops,
1889 		},
1890 	},
1891 };
1892 
1893 static struct clk_branch cam_cc_core_ahb_clk = {
1894 	.halt_reg = 0x1406c,
1895 	.halt_check = BRANCH_HALT_DELAY,
1896 	.clkr = {
1897 		.enable_reg = 0x1406c,
1898 		.enable_mask = BIT(0),
1899 		.hw.init = &(const struct clk_init_data) {
1900 			.name = "cam_cc_core_ahb_clk",
1901 			.parent_hws = (const struct clk_hw*[]) {
1902 				&cam_cc_slow_ahb_clk_src.clkr.hw,
1903 			},
1904 			.num_parents = 1,
1905 			.flags = CLK_SET_RATE_PARENT,
1906 			.ops = &clk_branch2_ops,
1907 		},
1908 	},
1909 };
1910 
1911 static struct clk_branch cam_cc_cpas_ahb_clk = {
1912 	.halt_reg = 0x13c90,
1913 	.halt_check = BRANCH_HALT,
1914 	.clkr = {
1915 		.enable_reg = 0x13c90,
1916 		.enable_mask = BIT(0),
1917 		.hw.init = &(const struct clk_init_data) {
1918 			.name = "cam_cc_cpas_ahb_clk",
1919 			.parent_hws = (const struct clk_hw*[]) {
1920 				&cam_cc_slow_ahb_clk_src.clkr.hw,
1921 			},
1922 			.num_parents = 1,
1923 			.flags = CLK_SET_RATE_PARENT,
1924 			.ops = &clk_branch2_ops,
1925 		},
1926 	},
1927 };
1928 
1929 static struct clk_branch cam_cc_cpas_bps_clk = {
1930 	.halt_reg = 0x103b0,
1931 	.halt_check = BRANCH_HALT,
1932 	.clkr = {
1933 		.enable_reg = 0x103b0,
1934 		.enable_mask = BIT(0),
1935 		.hw.init = &(const struct clk_init_data) {
1936 			.name = "cam_cc_cpas_bps_clk",
1937 			.parent_hws = (const struct clk_hw*[]) {
1938 				&cam_cc_bps_clk_src.clkr.hw,
1939 			},
1940 			.num_parents = 1,
1941 			.flags = CLK_SET_RATE_PARENT,
1942 			.ops = &clk_branch2_ops,
1943 		},
1944 	},
1945 };
1946 
1947 static struct clk_branch cam_cc_cpas_cre_clk = {
1948 	.halt_reg = 0x1366c,
1949 	.halt_check = BRANCH_HALT,
1950 	.clkr = {
1951 		.enable_reg = 0x1366c,
1952 		.enable_mask = BIT(0),
1953 		.hw.init = &(const struct clk_init_data) {
1954 			.name = "cam_cc_cpas_cre_clk",
1955 			.parent_hws = (const struct clk_hw*[]) {
1956 				&cam_cc_cre_clk_src.clkr.hw,
1957 			},
1958 			.num_parents = 1,
1959 			.flags = CLK_SET_RATE_PARENT,
1960 			.ops = &clk_branch2_ops,
1961 		},
1962 	},
1963 };
1964 
1965 static struct clk_branch cam_cc_cpas_fast_ahb_clk = {
1966 	.halt_reg = 0x13c9c,
1967 	.halt_check = BRANCH_HALT,
1968 	.clkr = {
1969 		.enable_reg = 0x13c9c,
1970 		.enable_mask = BIT(0),
1971 		.hw.init = &(const struct clk_init_data) {
1972 			.name = "cam_cc_cpas_fast_ahb_clk",
1973 			.parent_hws = (const struct clk_hw*[]) {
1974 				&cam_cc_fast_ahb_clk_src.clkr.hw,
1975 			},
1976 			.num_parents = 1,
1977 			.flags = CLK_SET_RATE_PARENT,
1978 			.ops = &clk_branch2_ops,
1979 		},
1980 	},
1981 };
1982 
1983 static struct clk_branch cam_cc_cpas_ife_0_clk = {
1984 	.halt_reg = 0x11150,
1985 	.halt_check = BRANCH_HALT,
1986 	.clkr = {
1987 		.enable_reg = 0x11150,
1988 		.enable_mask = BIT(0),
1989 		.hw.init = &(const struct clk_init_data) {
1990 			.name = "cam_cc_cpas_ife_0_clk",
1991 			.parent_hws = (const struct clk_hw*[]) {
1992 				&cam_cc_ife_0_clk_src.clkr.hw,
1993 			},
1994 			.num_parents = 1,
1995 			.flags = CLK_SET_RATE_PARENT,
1996 			.ops = &clk_branch2_ops,
1997 		},
1998 	},
1999 };
2000 
2001 static struct clk_branch cam_cc_cpas_ife_1_clk = {
2002 	.halt_reg = 0x12150,
2003 	.halt_check = BRANCH_HALT,
2004 	.clkr = {
2005 		.enable_reg = 0x12150,
2006 		.enable_mask = BIT(0),
2007 		.hw.init = &(const struct clk_init_data) {
2008 			.name = "cam_cc_cpas_ife_1_clk",
2009 			.parent_hws = (const struct clk_hw*[]) {
2010 				&cam_cc_ife_1_clk_src.clkr.hw,
2011 			},
2012 			.num_parents = 1,
2013 			.flags = CLK_SET_RATE_PARENT,
2014 			.ops = &clk_branch2_ops,
2015 		},
2016 	},
2017 };
2018 
2019 static struct clk_branch cam_cc_cpas_ife_2_clk = {
2020 	.halt_reg = 0x123e0,
2021 	.halt_check = BRANCH_HALT,
2022 	.clkr = {
2023 		.enable_reg = 0x123e0,
2024 		.enable_mask = BIT(0),
2025 		.hw.init = &(const struct clk_init_data) {
2026 			.name = "cam_cc_cpas_ife_2_clk",
2027 			.parent_hws = (const struct clk_hw*[]) {
2028 				&cam_cc_ife_2_clk_src.clkr.hw,
2029 			},
2030 			.num_parents = 1,
2031 			.flags = CLK_SET_RATE_PARENT,
2032 			.ops = &clk_branch2_ops,
2033 		},
2034 	},
2035 };
2036 
2037 static struct clk_branch cam_cc_cpas_ife_lite_clk = {
2038 	.halt_reg = 0x13138,
2039 	.halt_check = BRANCH_HALT,
2040 	.clkr = {
2041 		.enable_reg = 0x13138,
2042 		.enable_mask = BIT(0),
2043 		.hw.init = &(const struct clk_init_data) {
2044 			.name = "cam_cc_cpas_ife_lite_clk",
2045 			.parent_hws = (const struct clk_hw*[]) {
2046 				&cam_cc_ife_lite_clk_src.clkr.hw,
2047 			},
2048 			.num_parents = 1,
2049 			.flags = CLK_SET_RATE_PARENT,
2050 			.ops = &clk_branch2_ops,
2051 		},
2052 	},
2053 };
2054 
2055 static struct clk_branch cam_cc_cpas_ipe_nps_clk = {
2056 	.halt_reg = 0x10504,
2057 	.halt_check = BRANCH_HALT,
2058 	.clkr = {
2059 		.enable_reg = 0x10504,
2060 		.enable_mask = BIT(0),
2061 		.hw.init = &(const struct clk_init_data) {
2062 			.name = "cam_cc_cpas_ipe_nps_clk",
2063 			.parent_hws = (const struct clk_hw*[]) {
2064 				&cam_cc_ipe_nps_clk_src.clkr.hw,
2065 			},
2066 			.num_parents = 1,
2067 			.flags = CLK_SET_RATE_PARENT,
2068 			.ops = &clk_branch2_ops,
2069 		},
2070 	},
2071 };
2072 
2073 static struct clk_branch cam_cc_cpas_sbi_clk = {
2074 	.halt_reg = 0x1054c,
2075 	.halt_check = BRANCH_HALT,
2076 	.clkr = {
2077 		.enable_reg = 0x1054c,
2078 		.enable_mask = BIT(0),
2079 		.hw.init = &(const struct clk_init_data) {
2080 			.name = "cam_cc_cpas_sbi_clk",
2081 			.parent_hws = (const struct clk_hw*[]) {
2082 				&cam_cc_ife_0_clk_src.clkr.hw,
2083 			},
2084 			.num_parents = 1,
2085 			.flags = CLK_SET_RATE_PARENT,
2086 			.ops = &clk_branch2_ops,
2087 		},
2088 	},
2089 };
2090 
2091 static struct clk_branch cam_cc_cpas_sfe_0_clk = {
2092 	.halt_reg = 0x133cc,
2093 	.halt_check = BRANCH_HALT,
2094 	.clkr = {
2095 		.enable_reg = 0x133cc,
2096 		.enable_mask = BIT(0),
2097 		.hw.init = &(const struct clk_init_data) {
2098 			.name = "cam_cc_cpas_sfe_0_clk",
2099 			.parent_hws = (const struct clk_hw*[]) {
2100 				&cam_cc_sfe_0_clk_src.clkr.hw,
2101 			},
2102 			.num_parents = 1,
2103 			.flags = CLK_SET_RATE_PARENT,
2104 			.ops = &clk_branch2_ops,
2105 		},
2106 	},
2107 };
2108 
2109 static struct clk_branch cam_cc_cpas_sfe_1_clk = {
2110 	.halt_reg = 0x1352c,
2111 	.halt_check = BRANCH_HALT,
2112 	.clkr = {
2113 		.enable_reg = 0x1352c,
2114 		.enable_mask = BIT(0),
2115 		.hw.init = &(const struct clk_init_data) {
2116 			.name = "cam_cc_cpas_sfe_1_clk",
2117 			.parent_hws = (const struct clk_hw*[]) {
2118 				&cam_cc_sfe_1_clk_src.clkr.hw,
2119 			},
2120 			.num_parents = 1,
2121 			.flags = CLK_SET_RATE_PARENT,
2122 			.ops = &clk_branch2_ops,
2123 		},
2124 	},
2125 };
2126 
2127 static struct clk_branch cam_cc_cre_ahb_clk = {
2128 	.halt_reg = 0x13670,
2129 	.halt_check = BRANCH_HALT,
2130 	.clkr = {
2131 		.enable_reg = 0x13670,
2132 		.enable_mask = BIT(0),
2133 		.hw.init = &(const struct clk_init_data) {
2134 			.name = "cam_cc_cre_ahb_clk",
2135 			.parent_hws = (const struct clk_hw*[]) {
2136 				&cam_cc_slow_ahb_clk_src.clkr.hw,
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 cam_cc_cre_clk = {
2146 	.halt_reg = 0x13668,
2147 	.halt_check = BRANCH_HALT,
2148 	.clkr = {
2149 		.enable_reg = 0x13668,
2150 		.enable_mask = BIT(0),
2151 		.hw.init = &(const struct clk_init_data) {
2152 			.name = "cam_cc_cre_clk",
2153 			.parent_hws = (const struct clk_hw*[]) {
2154 				&cam_cc_cre_clk_src.clkr.hw,
2155 			},
2156 			.num_parents = 1,
2157 			.flags = CLK_SET_RATE_PARENT,
2158 			.ops = &clk_branch2_ops,
2159 		},
2160 	},
2161 };
2162 
2163 static struct clk_branch cam_cc_csi0phytimer_clk = {
2164 	.halt_reg = 0x15aac,
2165 	.halt_check = BRANCH_HALT,
2166 	.clkr = {
2167 		.enable_reg = 0x15aac,
2168 		.enable_mask = BIT(0),
2169 		.hw.init = &(const struct clk_init_data) {
2170 			.name = "cam_cc_csi0phytimer_clk",
2171 			.parent_hws = (const struct clk_hw*[]) {
2172 				&cam_cc_csi0phytimer_clk_src.clkr.hw,
2173 			},
2174 			.num_parents = 1,
2175 			.flags = CLK_SET_RATE_PARENT,
2176 			.ops = &clk_branch2_ops,
2177 		},
2178 	},
2179 };
2180 
2181 static struct clk_branch cam_cc_csi1phytimer_clk = {
2182 	.halt_reg = 0x15be4,
2183 	.halt_check = BRANCH_HALT,
2184 	.clkr = {
2185 		.enable_reg = 0x15be4,
2186 		.enable_mask = BIT(0),
2187 		.hw.init = &(const struct clk_init_data) {
2188 			.name = "cam_cc_csi1phytimer_clk",
2189 			.parent_hws = (const struct clk_hw*[]) {
2190 				&cam_cc_csi1phytimer_clk_src.clkr.hw,
2191 			},
2192 			.num_parents = 1,
2193 			.flags = CLK_SET_RATE_PARENT,
2194 			.ops = &clk_branch2_ops,
2195 		},
2196 	},
2197 };
2198 
2199 static struct clk_branch cam_cc_csi2phytimer_clk = {
2200 	.halt_reg = 0x15d18,
2201 	.halt_check = BRANCH_HALT,
2202 	.clkr = {
2203 		.enable_reg = 0x15d18,
2204 		.enable_mask = BIT(0),
2205 		.hw.init = &(const struct clk_init_data) {
2206 			.name = "cam_cc_csi2phytimer_clk",
2207 			.parent_hws = (const struct clk_hw*[]) {
2208 				&cam_cc_csi2phytimer_clk_src.clkr.hw,
2209 			},
2210 			.num_parents = 1,
2211 			.flags = CLK_SET_RATE_PARENT,
2212 			.ops = &clk_branch2_ops,
2213 		},
2214 	},
2215 };
2216 
2217 static struct clk_branch cam_cc_csi3phytimer_clk = {
2218 	.halt_reg = 0x15e4c,
2219 	.halt_check = BRANCH_HALT,
2220 	.clkr = {
2221 		.enable_reg = 0x15e4c,
2222 		.enable_mask = BIT(0),
2223 		.hw.init = &(const struct clk_init_data) {
2224 			.name = "cam_cc_csi3phytimer_clk",
2225 			.parent_hws = (const struct clk_hw*[]) {
2226 				&cam_cc_csi3phytimer_clk_src.clkr.hw,
2227 			},
2228 			.num_parents = 1,
2229 			.flags = CLK_SET_RATE_PARENT,
2230 			.ops = &clk_branch2_ops,
2231 		},
2232 	},
2233 };
2234 
2235 static struct clk_branch cam_cc_csi4phytimer_clk = {
2236 	.halt_reg = 0x15f80,
2237 	.halt_check = BRANCH_HALT,
2238 	.clkr = {
2239 		.enable_reg = 0x15f80,
2240 		.enable_mask = BIT(0),
2241 		.hw.init = &(const struct clk_init_data) {
2242 			.name = "cam_cc_csi4phytimer_clk",
2243 			.parent_hws = (const struct clk_hw*[]) {
2244 				&cam_cc_csi4phytimer_clk_src.clkr.hw,
2245 			},
2246 			.num_parents = 1,
2247 			.flags = CLK_SET_RATE_PARENT,
2248 			.ops = &clk_branch2_ops,
2249 		},
2250 	},
2251 };
2252 
2253 static struct clk_branch cam_cc_csi5phytimer_clk = {
2254 	.halt_reg = 0x160b4,
2255 	.halt_check = BRANCH_HALT,
2256 	.clkr = {
2257 		.enable_reg = 0x160b4,
2258 		.enable_mask = BIT(0),
2259 		.hw.init = &(const struct clk_init_data) {
2260 			.name = "cam_cc_csi5phytimer_clk",
2261 			.parent_hws = (const struct clk_hw*[]) {
2262 				&cam_cc_csi5phytimer_clk_src.clkr.hw,
2263 			},
2264 			.num_parents = 1,
2265 			.flags = CLK_SET_RATE_PARENT,
2266 			.ops = &clk_branch2_ops,
2267 		},
2268 	},
2269 };
2270 
2271 static struct clk_branch cam_cc_csi6phytimer_clk = {
2272 	.halt_reg = 0x161e8,
2273 	.halt_check = BRANCH_HALT,
2274 	.clkr = {
2275 		.enable_reg = 0x161e8,
2276 		.enable_mask = BIT(0),
2277 		.hw.init = &(const struct clk_init_data) {
2278 			.name = "cam_cc_csi6phytimer_clk",
2279 			.parent_hws = (const struct clk_hw*[]) {
2280 				&cam_cc_csi6phytimer_clk_src.clkr.hw,
2281 			},
2282 			.num_parents = 1,
2283 			.flags = CLK_SET_RATE_PARENT,
2284 			.ops = &clk_branch2_ops,
2285 		},
2286 	},
2287 };
2288 
2289 static struct clk_branch cam_cc_csi7phytimer_clk = {
2290 	.halt_reg = 0x1631c,
2291 	.halt_check = BRANCH_HALT,
2292 	.clkr = {
2293 		.enable_reg = 0x1631c,
2294 		.enable_mask = BIT(0),
2295 		.hw.init = &(const struct clk_init_data) {
2296 			.name = "cam_cc_csi7phytimer_clk",
2297 			.parent_hws = (const struct clk_hw*[]) {
2298 				&cam_cc_csi7phytimer_clk_src.clkr.hw,
2299 			},
2300 			.num_parents = 1,
2301 			.flags = CLK_SET_RATE_PARENT,
2302 			.ops = &clk_branch2_ops,
2303 		},
2304 	},
2305 };
2306 
2307 static struct clk_branch cam_cc_csid_clk = {
2308 	.halt_reg = 0x13dd4,
2309 	.halt_check = BRANCH_HALT,
2310 	.clkr = {
2311 		.enable_reg = 0x13dd4,
2312 		.enable_mask = BIT(0),
2313 		.hw.init = &(const struct clk_init_data) {
2314 			.name = "cam_cc_csid_clk",
2315 			.parent_hws = (const struct clk_hw*[]) {
2316 				&cam_cc_csid_clk_src.clkr.hw,
2317 			},
2318 			.num_parents = 1,
2319 			.flags = CLK_SET_RATE_PARENT,
2320 			.ops = &clk_branch2_ops,
2321 		},
2322 	},
2323 };
2324 
2325 static struct clk_branch cam_cc_csid_csiphy_rx_clk = {
2326 	.halt_reg = 0x15ab4,
2327 	.halt_check = BRANCH_HALT,
2328 	.clkr = {
2329 		.enable_reg = 0x15ab4,
2330 		.enable_mask = BIT(0),
2331 		.hw.init = &(const struct clk_init_data) {
2332 			.name = "cam_cc_csid_csiphy_rx_clk",
2333 			.parent_hws = (const struct clk_hw*[]) {
2334 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2335 			},
2336 			.num_parents = 1,
2337 			.flags = CLK_SET_RATE_PARENT,
2338 			.ops = &clk_branch2_ops,
2339 		},
2340 	},
2341 };
2342 
2343 static struct clk_branch cam_cc_csiphy0_clk = {
2344 	.halt_reg = 0x15ab0,
2345 	.halt_check = BRANCH_HALT,
2346 	.clkr = {
2347 		.enable_reg = 0x15ab0,
2348 		.enable_mask = BIT(0),
2349 		.hw.init = &(const struct clk_init_data) {
2350 			.name = "cam_cc_csiphy0_clk",
2351 			.parent_hws = (const struct clk_hw*[]) {
2352 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2353 			},
2354 			.num_parents = 1,
2355 			.flags = CLK_SET_RATE_PARENT,
2356 			.ops = &clk_branch2_ops,
2357 		},
2358 	},
2359 };
2360 
2361 static struct clk_branch cam_cc_csiphy1_clk = {
2362 	.halt_reg = 0x15be8,
2363 	.halt_check = BRANCH_HALT,
2364 	.clkr = {
2365 		.enable_reg = 0x15be8,
2366 		.enable_mask = BIT(0),
2367 		.hw.init = &(const struct clk_init_data) {
2368 			.name = "cam_cc_csiphy1_clk",
2369 			.parent_hws = (const struct clk_hw*[]) {
2370 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2371 			},
2372 			.num_parents = 1,
2373 			.flags = CLK_SET_RATE_PARENT,
2374 			.ops = &clk_branch2_ops,
2375 		},
2376 	},
2377 };
2378 
2379 static struct clk_branch cam_cc_csiphy2_clk = {
2380 	.halt_reg = 0x15d1c,
2381 	.halt_check = BRANCH_HALT,
2382 	.clkr = {
2383 		.enable_reg = 0x15d1c,
2384 		.enable_mask = BIT(0),
2385 		.hw.init = &(const struct clk_init_data) {
2386 			.name = "cam_cc_csiphy2_clk",
2387 			.parent_hws = (const struct clk_hw*[]) {
2388 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2389 			},
2390 			.num_parents = 1,
2391 			.flags = CLK_SET_RATE_PARENT,
2392 			.ops = &clk_branch2_ops,
2393 		},
2394 	},
2395 };
2396 
2397 static struct clk_branch cam_cc_csiphy3_clk = {
2398 	.halt_reg = 0x15e50,
2399 	.halt_check = BRANCH_HALT,
2400 	.clkr = {
2401 		.enable_reg = 0x15e50,
2402 		.enable_mask = BIT(0),
2403 		.hw.init = &(const struct clk_init_data) {
2404 			.name = "cam_cc_csiphy3_clk",
2405 			.parent_hws = (const struct clk_hw*[]) {
2406 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2407 			},
2408 			.num_parents = 1,
2409 			.flags = CLK_SET_RATE_PARENT,
2410 			.ops = &clk_branch2_ops,
2411 		},
2412 	},
2413 };
2414 
2415 static struct clk_branch cam_cc_csiphy4_clk = {
2416 	.halt_reg = 0x15f84,
2417 	.halt_check = BRANCH_HALT,
2418 	.clkr = {
2419 		.enable_reg = 0x15f84,
2420 		.enable_mask = BIT(0),
2421 		.hw.init = &(const struct clk_init_data) {
2422 			.name = "cam_cc_csiphy4_clk",
2423 			.parent_hws = (const struct clk_hw*[]) {
2424 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2425 			},
2426 			.num_parents = 1,
2427 			.flags = CLK_SET_RATE_PARENT,
2428 			.ops = &clk_branch2_ops,
2429 		},
2430 	},
2431 };
2432 
2433 static struct clk_branch cam_cc_csiphy5_clk = {
2434 	.halt_reg = 0x160b8,
2435 	.halt_check = BRANCH_HALT,
2436 	.clkr = {
2437 		.enable_reg = 0x160b8,
2438 		.enable_mask = BIT(0),
2439 		.hw.init = &(const struct clk_init_data) {
2440 			.name = "cam_cc_csiphy5_clk",
2441 			.parent_hws = (const struct clk_hw*[]) {
2442 				&cam_cc_cphy_rx_clk_src.clkr.hw,
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 cam_cc_csiphy6_clk = {
2452 	.halt_reg = 0x161ec,
2453 	.halt_check = BRANCH_HALT,
2454 	.clkr = {
2455 		.enable_reg = 0x161ec,
2456 		.enable_mask = BIT(0),
2457 		.hw.init = &(const struct clk_init_data) {
2458 			.name = "cam_cc_csiphy6_clk",
2459 			.parent_hws = (const struct clk_hw*[]) {
2460 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2461 			},
2462 			.num_parents = 1,
2463 			.flags = CLK_SET_RATE_PARENT,
2464 			.ops = &clk_branch2_ops,
2465 		},
2466 	},
2467 };
2468 
2469 static struct clk_branch cam_cc_csiphy7_clk = {
2470 	.halt_reg = 0x16320,
2471 	.halt_check = BRANCH_HALT,
2472 	.clkr = {
2473 		.enable_reg = 0x16320,
2474 		.enable_mask = BIT(0),
2475 		.hw.init = &(const struct clk_init_data) {
2476 			.name = "cam_cc_csiphy7_clk",
2477 			.parent_hws = (const struct clk_hw*[]) {
2478 				&cam_cc_cphy_rx_clk_src.clkr.hw,
2479 			},
2480 			.num_parents = 1,
2481 			.flags = CLK_SET_RATE_PARENT,
2482 			.ops = &clk_branch2_ops,
2483 		},
2484 	},
2485 };
2486 
2487 static struct clk_branch cam_cc_drv_ahb_clk = {
2488 	.halt_reg = 0x142d8,
2489 	.halt_check = BRANCH_HALT,
2490 	.clkr = {
2491 		.enable_reg = 0x142d8,
2492 		.enable_mask = BIT(0),
2493 		.hw.init = &(const struct clk_init_data) {
2494 			.name = "cam_cc_drv_ahb_clk",
2495 			.parent_hws = (const struct clk_hw*[]) {
2496 				&cam_cc_slow_ahb_clk_src.clkr.hw,
2497 			},
2498 			.num_parents = 1,
2499 			.flags = CLK_SET_RATE_PARENT,
2500 			.ops = &clk_branch2_ops,
2501 		},
2502 	},
2503 };
2504 
2505 static struct clk_branch cam_cc_drv_xo_clk = {
2506 	.halt_reg = 0x142d4,
2507 	.halt_check = BRANCH_HALT,
2508 	.clkr = {
2509 		.enable_reg = 0x142d4,
2510 		.enable_mask = BIT(0),
2511 		.hw.init = &(const struct clk_init_data) {
2512 			.name = "cam_cc_drv_xo_clk",
2513 			.parent_hws = (const struct clk_hw*[]) {
2514 				&cam_cc_xo_clk_src.clkr.hw,
2515 			},
2516 			.num_parents = 1,
2517 			.flags = CLK_SET_RATE_PARENT,
2518 			.ops = &clk_branch2_ops,
2519 		},
2520 	},
2521 };
2522 
2523 static struct clk_branch cam_cc_icp_ahb_clk = {
2524 	.halt_reg = 0x138fc,
2525 	.halt_check = BRANCH_HALT,
2526 	.clkr = {
2527 		.enable_reg = 0x138fc,
2528 		.enable_mask = BIT(0),
2529 		.hw.init = &(const struct clk_init_data) {
2530 			.name = "cam_cc_icp_ahb_clk",
2531 			.parent_hws = (const struct clk_hw*[]) {
2532 				&cam_cc_slow_ahb_clk_src.clkr.hw,
2533 			},
2534 			.num_parents = 1,
2535 			.flags = CLK_SET_RATE_PARENT,
2536 			.ops = &clk_branch2_ops,
2537 		},
2538 	},
2539 };
2540 
2541 static struct clk_branch cam_cc_icp_clk = {
2542 	.halt_reg = 0x138f0,
2543 	.halt_check = BRANCH_HALT,
2544 	.clkr = {
2545 		.enable_reg = 0x138f0,
2546 		.enable_mask = BIT(0),
2547 		.hw.init = &(const struct clk_init_data) {
2548 			.name = "cam_cc_icp_clk",
2549 			.parent_hws = (const struct clk_hw*[]) {
2550 				&cam_cc_icp_clk_src.clkr.hw,
2551 			},
2552 			.num_parents = 1,
2553 			.flags = CLK_SET_RATE_PARENT,
2554 			.ops = &clk_branch2_ops,
2555 		},
2556 	},
2557 };
2558 
2559 static struct clk_branch cam_cc_ife_0_clk = {
2560 	.halt_reg = 0x11144,
2561 	.halt_check = BRANCH_HALT,
2562 	.clkr = {
2563 		.enable_reg = 0x11144,
2564 		.enable_mask = BIT(0),
2565 		.hw.init = &(const struct clk_init_data) {
2566 			.name = "cam_cc_ife_0_clk",
2567 			.parent_hws = (const struct clk_hw*[]) {
2568 				&cam_cc_ife_0_clk_src.clkr.hw,
2569 			},
2570 			.num_parents = 1,
2571 			.flags = CLK_SET_RATE_PARENT,
2572 			.ops = &clk_branch2_ops,
2573 		},
2574 	},
2575 };
2576 
2577 static struct clk_branch cam_cc_ife_0_dsp_clk = {
2578 	.halt_reg = 0x11280,
2579 	.halt_check = BRANCH_HALT,
2580 	.clkr = {
2581 		.enable_reg = 0x11280,
2582 		.enable_mask = BIT(0),
2583 		.hw.init = &(const struct clk_init_data) {
2584 			.name = "cam_cc_ife_0_dsp_clk",
2585 			.parent_hws = (const struct clk_hw*[]) {
2586 				&cam_cc_ife_0_dsp_clk_src.clkr.hw,
2587 			},
2588 			.num_parents = 1,
2589 			.flags = CLK_SET_RATE_PARENT,
2590 			.ops = &clk_branch2_ops,
2591 		},
2592 	},
2593 };
2594 
2595 static struct clk_branch cam_cc_ife_0_fast_ahb_clk = {
2596 	.halt_reg = 0x1128c,
2597 	.halt_check = BRANCH_HALT,
2598 	.clkr = {
2599 		.enable_reg = 0x1128c,
2600 		.enable_mask = BIT(0),
2601 		.hw.init = &(const struct clk_init_data) {
2602 			.name = "cam_cc_ife_0_fast_ahb_clk",
2603 			.parent_hws = (const struct clk_hw*[]) {
2604 				&cam_cc_fast_ahb_clk_src.clkr.hw,
2605 			},
2606 			.num_parents = 1,
2607 			.flags = CLK_SET_RATE_PARENT,
2608 			.ops = &clk_branch2_ops,
2609 		},
2610 	},
2611 };
2612 
2613 static struct clk_branch cam_cc_ife_1_clk = {
2614 	.halt_reg = 0x12144,
2615 	.halt_check = BRANCH_HALT,
2616 	.clkr = {
2617 		.enable_reg = 0x12144,
2618 		.enable_mask = BIT(0),
2619 		.hw.init = &(const struct clk_init_data) {
2620 			.name = "cam_cc_ife_1_clk",
2621 			.parent_hws = (const struct clk_hw*[]) {
2622 				&cam_cc_ife_1_clk_src.clkr.hw,
2623 			},
2624 			.num_parents = 1,
2625 			.flags = CLK_SET_RATE_PARENT,
2626 			.ops = &clk_branch2_ops,
2627 		},
2628 	},
2629 };
2630 
2631 static struct clk_branch cam_cc_ife_1_dsp_clk = {
2632 	.halt_reg = 0x12280,
2633 	.halt_check = BRANCH_HALT,
2634 	.clkr = {
2635 		.enable_reg = 0x12280,
2636 		.enable_mask = BIT(0),
2637 		.hw.init = &(const struct clk_init_data) {
2638 			.name = "cam_cc_ife_1_dsp_clk",
2639 			.parent_hws = (const struct clk_hw*[]) {
2640 				&cam_cc_ife_1_dsp_clk_src.clkr.hw,
2641 			},
2642 			.num_parents = 1,
2643 			.flags = CLK_SET_RATE_PARENT,
2644 			.ops = &clk_branch2_ops,
2645 		},
2646 	},
2647 };
2648 
2649 static struct clk_branch cam_cc_ife_1_fast_ahb_clk = {
2650 	.halt_reg = 0x1228c,
2651 	.halt_check = BRANCH_HALT,
2652 	.clkr = {
2653 		.enable_reg = 0x1228c,
2654 		.enable_mask = BIT(0),
2655 		.hw.init = &(const struct clk_init_data) {
2656 			.name = "cam_cc_ife_1_fast_ahb_clk",
2657 			.parent_hws = (const struct clk_hw*[]) {
2658 				&cam_cc_fast_ahb_clk_src.clkr.hw,
2659 			},
2660 			.num_parents = 1,
2661 			.flags = CLK_SET_RATE_PARENT,
2662 			.ops = &clk_branch2_ops,
2663 		},
2664 	},
2665 };
2666 
2667 static struct clk_branch cam_cc_ife_2_clk = {
2668 	.halt_reg = 0x123d4,
2669 	.halt_check = BRANCH_HALT,
2670 	.clkr = {
2671 		.enable_reg = 0x123d4,
2672 		.enable_mask = BIT(0),
2673 		.hw.init = &(const struct clk_init_data) {
2674 			.name = "cam_cc_ife_2_clk",
2675 			.parent_hws = (const struct clk_hw*[]) {
2676 				&cam_cc_ife_2_clk_src.clkr.hw,
2677 			},
2678 			.num_parents = 1,
2679 			.flags = CLK_SET_RATE_PARENT,
2680 			.ops = &clk_branch2_ops,
2681 		},
2682 	},
2683 };
2684 
2685 static struct clk_branch cam_cc_ife_2_dsp_clk = {
2686 	.halt_reg = 0x12510,
2687 	.halt_check = BRANCH_HALT,
2688 	.clkr = {
2689 		.enable_reg = 0x12510,
2690 		.enable_mask = BIT(0),
2691 		.hw.init = &(const struct clk_init_data) {
2692 			.name = "cam_cc_ife_2_dsp_clk",
2693 			.parent_hws = (const struct clk_hw*[]) {
2694 				&cam_cc_ife_2_dsp_clk_src.clkr.hw,
2695 			},
2696 			.num_parents = 1,
2697 			.flags = CLK_SET_RATE_PARENT,
2698 			.ops = &clk_branch2_ops,
2699 		},
2700 	},
2701 };
2702 
2703 static struct clk_branch cam_cc_ife_2_fast_ahb_clk = {
2704 	.halt_reg = 0x1251c,
2705 	.halt_check = BRANCH_HALT,
2706 	.clkr = {
2707 		.enable_reg = 0x1251c,
2708 		.enable_mask = BIT(0),
2709 		.hw.init = &(const struct clk_init_data) {
2710 			.name = "cam_cc_ife_2_fast_ahb_clk",
2711 			.parent_hws = (const struct clk_hw*[]) {
2712 				&cam_cc_fast_ahb_clk_src.clkr.hw,
2713 			},
2714 			.num_parents = 1,
2715 			.flags = CLK_SET_RATE_PARENT,
2716 			.ops = &clk_branch2_ops,
2717 		},
2718 	},
2719 };
2720 
2721 static struct clk_branch cam_cc_ife_lite_ahb_clk = {
2722 	.halt_reg = 0x13278,
2723 	.halt_check = BRANCH_HALT,
2724 	.clkr = {
2725 		.enable_reg = 0x13278,
2726 		.enable_mask = BIT(0),
2727 		.hw.init = &(const struct clk_init_data) {
2728 			.name = "cam_cc_ife_lite_ahb_clk",
2729 			.parent_hws = (const struct clk_hw*[]) {
2730 				&cam_cc_slow_ahb_clk_src.clkr.hw,
2731 			},
2732 			.num_parents = 1,
2733 			.flags = CLK_SET_RATE_PARENT,
2734 			.ops = &clk_branch2_ops,
2735 		},
2736 	},
2737 };
2738 
2739 static struct clk_branch cam_cc_ife_lite_clk = {
2740 	.halt_reg = 0x1312c,
2741 	.halt_check = BRANCH_HALT,
2742 	.clkr = {
2743 		.enable_reg = 0x1312c,
2744 		.enable_mask = BIT(0),
2745 		.hw.init = &(const struct clk_init_data) {
2746 			.name = "cam_cc_ife_lite_clk",
2747 			.parent_hws = (const struct clk_hw*[]) {
2748 				&cam_cc_ife_lite_clk_src.clkr.hw,
2749 			},
2750 			.num_parents = 1,
2751 			.flags = CLK_SET_RATE_PARENT,
2752 			.ops = &clk_branch2_ops,
2753 		},
2754 	},
2755 };
2756 
2757 static struct clk_branch cam_cc_ife_lite_cphy_rx_clk = {
2758 	.halt_reg = 0x13274,
2759 	.halt_check = BRANCH_HALT,
2760 	.clkr = {
2761 		.enable_reg = 0x13274,
2762 		.enable_mask = BIT(0),
2763 		.hw.init = &(const struct clk_init_data) {
2764 			.name = "cam_cc_ife_lite_cphy_rx_clk",
2765 			.parent_hws = (const struct clk_hw*[]) {
2766 				&cam_cc_cphy_rx_clk_src.clkr.hw,
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 cam_cc_ife_lite_csid_clk = {
2776 	.halt_reg = 0x13268,
2777 	.halt_check = BRANCH_HALT,
2778 	.clkr = {
2779 		.enable_reg = 0x13268,
2780 		.enable_mask = BIT(0),
2781 		.hw.init = &(const struct clk_init_data) {
2782 			.name = "cam_cc_ife_lite_csid_clk",
2783 			.parent_hws = (const struct clk_hw*[]) {
2784 				&cam_cc_ife_lite_csid_clk_src.clkr.hw,
2785 			},
2786 			.num_parents = 1,
2787 			.flags = CLK_SET_RATE_PARENT,
2788 			.ops = &clk_branch2_ops,
2789 		},
2790 	},
2791 };
2792 
2793 static struct clk_branch cam_cc_ipe_nps_ahb_clk = {
2794 	.halt_reg = 0x1051c,
2795 	.halt_check = BRANCH_HALT,
2796 	.clkr = {
2797 		.enable_reg = 0x1051c,
2798 		.enable_mask = BIT(0),
2799 		.hw.init = &(const struct clk_init_data) {
2800 			.name = "cam_cc_ipe_nps_ahb_clk",
2801 			.parent_hws = (const struct clk_hw*[]) {
2802 				&cam_cc_slow_ahb_clk_src.clkr.hw,
2803 			},
2804 			.num_parents = 1,
2805 			.flags = CLK_SET_RATE_PARENT,
2806 			.ops = &clk_branch2_ops,
2807 		},
2808 	},
2809 };
2810 
2811 static struct clk_branch cam_cc_ipe_nps_clk = {
2812 	.halt_reg = 0x104f8,
2813 	.halt_check = BRANCH_HALT,
2814 	.clkr = {
2815 		.enable_reg = 0x104f8,
2816 		.enable_mask = BIT(0),
2817 		.hw.init = &(const struct clk_init_data) {
2818 			.name = "cam_cc_ipe_nps_clk",
2819 			.parent_hws = (const struct clk_hw*[]) {
2820 				&cam_cc_ipe_nps_clk_src.clkr.hw,
2821 			},
2822 			.num_parents = 1,
2823 			.flags = CLK_SET_RATE_PARENT,
2824 			.ops = &clk_branch2_ops,
2825 		},
2826 	},
2827 };
2828 
2829 static struct clk_branch cam_cc_ipe_nps_fast_ahb_clk = {
2830 	.halt_reg = 0x10520,
2831 	.halt_check = BRANCH_HALT,
2832 	.clkr = {
2833 		.enable_reg = 0x10520,
2834 		.enable_mask = BIT(0),
2835 		.hw.init = &(const struct clk_init_data) {
2836 			.name = "cam_cc_ipe_nps_fast_ahb_clk",
2837 			.parent_hws = (const struct clk_hw*[]) {
2838 				&cam_cc_fast_ahb_clk_src.clkr.hw,
2839 			},
2840 			.num_parents = 1,
2841 			.flags = CLK_SET_RATE_PARENT,
2842 			.ops = &clk_branch2_ops,
2843 		},
2844 	},
2845 };
2846 
2847 static struct clk_branch cam_cc_ipe_pps_clk = {
2848 	.halt_reg = 0x10508,
2849 	.halt_check = BRANCH_HALT,
2850 	.clkr = {
2851 		.enable_reg = 0x10508,
2852 		.enable_mask = BIT(0),
2853 		.hw.init = &(const struct clk_init_data) {
2854 			.name = "cam_cc_ipe_pps_clk",
2855 			.parent_hws = (const struct clk_hw*[]) {
2856 				&cam_cc_ipe_nps_clk_src.clkr.hw,
2857 			},
2858 			.num_parents = 1,
2859 			.flags = CLK_SET_RATE_PARENT,
2860 			.ops = &clk_branch2_ops,
2861 		},
2862 	},
2863 };
2864 
2865 static struct clk_branch cam_cc_ipe_pps_fast_ahb_clk = {
2866 	.halt_reg = 0x10524,
2867 	.halt_check = BRANCH_HALT,
2868 	.clkr = {
2869 		.enable_reg = 0x10524,
2870 		.enable_mask = BIT(0),
2871 		.hw.init = &(const struct clk_init_data) {
2872 			.name = "cam_cc_ipe_pps_fast_ahb_clk",
2873 			.parent_hws = (const struct clk_hw*[]) {
2874 				&cam_cc_fast_ahb_clk_src.clkr.hw,
2875 			},
2876 			.num_parents = 1,
2877 			.flags = CLK_SET_RATE_PARENT,
2878 			.ops = &clk_branch2_ops,
2879 		},
2880 	},
2881 };
2882 
2883 static struct clk_branch cam_cc_jpeg_1_clk = {
2884 	.halt_reg = 0x137ac,
2885 	.halt_check = BRANCH_HALT,
2886 	.clkr = {
2887 		.enable_reg = 0x137ac,
2888 		.enable_mask = BIT(0),
2889 		.hw.init = &(const struct clk_init_data) {
2890 			.name = "cam_cc_jpeg_1_clk",
2891 			.parent_hws = (const struct clk_hw*[]) {
2892 				&cam_cc_jpeg_clk_src.clkr.hw,
2893 			},
2894 			.num_parents = 1,
2895 			.flags = CLK_SET_RATE_PARENT,
2896 			.ops = &clk_branch2_ops,
2897 		},
2898 	},
2899 };
2900 
2901 static struct clk_branch cam_cc_jpeg_clk = {
2902 	.halt_reg = 0x137a0,
2903 	.halt_check = BRANCH_HALT,
2904 	.clkr = {
2905 		.enable_reg = 0x137a0,
2906 		.enable_mask = BIT(0),
2907 		.hw.init = &(const struct clk_init_data) {
2908 			.name = "cam_cc_jpeg_clk",
2909 			.parent_hws = (const struct clk_hw*[]) {
2910 				&cam_cc_jpeg_clk_src.clkr.hw,
2911 			},
2912 			.num_parents = 1,
2913 			.flags = CLK_SET_RATE_PARENT,
2914 			.ops = &clk_branch2_ops,
2915 		},
2916 	},
2917 };
2918 
2919 static struct clk_branch cam_cc_mclk0_clk = {
2920 	.halt_reg = 0x1512c,
2921 	.halt_check = BRANCH_HALT,
2922 	.clkr = {
2923 		.enable_reg = 0x1512c,
2924 		.enable_mask = BIT(0),
2925 		.hw.init = &(const struct clk_init_data) {
2926 			.name = "cam_cc_mclk0_clk",
2927 			.parent_hws = (const struct clk_hw*[]) {
2928 				&cam_cc_mclk0_clk_src.clkr.hw,
2929 			},
2930 			.num_parents = 1,
2931 			.flags = CLK_SET_RATE_PARENT,
2932 			.ops = &clk_branch2_ops,
2933 		},
2934 	},
2935 };
2936 
2937 static struct clk_branch cam_cc_mclk1_clk = {
2938 	.halt_reg = 0x1525c,
2939 	.halt_check = BRANCH_HALT,
2940 	.clkr = {
2941 		.enable_reg = 0x1525c,
2942 		.enable_mask = BIT(0),
2943 		.hw.init = &(const struct clk_init_data) {
2944 			.name = "cam_cc_mclk1_clk",
2945 			.parent_hws = (const struct clk_hw*[]) {
2946 				&cam_cc_mclk1_clk_src.clkr.hw,
2947 			},
2948 			.num_parents = 1,
2949 			.flags = CLK_SET_RATE_PARENT,
2950 			.ops = &clk_branch2_ops,
2951 		},
2952 	},
2953 };
2954 
2955 static struct clk_branch cam_cc_mclk2_clk = {
2956 	.halt_reg = 0x1538c,
2957 	.halt_check = BRANCH_HALT,
2958 	.clkr = {
2959 		.enable_reg = 0x1538c,
2960 		.enable_mask = BIT(0),
2961 		.hw.init = &(const struct clk_init_data) {
2962 			.name = "cam_cc_mclk2_clk",
2963 			.parent_hws = (const struct clk_hw*[]) {
2964 				&cam_cc_mclk2_clk_src.clkr.hw,
2965 			},
2966 			.num_parents = 1,
2967 			.flags = CLK_SET_RATE_PARENT,
2968 			.ops = &clk_branch2_ops,
2969 		},
2970 	},
2971 };
2972 
2973 static struct clk_branch cam_cc_mclk3_clk = {
2974 	.halt_reg = 0x154bc,
2975 	.halt_check = BRANCH_HALT,
2976 	.clkr = {
2977 		.enable_reg = 0x154bc,
2978 		.enable_mask = BIT(0),
2979 		.hw.init = &(const struct clk_init_data) {
2980 			.name = "cam_cc_mclk3_clk",
2981 			.parent_hws = (const struct clk_hw*[]) {
2982 				&cam_cc_mclk3_clk_src.clkr.hw,
2983 			},
2984 			.num_parents = 1,
2985 			.flags = CLK_SET_RATE_PARENT,
2986 			.ops = &clk_branch2_ops,
2987 		},
2988 	},
2989 };
2990 
2991 static struct clk_branch cam_cc_mclk4_clk = {
2992 	.halt_reg = 0x155ec,
2993 	.halt_check = BRANCH_HALT,
2994 	.clkr = {
2995 		.enable_reg = 0x155ec,
2996 		.enable_mask = BIT(0),
2997 		.hw.init = &(const struct clk_init_data) {
2998 			.name = "cam_cc_mclk4_clk",
2999 			.parent_hws = (const struct clk_hw*[]) {
3000 				&cam_cc_mclk4_clk_src.clkr.hw,
3001 			},
3002 			.num_parents = 1,
3003 			.flags = CLK_SET_RATE_PARENT,
3004 			.ops = &clk_branch2_ops,
3005 		},
3006 	},
3007 };
3008 
3009 static struct clk_branch cam_cc_mclk5_clk = {
3010 	.halt_reg = 0x1571c,
3011 	.halt_check = BRANCH_HALT,
3012 	.clkr = {
3013 		.enable_reg = 0x1571c,
3014 		.enable_mask = BIT(0),
3015 		.hw.init = &(const struct clk_init_data) {
3016 			.name = "cam_cc_mclk5_clk",
3017 			.parent_hws = (const struct clk_hw*[]) {
3018 				&cam_cc_mclk5_clk_src.clkr.hw,
3019 			},
3020 			.num_parents = 1,
3021 			.flags = CLK_SET_RATE_PARENT,
3022 			.ops = &clk_branch2_ops,
3023 		},
3024 	},
3025 };
3026 
3027 static struct clk_branch cam_cc_mclk6_clk = {
3028 	.halt_reg = 0x1584c,
3029 	.halt_check = BRANCH_HALT,
3030 	.clkr = {
3031 		.enable_reg = 0x1584c,
3032 		.enable_mask = BIT(0),
3033 		.hw.init = &(const struct clk_init_data) {
3034 			.name = "cam_cc_mclk6_clk",
3035 			.parent_hws = (const struct clk_hw*[]) {
3036 				&cam_cc_mclk6_clk_src.clkr.hw,
3037 			},
3038 			.num_parents = 1,
3039 			.flags = CLK_SET_RATE_PARENT,
3040 			.ops = &clk_branch2_ops,
3041 		},
3042 	},
3043 };
3044 
3045 static struct clk_branch cam_cc_mclk7_clk = {
3046 	.halt_reg = 0x1597c,
3047 	.halt_check = BRANCH_HALT,
3048 	.clkr = {
3049 		.enable_reg = 0x1597c,
3050 		.enable_mask = BIT(0),
3051 		.hw.init = &(const struct clk_init_data) {
3052 			.name = "cam_cc_mclk7_clk",
3053 			.parent_hws = (const struct clk_hw*[]) {
3054 				&cam_cc_mclk7_clk_src.clkr.hw,
3055 			},
3056 			.num_parents = 1,
3057 			.flags = CLK_SET_RATE_PARENT,
3058 			.ops = &clk_branch2_ops,
3059 		},
3060 	},
3061 };
3062 
3063 static struct clk_branch cam_cc_qdss_debug_clk = {
3064 	.halt_reg = 0x14050,
3065 	.halt_check = BRANCH_HALT,
3066 	.clkr = {
3067 		.enable_reg = 0x14050,
3068 		.enable_mask = BIT(0),
3069 		.hw.init = &(const struct clk_init_data) {
3070 			.name = "cam_cc_qdss_debug_clk",
3071 			.parent_hws = (const struct clk_hw*[]) {
3072 				&cam_cc_qdss_debug_clk_src.clkr.hw,
3073 			},
3074 			.num_parents = 1,
3075 			.flags = CLK_SET_RATE_PARENT,
3076 			.ops = &clk_branch2_ops,
3077 		},
3078 	},
3079 };
3080 
3081 static struct clk_branch cam_cc_qdss_debug_xo_clk = {
3082 	.halt_reg = 0x14054,
3083 	.halt_check = BRANCH_HALT,
3084 	.clkr = {
3085 		.enable_reg = 0x14054,
3086 		.enable_mask = BIT(0),
3087 		.hw.init = &(const struct clk_init_data) {
3088 			.name = "cam_cc_qdss_debug_xo_clk",
3089 			.parent_hws = (const struct clk_hw*[]) {
3090 				&cam_cc_xo_clk_src.clkr.hw,
3091 			},
3092 			.num_parents = 1,
3093 			.flags = CLK_SET_RATE_PARENT,
3094 			.ops = &clk_branch2_ops,
3095 		},
3096 	},
3097 };
3098 
3099 static struct clk_branch cam_cc_sbi_clk = {
3100 	.halt_reg = 0x10540,
3101 	.halt_check = BRANCH_HALT,
3102 	.clkr = {
3103 		.enable_reg = 0x10540,
3104 		.enable_mask = BIT(0),
3105 		.hw.init = &(const struct clk_init_data) {
3106 			.name = "cam_cc_sbi_clk",
3107 			.parent_hws = (const struct clk_hw*[]) {
3108 				&cam_cc_ife_0_clk_src.clkr.hw,
3109 			},
3110 			.num_parents = 1,
3111 			.flags = CLK_SET_RATE_PARENT,
3112 			.ops = &clk_branch2_ops,
3113 		},
3114 	},
3115 };
3116 
3117 static struct clk_branch cam_cc_sbi_fast_ahb_clk = {
3118 	.halt_reg = 0x10550,
3119 	.halt_check = BRANCH_HALT,
3120 	.clkr = {
3121 		.enable_reg = 0x10550,
3122 		.enable_mask = BIT(0),
3123 		.hw.init = &(const struct clk_init_data) {
3124 			.name = "cam_cc_sbi_fast_ahb_clk",
3125 			.parent_hws = (const struct clk_hw*[]) {
3126 				&cam_cc_fast_ahb_clk_src.clkr.hw,
3127 			},
3128 			.num_parents = 1,
3129 			.flags = CLK_SET_RATE_PARENT,
3130 			.ops = &clk_branch2_ops,
3131 		},
3132 	},
3133 };
3134 
3135 static struct clk_branch cam_cc_sfe_0_clk = {
3136 	.halt_reg = 0x133c0,
3137 	.halt_check = BRANCH_HALT,
3138 	.clkr = {
3139 		.enable_reg = 0x133c0,
3140 		.enable_mask = BIT(0),
3141 		.hw.init = &(const struct clk_init_data) {
3142 			.name = "cam_cc_sfe_0_clk",
3143 			.parent_hws = (const struct clk_hw*[]) {
3144 				&cam_cc_sfe_0_clk_src.clkr.hw,
3145 			},
3146 			.num_parents = 1,
3147 			.flags = CLK_SET_RATE_PARENT,
3148 			.ops = &clk_branch2_ops,
3149 		},
3150 	},
3151 };
3152 
3153 static struct clk_branch cam_cc_sfe_0_fast_ahb_clk = {
3154 	.halt_reg = 0x133d8,
3155 	.halt_check = BRANCH_HALT,
3156 	.clkr = {
3157 		.enable_reg = 0x133d8,
3158 		.enable_mask = BIT(0),
3159 		.hw.init = &(const struct clk_init_data) {
3160 			.name = "cam_cc_sfe_0_fast_ahb_clk",
3161 			.parent_hws = (const struct clk_hw*[]) {
3162 				&cam_cc_fast_ahb_clk_src.clkr.hw,
3163 			},
3164 			.num_parents = 1,
3165 			.flags = CLK_SET_RATE_PARENT,
3166 			.ops = &clk_branch2_ops,
3167 		},
3168 	},
3169 };
3170 
3171 static struct clk_branch cam_cc_sfe_1_clk = {
3172 	.halt_reg = 0x13520,
3173 	.halt_check = BRANCH_HALT,
3174 	.clkr = {
3175 		.enable_reg = 0x13520,
3176 		.enable_mask = BIT(0),
3177 		.hw.init = &(const struct clk_init_data) {
3178 			.name = "cam_cc_sfe_1_clk",
3179 			.parent_hws = (const struct clk_hw*[]) {
3180 				&cam_cc_sfe_1_clk_src.clkr.hw,
3181 			},
3182 			.num_parents = 1,
3183 			.flags = CLK_SET_RATE_PARENT,
3184 			.ops = &clk_branch2_ops,
3185 		},
3186 	},
3187 };
3188 
3189 static struct clk_branch cam_cc_sfe_1_fast_ahb_clk = {
3190 	.halt_reg = 0x13538,
3191 	.halt_check = BRANCH_HALT,
3192 	.clkr = {
3193 		.enable_reg = 0x13538,
3194 		.enable_mask = BIT(0),
3195 		.hw.init = &(const struct clk_init_data) {
3196 			.name = "cam_cc_sfe_1_fast_ahb_clk",
3197 			.parent_hws = (const struct clk_hw*[]) {
3198 				&cam_cc_fast_ahb_clk_src.clkr.hw,
3199 			},
3200 			.num_parents = 1,
3201 			.flags = CLK_SET_RATE_PARENT,
3202 			.ops = &clk_branch2_ops,
3203 		},
3204 	},
3205 };
3206 
3207 static struct gdsc cam_cc_bps_gdsc = {
3208 	.gdscr = 0x10004,
3209 	.en_rest_wait_val = 0x2,
3210 	.en_few_wait_val = 0x2,
3211 	.clk_dis_wait_val = 0xf,
3212 	.pd = {
3213 		.name = "cam_cc_bps_gdsc",
3214 	},
3215 	.pwrsts = PWRSTS_OFF_ON,
3216 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3217 };
3218 
3219 static struct gdsc cam_cc_ife_0_gdsc = {
3220 	.gdscr = 0x11004,
3221 	.en_rest_wait_val = 0x2,
3222 	.en_few_wait_val = 0x2,
3223 	.clk_dis_wait_val = 0xf,
3224 	.pd = {
3225 		.name = "cam_cc_ife_0_gdsc",
3226 	},
3227 	.pwrsts = PWRSTS_OFF_ON,
3228 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3229 };
3230 
3231 static struct gdsc cam_cc_ife_1_gdsc = {
3232 	.gdscr = 0x12004,
3233 	.en_rest_wait_val = 0x2,
3234 	.en_few_wait_val = 0x2,
3235 	.clk_dis_wait_val = 0xf,
3236 	.pd = {
3237 		.name = "cam_cc_ife_1_gdsc",
3238 	},
3239 	.pwrsts = PWRSTS_OFF_ON,
3240 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3241 };
3242 
3243 static struct gdsc cam_cc_ife_2_gdsc = {
3244 	.gdscr = 0x12294,
3245 	.en_rest_wait_val = 0x2,
3246 	.en_few_wait_val = 0x2,
3247 	.clk_dis_wait_val = 0xf,
3248 	.pd = {
3249 		.name = "cam_cc_ife_2_gdsc",
3250 	},
3251 	.pwrsts = PWRSTS_OFF_ON,
3252 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3253 };
3254 
3255 static struct gdsc cam_cc_ipe_0_gdsc = {
3256 	.gdscr = 0x103b8,
3257 	.en_rest_wait_val = 0x2,
3258 	.en_few_wait_val = 0x2,
3259 	.clk_dis_wait_val = 0xf,
3260 	.pd = {
3261 		.name = "cam_cc_ipe_0_gdsc",
3262 	},
3263 	.pwrsts = PWRSTS_OFF_ON,
3264 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3265 };
3266 
3267 static struct gdsc cam_cc_sbi_gdsc = {
3268 	.gdscr = 0x1052c,
3269 	.en_rest_wait_val = 0x2,
3270 	.en_few_wait_val = 0x2,
3271 	.clk_dis_wait_val = 0xf,
3272 	.pd = {
3273 		.name = "cam_cc_sbi_gdsc",
3274 	},
3275 	.pwrsts = PWRSTS_OFF_ON,
3276 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3277 };
3278 
3279 static struct gdsc cam_cc_sfe_0_gdsc = {
3280 	.gdscr = 0x13280,
3281 	.en_rest_wait_val = 0x2,
3282 	.en_few_wait_val = 0x2,
3283 	.clk_dis_wait_val = 0xf,
3284 	.pd = {
3285 		.name = "cam_cc_sfe_0_gdsc",
3286 	},
3287 	.pwrsts = PWRSTS_OFF_ON,
3288 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3289 };
3290 
3291 static struct gdsc cam_cc_sfe_1_gdsc = {
3292 	.gdscr = 0x133e0,
3293 	.en_rest_wait_val = 0x2,
3294 	.en_few_wait_val = 0x2,
3295 	.clk_dis_wait_val = 0xf,
3296 	.pd = {
3297 		.name = "cam_cc_sfe_1_gdsc",
3298 	},
3299 	.pwrsts = PWRSTS_OFF_ON,
3300 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3301 };
3302 
3303 static struct gdsc cam_cc_titan_top_gdsc = {
3304 	.gdscr = 0x14058,
3305 	.en_rest_wait_val = 0x2,
3306 	.en_few_wait_val = 0x2,
3307 	.clk_dis_wait_val = 0xf,
3308 	.pd = {
3309 		.name = "cam_cc_titan_top_gdsc",
3310 	},
3311 	.pwrsts = PWRSTS_OFF_ON,
3312 	.flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE,
3313 };
3314 
3315 static struct clk_regmap *cam_cc_sm8550_clocks[] = {
3316 	[CAM_CC_BPS_AHB_CLK] = &cam_cc_bps_ahb_clk.clkr,
3317 	[CAM_CC_BPS_CLK] = &cam_cc_bps_clk.clkr,
3318 	[CAM_CC_BPS_CLK_SRC] = &cam_cc_bps_clk_src.clkr,
3319 	[CAM_CC_BPS_FAST_AHB_CLK] = &cam_cc_bps_fast_ahb_clk.clkr,
3320 	[CAM_CC_CAMNOC_AXI_CLK] = &cam_cc_camnoc_axi_clk.clkr,
3321 	[CAM_CC_CAMNOC_AXI_CLK_SRC] = &cam_cc_camnoc_axi_clk_src.clkr,
3322 	[CAM_CC_CAMNOC_DCD_XO_CLK] = &cam_cc_camnoc_dcd_xo_clk.clkr,
3323 	[CAM_CC_CAMNOC_XO_CLK] = &cam_cc_camnoc_xo_clk.clkr,
3324 	[CAM_CC_CCI_0_CLK] = &cam_cc_cci_0_clk.clkr,
3325 	[CAM_CC_CCI_0_CLK_SRC] = &cam_cc_cci_0_clk_src.clkr,
3326 	[CAM_CC_CCI_1_CLK] = &cam_cc_cci_1_clk.clkr,
3327 	[CAM_CC_CCI_1_CLK_SRC] = &cam_cc_cci_1_clk_src.clkr,
3328 	[CAM_CC_CCI_2_CLK] = &cam_cc_cci_2_clk.clkr,
3329 	[CAM_CC_CCI_2_CLK_SRC] = &cam_cc_cci_2_clk_src.clkr,
3330 	[CAM_CC_CORE_AHB_CLK] = &cam_cc_core_ahb_clk.clkr,
3331 	[CAM_CC_CPAS_AHB_CLK] = &cam_cc_cpas_ahb_clk.clkr,
3332 	[CAM_CC_CPAS_BPS_CLK] = &cam_cc_cpas_bps_clk.clkr,
3333 	[CAM_CC_CPAS_CRE_CLK] = &cam_cc_cpas_cre_clk.clkr,
3334 	[CAM_CC_CPAS_FAST_AHB_CLK] = &cam_cc_cpas_fast_ahb_clk.clkr,
3335 	[CAM_CC_CPAS_IFE_0_CLK] = &cam_cc_cpas_ife_0_clk.clkr,
3336 	[CAM_CC_CPAS_IFE_1_CLK] = &cam_cc_cpas_ife_1_clk.clkr,
3337 	[CAM_CC_CPAS_IFE_2_CLK] = &cam_cc_cpas_ife_2_clk.clkr,
3338 	[CAM_CC_CPAS_IFE_LITE_CLK] = &cam_cc_cpas_ife_lite_clk.clkr,
3339 	[CAM_CC_CPAS_IPE_NPS_CLK] = &cam_cc_cpas_ipe_nps_clk.clkr,
3340 	[CAM_CC_CPAS_SBI_CLK] = &cam_cc_cpas_sbi_clk.clkr,
3341 	[CAM_CC_CPAS_SFE_0_CLK] = &cam_cc_cpas_sfe_0_clk.clkr,
3342 	[CAM_CC_CPAS_SFE_1_CLK] = &cam_cc_cpas_sfe_1_clk.clkr,
3343 	[CAM_CC_CPHY_RX_CLK_SRC] = &cam_cc_cphy_rx_clk_src.clkr,
3344 	[CAM_CC_CRE_AHB_CLK] = &cam_cc_cre_ahb_clk.clkr,
3345 	[CAM_CC_CRE_CLK] = &cam_cc_cre_clk.clkr,
3346 	[CAM_CC_CRE_CLK_SRC] = &cam_cc_cre_clk_src.clkr,
3347 	[CAM_CC_CSI0PHYTIMER_CLK] = &cam_cc_csi0phytimer_clk.clkr,
3348 	[CAM_CC_CSI0PHYTIMER_CLK_SRC] = &cam_cc_csi0phytimer_clk_src.clkr,
3349 	[CAM_CC_CSI1PHYTIMER_CLK] = &cam_cc_csi1phytimer_clk.clkr,
3350 	[CAM_CC_CSI1PHYTIMER_CLK_SRC] = &cam_cc_csi1phytimer_clk_src.clkr,
3351 	[CAM_CC_CSI2PHYTIMER_CLK] = &cam_cc_csi2phytimer_clk.clkr,
3352 	[CAM_CC_CSI2PHYTIMER_CLK_SRC] = &cam_cc_csi2phytimer_clk_src.clkr,
3353 	[CAM_CC_CSI3PHYTIMER_CLK] = &cam_cc_csi3phytimer_clk.clkr,
3354 	[CAM_CC_CSI3PHYTIMER_CLK_SRC] = &cam_cc_csi3phytimer_clk_src.clkr,
3355 	[CAM_CC_CSI4PHYTIMER_CLK] = &cam_cc_csi4phytimer_clk.clkr,
3356 	[CAM_CC_CSI4PHYTIMER_CLK_SRC] = &cam_cc_csi4phytimer_clk_src.clkr,
3357 	[CAM_CC_CSI5PHYTIMER_CLK] = &cam_cc_csi5phytimer_clk.clkr,
3358 	[CAM_CC_CSI5PHYTIMER_CLK_SRC] = &cam_cc_csi5phytimer_clk_src.clkr,
3359 	[CAM_CC_CSI6PHYTIMER_CLK] = &cam_cc_csi6phytimer_clk.clkr,
3360 	[CAM_CC_CSI6PHYTIMER_CLK_SRC] = &cam_cc_csi6phytimer_clk_src.clkr,
3361 	[CAM_CC_CSI7PHYTIMER_CLK] = &cam_cc_csi7phytimer_clk.clkr,
3362 	[CAM_CC_CSI7PHYTIMER_CLK_SRC] = &cam_cc_csi7phytimer_clk_src.clkr,
3363 	[CAM_CC_CSID_CLK] = &cam_cc_csid_clk.clkr,
3364 	[CAM_CC_CSID_CLK_SRC] = &cam_cc_csid_clk_src.clkr,
3365 	[CAM_CC_CSID_CSIPHY_RX_CLK] = &cam_cc_csid_csiphy_rx_clk.clkr,
3366 	[CAM_CC_CSIPHY0_CLK] = &cam_cc_csiphy0_clk.clkr,
3367 	[CAM_CC_CSIPHY1_CLK] = &cam_cc_csiphy1_clk.clkr,
3368 	[CAM_CC_CSIPHY2_CLK] = &cam_cc_csiphy2_clk.clkr,
3369 	[CAM_CC_CSIPHY3_CLK] = &cam_cc_csiphy3_clk.clkr,
3370 	[CAM_CC_CSIPHY4_CLK] = &cam_cc_csiphy4_clk.clkr,
3371 	[CAM_CC_CSIPHY5_CLK] = &cam_cc_csiphy5_clk.clkr,
3372 	[CAM_CC_CSIPHY6_CLK] = &cam_cc_csiphy6_clk.clkr,
3373 	[CAM_CC_CSIPHY7_CLK] = &cam_cc_csiphy7_clk.clkr,
3374 	[CAM_CC_DRV_AHB_CLK] = &cam_cc_drv_ahb_clk.clkr,
3375 	[CAM_CC_DRV_XO_CLK] = &cam_cc_drv_xo_clk.clkr,
3376 	[CAM_CC_FAST_AHB_CLK_SRC] = &cam_cc_fast_ahb_clk_src.clkr,
3377 	[CAM_CC_ICP_AHB_CLK] = &cam_cc_icp_ahb_clk.clkr,
3378 	[CAM_CC_ICP_CLK] = &cam_cc_icp_clk.clkr,
3379 	[CAM_CC_ICP_CLK_SRC] = &cam_cc_icp_clk_src.clkr,
3380 	[CAM_CC_IFE_0_CLK] = &cam_cc_ife_0_clk.clkr,
3381 	[CAM_CC_IFE_0_CLK_SRC] = &cam_cc_ife_0_clk_src.clkr,
3382 	[CAM_CC_IFE_0_DSP_CLK] = &cam_cc_ife_0_dsp_clk.clkr,
3383 	[CAM_CC_IFE_0_DSP_CLK_SRC] = &cam_cc_ife_0_dsp_clk_src.clkr,
3384 	[CAM_CC_IFE_0_FAST_AHB_CLK] = &cam_cc_ife_0_fast_ahb_clk.clkr,
3385 	[CAM_CC_IFE_1_CLK] = &cam_cc_ife_1_clk.clkr,
3386 	[CAM_CC_IFE_1_CLK_SRC] = &cam_cc_ife_1_clk_src.clkr,
3387 	[CAM_CC_IFE_1_DSP_CLK] = &cam_cc_ife_1_dsp_clk.clkr,
3388 	[CAM_CC_IFE_1_DSP_CLK_SRC] = &cam_cc_ife_1_dsp_clk_src.clkr,
3389 	[CAM_CC_IFE_1_FAST_AHB_CLK] = &cam_cc_ife_1_fast_ahb_clk.clkr,
3390 	[CAM_CC_IFE_2_CLK] = &cam_cc_ife_2_clk.clkr,
3391 	[CAM_CC_IFE_2_CLK_SRC] = &cam_cc_ife_2_clk_src.clkr,
3392 	[CAM_CC_IFE_2_DSP_CLK] = &cam_cc_ife_2_dsp_clk.clkr,
3393 	[CAM_CC_IFE_2_DSP_CLK_SRC] = &cam_cc_ife_2_dsp_clk_src.clkr,
3394 	[CAM_CC_IFE_2_FAST_AHB_CLK] = &cam_cc_ife_2_fast_ahb_clk.clkr,
3395 	[CAM_CC_IFE_LITE_AHB_CLK] = &cam_cc_ife_lite_ahb_clk.clkr,
3396 	[CAM_CC_IFE_LITE_CLK] = &cam_cc_ife_lite_clk.clkr,
3397 	[CAM_CC_IFE_LITE_CLK_SRC] = &cam_cc_ife_lite_clk_src.clkr,
3398 	[CAM_CC_IFE_LITE_CPHY_RX_CLK] = &cam_cc_ife_lite_cphy_rx_clk.clkr,
3399 	[CAM_CC_IFE_LITE_CSID_CLK] = &cam_cc_ife_lite_csid_clk.clkr,
3400 	[CAM_CC_IFE_LITE_CSID_CLK_SRC] = &cam_cc_ife_lite_csid_clk_src.clkr,
3401 	[CAM_CC_IPE_NPS_AHB_CLK] = &cam_cc_ipe_nps_ahb_clk.clkr,
3402 	[CAM_CC_IPE_NPS_CLK] = &cam_cc_ipe_nps_clk.clkr,
3403 	[CAM_CC_IPE_NPS_CLK_SRC] = &cam_cc_ipe_nps_clk_src.clkr,
3404 	[CAM_CC_IPE_NPS_FAST_AHB_CLK] = &cam_cc_ipe_nps_fast_ahb_clk.clkr,
3405 	[CAM_CC_IPE_PPS_CLK] = &cam_cc_ipe_pps_clk.clkr,
3406 	[CAM_CC_IPE_PPS_FAST_AHB_CLK] = &cam_cc_ipe_pps_fast_ahb_clk.clkr,
3407 	[CAM_CC_JPEG_1_CLK] = &cam_cc_jpeg_1_clk.clkr,
3408 	[CAM_CC_JPEG_CLK] = &cam_cc_jpeg_clk.clkr,
3409 	[CAM_CC_JPEG_CLK_SRC] = &cam_cc_jpeg_clk_src.clkr,
3410 	[CAM_CC_MCLK0_CLK] = &cam_cc_mclk0_clk.clkr,
3411 	[CAM_CC_MCLK0_CLK_SRC] = &cam_cc_mclk0_clk_src.clkr,
3412 	[CAM_CC_MCLK1_CLK] = &cam_cc_mclk1_clk.clkr,
3413 	[CAM_CC_MCLK1_CLK_SRC] = &cam_cc_mclk1_clk_src.clkr,
3414 	[CAM_CC_MCLK2_CLK] = &cam_cc_mclk2_clk.clkr,
3415 	[CAM_CC_MCLK2_CLK_SRC] = &cam_cc_mclk2_clk_src.clkr,
3416 	[CAM_CC_MCLK3_CLK] = &cam_cc_mclk3_clk.clkr,
3417 	[CAM_CC_MCLK3_CLK_SRC] = &cam_cc_mclk3_clk_src.clkr,
3418 	[CAM_CC_MCLK4_CLK] = &cam_cc_mclk4_clk.clkr,
3419 	[CAM_CC_MCLK4_CLK_SRC] = &cam_cc_mclk4_clk_src.clkr,
3420 	[CAM_CC_MCLK5_CLK] = &cam_cc_mclk5_clk.clkr,
3421 	[CAM_CC_MCLK5_CLK_SRC] = &cam_cc_mclk5_clk_src.clkr,
3422 	[CAM_CC_MCLK6_CLK] = &cam_cc_mclk6_clk.clkr,
3423 	[CAM_CC_MCLK6_CLK_SRC] = &cam_cc_mclk6_clk_src.clkr,
3424 	[CAM_CC_MCLK7_CLK] = &cam_cc_mclk7_clk.clkr,
3425 	[CAM_CC_MCLK7_CLK_SRC] = &cam_cc_mclk7_clk_src.clkr,
3426 	[CAM_CC_PLL0] = &cam_cc_pll0.clkr,
3427 	[CAM_CC_PLL0_OUT_EVEN] = &cam_cc_pll0_out_even.clkr,
3428 	[CAM_CC_PLL0_OUT_ODD] = &cam_cc_pll0_out_odd.clkr,
3429 	[CAM_CC_PLL1] = &cam_cc_pll1.clkr,
3430 	[CAM_CC_PLL1_OUT_EVEN] = &cam_cc_pll1_out_even.clkr,
3431 	[CAM_CC_PLL2] = &cam_cc_pll2.clkr,
3432 	[CAM_CC_PLL3] = &cam_cc_pll3.clkr,
3433 	[CAM_CC_PLL3_OUT_EVEN] = &cam_cc_pll3_out_even.clkr,
3434 	[CAM_CC_PLL4] = &cam_cc_pll4.clkr,
3435 	[CAM_CC_PLL4_OUT_EVEN] = &cam_cc_pll4_out_even.clkr,
3436 	[CAM_CC_PLL5] = &cam_cc_pll5.clkr,
3437 	[CAM_CC_PLL5_OUT_EVEN] = &cam_cc_pll5_out_even.clkr,
3438 	[CAM_CC_PLL6] = &cam_cc_pll6.clkr,
3439 	[CAM_CC_PLL6_OUT_EVEN] = &cam_cc_pll6_out_even.clkr,
3440 	[CAM_CC_PLL7] = &cam_cc_pll7.clkr,
3441 	[CAM_CC_PLL7_OUT_EVEN] = &cam_cc_pll7_out_even.clkr,
3442 	[CAM_CC_PLL8] = &cam_cc_pll8.clkr,
3443 	[CAM_CC_PLL8_OUT_EVEN] = &cam_cc_pll8_out_even.clkr,
3444 	[CAM_CC_PLL9] = &cam_cc_pll9.clkr,
3445 	[CAM_CC_PLL9_OUT_EVEN] = &cam_cc_pll9_out_even.clkr,
3446 	[CAM_CC_PLL10] = &cam_cc_pll10.clkr,
3447 	[CAM_CC_PLL10_OUT_EVEN] = &cam_cc_pll10_out_even.clkr,
3448 	[CAM_CC_PLL11] = &cam_cc_pll11.clkr,
3449 	[CAM_CC_PLL11_OUT_EVEN] = &cam_cc_pll11_out_even.clkr,
3450 	[CAM_CC_PLL12] = &cam_cc_pll12.clkr,
3451 	[CAM_CC_PLL12_OUT_EVEN] = &cam_cc_pll12_out_even.clkr,
3452 	[CAM_CC_QDSS_DEBUG_CLK] = &cam_cc_qdss_debug_clk.clkr,
3453 	[CAM_CC_QDSS_DEBUG_CLK_SRC] = &cam_cc_qdss_debug_clk_src.clkr,
3454 	[CAM_CC_QDSS_DEBUG_XO_CLK] = &cam_cc_qdss_debug_xo_clk.clkr,
3455 	[CAM_CC_SBI_CLK] = &cam_cc_sbi_clk.clkr,
3456 	[CAM_CC_SBI_FAST_AHB_CLK] = &cam_cc_sbi_fast_ahb_clk.clkr,
3457 	[CAM_CC_SFE_0_CLK] = &cam_cc_sfe_0_clk.clkr,
3458 	[CAM_CC_SFE_0_CLK_SRC] = &cam_cc_sfe_0_clk_src.clkr,
3459 	[CAM_CC_SFE_0_FAST_AHB_CLK] = &cam_cc_sfe_0_fast_ahb_clk.clkr,
3460 	[CAM_CC_SFE_1_CLK] = &cam_cc_sfe_1_clk.clkr,
3461 	[CAM_CC_SFE_1_CLK_SRC] = &cam_cc_sfe_1_clk_src.clkr,
3462 	[CAM_CC_SFE_1_FAST_AHB_CLK] = &cam_cc_sfe_1_fast_ahb_clk.clkr,
3463 	[CAM_CC_SLEEP_CLK_SRC] = &cam_cc_sleep_clk_src.clkr,
3464 	[CAM_CC_SLOW_AHB_CLK_SRC] = &cam_cc_slow_ahb_clk_src.clkr,
3465 	[CAM_CC_XO_CLK_SRC] = &cam_cc_xo_clk_src.clkr,
3466 };
3467 
3468 static struct gdsc *cam_cc_sm8550_gdscs[] = {
3469 	[CAM_CC_BPS_GDSC] = &cam_cc_bps_gdsc,
3470 	[CAM_CC_IFE_0_GDSC] = &cam_cc_ife_0_gdsc,
3471 	[CAM_CC_IFE_1_GDSC] = &cam_cc_ife_1_gdsc,
3472 	[CAM_CC_IFE_2_GDSC] = &cam_cc_ife_2_gdsc,
3473 	[CAM_CC_IPE_0_GDSC] = &cam_cc_ipe_0_gdsc,
3474 	[CAM_CC_SBI_GDSC] = &cam_cc_sbi_gdsc,
3475 	[CAM_CC_SFE_0_GDSC] = &cam_cc_sfe_0_gdsc,
3476 	[CAM_CC_SFE_1_GDSC] = &cam_cc_sfe_1_gdsc,
3477 	[CAM_CC_TITAN_TOP_GDSC] = &cam_cc_titan_top_gdsc,
3478 };
3479 
3480 static const struct qcom_reset_map cam_cc_sm8550_resets[] = {
3481 	[CAM_CC_BPS_BCR] = { 0x10000 },
3482 	[CAM_CC_DRV_BCR] = { 0x142d0 },
3483 	[CAM_CC_ICP_BCR] = { 0x137c0 },
3484 	[CAM_CC_IFE_0_BCR] = { 0x11000 },
3485 	[CAM_CC_IFE_1_BCR] = { 0x12000 },
3486 	[CAM_CC_IFE_2_BCR] = { 0x12290 },
3487 	[CAM_CC_IPE_0_BCR] = { 0x103b4 },
3488 	[CAM_CC_QDSS_DEBUG_BCR] = { 0x13f20 },
3489 	[CAM_CC_SBI_BCR] = { 0x10528 },
3490 	[CAM_CC_SFE_0_BCR] = { 0x1327c },
3491 	[CAM_CC_SFE_1_BCR] = { 0x133dc },
3492 };
3493 
3494 static struct clk_alpha_pll *cam_cc_sm8550_plls[] = {
3495 	&cam_cc_pll0,
3496 	&cam_cc_pll1,
3497 	&cam_cc_pll2,
3498 	&cam_cc_pll3,
3499 	&cam_cc_pll4,
3500 	&cam_cc_pll5,
3501 	&cam_cc_pll6,
3502 	&cam_cc_pll7,
3503 	&cam_cc_pll8,
3504 	&cam_cc_pll9,
3505 	&cam_cc_pll10,
3506 	&cam_cc_pll11,
3507 	&cam_cc_pll12,
3508 };
3509 
3510 static u32 cam_cc_sm8550_critical_cbcrs[] = {
3511 	0x1419c, /* CAM_CC_GDSC_CLK */
3512 	0x142cc, /* CAM_CC_SLEEP_CLK */
3513 };
3514 
3515 static const struct regmap_config cam_cc_sm8550_regmap_config = {
3516 	.reg_bits = 32,
3517 	.reg_stride = 4,
3518 	.val_bits = 32,
3519 	.max_register = 0x16320,
3520 	.fast_io = true,
3521 };
3522 
3523 static struct qcom_cc_driver_data cam_cc_sm8550_driver_data = {
3524 	.alpha_plls = cam_cc_sm8550_plls,
3525 	.num_alpha_plls = ARRAY_SIZE(cam_cc_sm8550_plls),
3526 	.clk_cbcrs = cam_cc_sm8550_critical_cbcrs,
3527 	.num_clk_cbcrs = ARRAY_SIZE(cam_cc_sm8550_critical_cbcrs),
3528 };
3529 
3530 static const struct qcom_cc_desc cam_cc_sm8550_desc = {
3531 	.config = &cam_cc_sm8550_regmap_config,
3532 	.clks = cam_cc_sm8550_clocks,
3533 	.num_clks = ARRAY_SIZE(cam_cc_sm8550_clocks),
3534 	.resets = cam_cc_sm8550_resets,
3535 	.num_resets = ARRAY_SIZE(cam_cc_sm8550_resets),
3536 	.gdscs = cam_cc_sm8550_gdscs,
3537 	.num_gdscs = ARRAY_SIZE(cam_cc_sm8550_gdscs),
3538 	.use_rpm = true,
3539 	.driver_data = &cam_cc_sm8550_driver_data,
3540 };
3541 
3542 static const struct of_device_id cam_cc_sm8550_match_table[] = {
3543 	{ .compatible = "qcom,sm8550-camcc" },
3544 	{ }
3545 };
3546 MODULE_DEVICE_TABLE(of, cam_cc_sm8550_match_table);
3547 
3548 static int cam_cc_sm8550_probe(struct platform_device *pdev)
3549 {
3550 	return qcom_cc_probe(pdev, &cam_cc_sm8550_desc);
3551 }
3552 
3553 static struct platform_driver cam_cc_sm8550_driver = {
3554 	.probe = cam_cc_sm8550_probe,
3555 	.driver = {
3556 		.name = "cam_cc-sm8550",
3557 		.of_match_table = cam_cc_sm8550_match_table,
3558 	},
3559 };
3560 
3561 module_platform_driver(cam_cc_sm8550_driver);
3562 
3563 MODULE_DESCRIPTION("QTI CAMCC SM8550 Driver");
3564 MODULE_LICENSE("GPL");
3565