1// SPDX-License-Identifier: GPL-2.0-only
2/*
3 * Copyright (c) 2022, The Linux Foundation. All rights reserved.
4 * Copyright (c) 2022, Linaro Limited
5 */
6
7#include <linux/clk-provider.h>
8#include <linux/module.h>
9#include <linux/platform_device.h>
10#include <linux/regmap.h>
11
12#include <dt-bindings/clock/qcom,sm6350-camcc.h>
13
14#include "clk-alpha-pll.h"
15#include "clk-branch.h"
16#include "clk-rcg.h"
17#include "common.h"
18#include "gdsc.h"
19
20enum {
21 DT_BI_TCXO,
22};
23
24enum {
25 P_BI_TCXO,
26 P_CAMCC_PLL0_OUT_EVEN,
27 P_CAMCC_PLL0_OUT_MAIN,
28 P_CAMCC_PLL1_OUT_EVEN,
29 P_CAMCC_PLL1_OUT_MAIN,
30 P_CAMCC_PLL2_OUT_EARLY,
31 P_CAMCC_PLL2_OUT_MAIN,
32 P_CAMCC_PLL3_OUT_MAIN,
33};
34
35static struct pll_vco fabia_vco[] = {
36 { 249600000, 2000000000, 0 },
37};
38
39/* 600MHz configuration */
40static const struct alpha_pll_config camcc_pll0_config = {
41 .l = 0x1f,
42 .alpha = 0x4000,
43 .config_ctl_val = 0x20485699,
44 .config_ctl_hi_val = 0x00002067,
45 .test_ctl_val = 0x40000000,
46 .test_ctl_hi_val = 0x00000002,
47 .user_ctl_val = 0x00000101,
48 .user_ctl_hi_val = 0x00004805,
49};
50
51static struct clk_alpha_pll camcc_pll0 = {
52 .offset = 0x0,
53 .vco_table = fabia_vco,
54 .num_vco = ARRAY_SIZE(fabia_vco),
55 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
56 .clkr = {
57 .hw.init = &(struct clk_init_data){
58 .name = "camcc_pll0",
59 .parent_data = &(const struct clk_parent_data){
60 .index = DT_BI_TCXO,
61 },
62 .num_parents = 1,
63 .ops = &clk_alpha_pll_fabia_ops,
64 },
65 },
66};
67
68static const struct clk_div_table post_div_table_camcc_pll0_out_even[] = {
69 { 0x1, 2 },
70 { }
71};
72
73static struct clk_alpha_pll_postdiv camcc_pll0_out_even = {
74 .offset = 0x0,
75 .post_div_shift = 8,
76 .post_div_table = post_div_table_camcc_pll0_out_even,
77 .num_post_div = ARRAY_SIZE(post_div_table_camcc_pll0_out_even),
78 .width = 4,
79 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
80 .clkr.hw.init = &(struct clk_init_data){
81 .name = "camcc_pll0_out_even",
82 .parent_hws = (const struct clk_hw*[]){
83 &camcc_pll0.clkr.hw,
84 },
85 .num_parents = 1,
86 .flags = CLK_SET_RATE_PARENT,
87 .ops = &clk_alpha_pll_postdiv_fabia_ops,
88 },
89};
90
91/* 808MHz configuration */
92static const struct alpha_pll_config camcc_pll1_config = {
93 .l = 0x2a,
94 .alpha = 0x1555,
95 .config_ctl_val = 0x20485699,
96 .config_ctl_hi_val = 0x00002067,
97 .test_ctl_val = 0x40000000,
98 .test_ctl_hi_val = 0x00000000,
99 .user_ctl_val = 0x00000101,
100 .user_ctl_hi_val = 0x00004805,
101};
102
103static struct clk_alpha_pll camcc_pll1 = {
104 .offset = 0x1000,
105 .vco_table = fabia_vco,
106 .num_vco = ARRAY_SIZE(fabia_vco),
107 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
108 .clkr = {
109 .hw.init = &(struct clk_init_data){
110 .name = "camcc_pll1",
111 .parent_data = &(const struct clk_parent_data){
112 .index = DT_BI_TCXO,
113 },
114 .num_parents = 1,
115 .ops = &clk_alpha_pll_fabia_ops,
116 },
117 },
118};
119
120static const struct clk_div_table post_div_table_camcc_pll1_out_even[] = {
121 { 0x1, 2 },
122 { }
123};
124
125static struct clk_alpha_pll_postdiv camcc_pll1_out_even = {
126 .offset = 0x1000,
127 .post_div_shift = 8,
128 .post_div_table = post_div_table_camcc_pll1_out_even,
129 .num_post_div = ARRAY_SIZE(post_div_table_camcc_pll1_out_even),
130 .width = 4,
131 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
132 .clkr.hw.init = &(struct clk_init_data){
133 .name = "camcc_pll1_out_even",
134 .parent_hws = (const struct clk_hw*[]){
135 &camcc_pll1.clkr.hw,
136 },
137 .num_parents = 1,
138 .flags = CLK_SET_RATE_PARENT,
139 .ops = &clk_alpha_pll_postdiv_fabia_ops,
140 },
141};
142
143/* 1920MHz configuration */
144static const struct alpha_pll_config camcc_pll2_config = {
145 .l = 0x64,
146 .alpha = 0x0,
147 .post_div_val = 0x3 << 8,
148 .post_div_mask = 0x3 << 8,
149 .aux_output_mask = BIT(1),
150 .main_output_mask = BIT(0),
151 .early_output_mask = BIT(3),
152 .config_ctl_val = 0x20000800,
153 .config_ctl_hi_val = 0x400003d2,
154 .test_ctl_val = 0x04000400,
155 .test_ctl_hi_val = 0x00004000,
156};
157
158static struct clk_alpha_pll camcc_pll2 = {
159 .offset = 0x2000,
160 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_AGERA],
161 .clkr = {
162 .hw.init = &(struct clk_init_data){
163 .name = "camcc_pll2",
164 .parent_data = &(const struct clk_parent_data){
165 .index = DT_BI_TCXO,
166 },
167 .num_parents = 1,
168 .ops = &clk_alpha_pll_agera_ops,
169 },
170 },
171};
172
173static struct clk_fixed_factor camcc_pll2_out_early = {
174 .mult = 1,
175 .div = 2,
176 .hw.init = &(struct clk_init_data){
177 .name = "camcc_pll2_out_early",
178 .parent_hws = (const struct clk_hw*[]){
179 &camcc_pll2.clkr.hw,
180 },
181 .num_parents = 1,
182 .ops = &clk_fixed_factor_ops,
183 },
184};
185
186static const struct clk_div_table post_div_table_camcc_pll2_out_main[] = {
187 { 0x1, 2 },
188 { }
189};
190
191static struct clk_alpha_pll_postdiv camcc_pll2_out_main = {
192 .offset = 0x2000,
193 .post_div_shift = 8,
194 .post_div_table = post_div_table_camcc_pll2_out_main,
195 .num_post_div = ARRAY_SIZE(post_div_table_camcc_pll2_out_main),
196 .width = 2,
197 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_AGERA],
198 .clkr.hw.init = &(struct clk_init_data){
199 .name = "camcc_pll2_out_main",
200 .parent_hws = (const struct clk_hw*[]){
201 &camcc_pll2.clkr.hw,
202 },
203 .num_parents = 1,
204 .flags = CLK_SET_RATE_PARENT,
205 .ops = &clk_alpha_pll_postdiv_ops,
206 },
207};
208
209/* 384MHz configuration */
210static const struct alpha_pll_config camcc_pll3_config = {
211 .l = 0x14,
212 .alpha = 0x0,
213 .config_ctl_val = 0x20485699,
214 .config_ctl_hi_val = 0x00002067,
215 .test_ctl_val = 0x40000000,
216 .test_ctl_hi_val = 0x00000002,
217 .user_ctl_val = 0x00000001,
218 .user_ctl_hi_val = 0x00014805,
219};
220
221static struct clk_alpha_pll camcc_pll3 = {
222 .offset = 0x3000,
223 .vco_table = fabia_vco,
224 .num_vco = ARRAY_SIZE(fabia_vco),
225 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
226 .clkr = {
227 .hw.init = &(struct clk_init_data){
228 .name = "camcc_pll3",
229 .parent_data = &(const struct clk_parent_data){
230 .index = DT_BI_TCXO,
231 },
232 .num_parents = 1,
233 .ops = &clk_alpha_pll_fabia_ops,
234 },
235 },
236};
237
238static const struct parent_map camcc_parent_map_0[] = {
239 { P_BI_TCXO, 0 },
240 { P_CAMCC_PLL0_OUT_EVEN, 6 },
241};
242
243static const struct clk_parent_data camcc_parent_data_0[] = {
244 { .fw_name = "bi_tcxo" },
245 { .hw = &camcc_pll0_out_even.clkr.hw },
246};
247
248static const struct parent_map camcc_parent_map_1[] = {
249 { P_BI_TCXO, 0 },
250 { P_CAMCC_PLL0_OUT_MAIN, 1 },
251 { P_CAMCC_PLL1_OUT_EVEN, 3 },
252 { P_CAMCC_PLL2_OUT_MAIN, 4 },
253};
254
255static const struct clk_parent_data camcc_parent_data_1[] = {
256 { .fw_name = "bi_tcxo" },
257 { .hw = &camcc_pll0.clkr.hw },
258 { .hw = &camcc_pll1_out_even.clkr.hw },
259 { .hw = &camcc_pll2_out_main.clkr.hw },
260};
261
262static const struct parent_map camcc_parent_map_2[] = {
263 { P_BI_TCXO, 0 },
264 { P_CAMCC_PLL0_OUT_MAIN, 1 },
265 { P_CAMCC_PLL3_OUT_MAIN, 5 },
266};
267
268static const struct clk_parent_data camcc_parent_data_2[] = {
269 { .fw_name = "bi_tcxo" },
270 { .hw = &camcc_pll0.clkr.hw },
271 { .hw = &camcc_pll3.clkr.hw },
272};
273
274static const struct parent_map camcc_parent_map_3[] = {
275 { P_BI_TCXO, 0 },
276 { P_CAMCC_PLL2_OUT_EARLY, 3 },
277};
278
279static const struct clk_parent_data camcc_parent_data_3[] = {
280 { .fw_name = "bi_tcxo" },
281 { .hw = &camcc_pll2_out_early.hw },
282};
283
284static const struct parent_map camcc_parent_map_4[] = {
285 { P_BI_TCXO, 0 },
286 { P_CAMCC_PLL0_OUT_MAIN, 1 },
287 { P_CAMCC_PLL1_OUT_EVEN, 3 },
288};
289
290static const struct clk_parent_data camcc_parent_data_4[] = {
291 { .fw_name = "bi_tcxo" },
292 { .hw = &camcc_pll0.clkr.hw },
293 { .hw = &camcc_pll1_out_even.clkr.hw },
294};
295
296static const struct parent_map camcc_parent_map_5[] = {
297 { P_BI_TCXO, 0 },
298 { P_CAMCC_PLL0_OUT_MAIN, 1 },
299 { P_CAMCC_PLL1_OUT_EVEN, 3 },
300 { P_CAMCC_PLL3_OUT_MAIN, 5 },
301};
302
303static const struct clk_parent_data camcc_parent_data_5[] = {
304 { .fw_name = "bi_tcxo" },
305 { .hw = &camcc_pll0.clkr.hw },
306 { .hw = &camcc_pll1_out_even.clkr.hw },
307 { .hw = &camcc_pll3.clkr.hw },
308};
309
310static const struct parent_map camcc_parent_map_6[] = {
311 { P_BI_TCXO, 0 },
312 { P_CAMCC_PLL0_OUT_MAIN, 1 },
313 { P_CAMCC_PLL2_OUT_MAIN, 4 },
314};
315
316static const struct clk_parent_data camcc_parent_data_6[] = {
317 { .fw_name = "bi_tcxo" },
318 { .hw = &camcc_pll0.clkr.hw },
319 { .hw = &camcc_pll2_out_main.clkr.hw },
320};
321
322static const struct parent_map camcc_parent_map_7[] = {
323 { P_BI_TCXO, 0 },
324 { P_CAMCC_PLL0_OUT_MAIN, 1 },
325 { P_CAMCC_PLL1_OUT_MAIN, 2 },
326 { P_CAMCC_PLL2_OUT_MAIN, 4 },
327};
328
329static const struct clk_parent_data camcc_parent_data_7[] = {
330 { .fw_name = "bi_tcxo" },
331 { .hw = &camcc_pll0.clkr.hw },
332 { .hw = &camcc_pll1.clkr.hw },
333 { .hw = &camcc_pll2_out_main.clkr.hw },
334};
335
336static const struct parent_map camcc_parent_map_8[] = {
337 { P_BI_TCXO, 0 },
338 { P_CAMCC_PLL0_OUT_MAIN, 1 },
339 { P_CAMCC_PLL1_OUT_MAIN, 2 },
340};
341
342static const struct clk_parent_data camcc_parent_data_8[] = {
343 { .fw_name = "bi_tcxo" },
344 { .hw = &camcc_pll0.clkr.hw },
345 { .hw = &camcc_pll1.clkr.hw },
346};
347
348static const struct parent_map camcc_parent_map_9[] = {
349 { P_BI_TCXO, 0 },
350 { P_CAMCC_PLL2_OUT_MAIN, 4 },
351};
352
353static const struct clk_parent_data camcc_parent_data_9[] = {
354 { .fw_name = "bi_tcxo" },
355 { .hw = &camcc_pll2_out_main.clkr.hw },
356};
357
358static const struct freq_tbl ftbl_camcc_bps_clk_src[] = {
359 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0),
360 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0),
361 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0),
362 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0),
363 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0),
364 { }
365};
366
367static struct clk_rcg2 camcc_bps_clk_src = {
368 .cmd_rcgr = 0x6010,
369 .mnd_width = 0,
370 .hid_width = 5,
371 .parent_map = camcc_parent_map_1,
372 .freq_tbl = ftbl_camcc_bps_clk_src,
373 .clkr.hw.init = &(struct clk_init_data){
374 .name = "camcc_bps_clk_src",
375 .parent_data = camcc_parent_data_1,
376 .num_parents = ARRAY_SIZE(camcc_parent_data_1),
377 .ops = &clk_rcg2_ops,
378 },
379};
380
381static const struct freq_tbl ftbl_camcc_cci_0_clk_src[] = {
382 F(37500000, P_CAMCC_PLL0_OUT_EVEN, 8, 0, 0),
383 F(50000000, P_CAMCC_PLL0_OUT_EVEN, 6, 0, 0),
384 F(100000000, P_CAMCC_PLL0_OUT_EVEN, 3, 0, 0),
385 { }
386};
387
388static struct clk_rcg2 camcc_cci_0_clk_src = {
389 .cmd_rcgr = 0xf004,
390 .mnd_width = 8,
391 .hid_width = 5,
392 .parent_map = camcc_parent_map_0,
393 .freq_tbl = ftbl_camcc_cci_0_clk_src,
394 .clkr.hw.init = &(struct clk_init_data){
395 .name = "camcc_cci_0_clk_src",
396 .parent_data = camcc_parent_data_0,
397 .num_parents = ARRAY_SIZE(camcc_parent_data_0),
398 .ops = &clk_rcg2_ops,
399 },
400};
401
402static struct clk_rcg2 camcc_cci_1_clk_src = {
403 .cmd_rcgr = 0x10004,
404 .mnd_width = 8,
405 .hid_width = 5,
406 .parent_map = camcc_parent_map_0,
407 .freq_tbl = ftbl_camcc_cci_0_clk_src,
408 .clkr.hw.init = &(struct clk_init_data){
409 .name = "camcc_cci_1_clk_src",
410 .parent_data = camcc_parent_data_0,
411 .num_parents = ARRAY_SIZE(camcc_parent_data_0),
412 .ops = &clk_rcg2_ops,
413 },
414};
415
416static const struct freq_tbl ftbl_camcc_cphy_rx_clk_src[] = {
417 F(150000000, P_CAMCC_PLL0_OUT_MAIN, 4, 0, 0),
418 F(300000000, P_CAMCC_PLL0_OUT_MAIN, 2, 0, 0),
419 F(384000000, P_CAMCC_PLL3_OUT_MAIN, 1, 0, 0),
420 F(400000000, P_CAMCC_PLL0_OUT_MAIN, 1.5, 0, 0),
421 { }
422};
423
424static struct clk_rcg2 camcc_cphy_rx_clk_src = {
425 .cmd_rcgr = 0x9064,
426 .mnd_width = 0,
427 .hid_width = 5,
428 .parent_map = camcc_parent_map_2,
429 .freq_tbl = ftbl_camcc_cphy_rx_clk_src,
430 .clkr.hw.init = &(struct clk_init_data){
431 .name = "camcc_cphy_rx_clk_src",
432 .parent_data = camcc_parent_data_2,
433 .num_parents = ARRAY_SIZE(camcc_parent_data_2),
434 .ops = &clk_rcg2_ops,
435 },
436};
437
438static const struct freq_tbl ftbl_camcc_csi0phytimer_clk_src[] = {
439 F(300000000, P_CAMCC_PLL0_OUT_EVEN, 1, 0, 0),
440 { }
441};
442
443static struct clk_rcg2 camcc_csi0phytimer_clk_src = {
444 .cmd_rcgr = 0x5004,
445 .mnd_width = 0,
446 .hid_width = 5,
447 .parent_map = camcc_parent_map_0,
448 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src,
449 .clkr.hw.init = &(struct clk_init_data){
450 .name = "camcc_csi0phytimer_clk_src",
451 .parent_data = camcc_parent_data_0,
452 .num_parents = ARRAY_SIZE(camcc_parent_data_0),
453 .ops = &clk_rcg2_ops,
454 },
455};
456
457static struct clk_rcg2 camcc_csi1phytimer_clk_src = {
458 .cmd_rcgr = 0x5028,
459 .mnd_width = 0,
460 .hid_width = 5,
461 .parent_map = camcc_parent_map_0,
462 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src,
463 .clkr.hw.init = &(struct clk_init_data){
464 .name = "camcc_csi1phytimer_clk_src",
465 .parent_data = camcc_parent_data_0,
466 .num_parents = ARRAY_SIZE(camcc_parent_data_0),
467 .ops = &clk_rcg2_ops,
468 },
469};
470
471static struct clk_rcg2 camcc_csi2phytimer_clk_src = {
472 .cmd_rcgr = 0x504c,
473 .mnd_width = 0,
474 .hid_width = 5,
475 .parent_map = camcc_parent_map_0,
476 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src,
477 .clkr.hw.init = &(struct clk_init_data){
478 .name = "camcc_csi2phytimer_clk_src",
479 .parent_data = camcc_parent_data_0,
480 .num_parents = ARRAY_SIZE(camcc_parent_data_0),
481 .ops = &clk_rcg2_ops,
482 },
483};
484
485static struct clk_rcg2 camcc_csi3phytimer_clk_src = {
486 .cmd_rcgr = 0x5070,
487 .mnd_width = 0,
488 .hid_width = 5,
489 .parent_map = camcc_parent_map_0,
490 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src,
491 .clkr.hw.init = &(struct clk_init_data){
492 .name = "camcc_csi3phytimer_clk_src",
493 .parent_data = camcc_parent_data_0,
494 .num_parents = ARRAY_SIZE(camcc_parent_data_0),
495 .ops = &clk_rcg2_ops,
496 },
497};
498
499static const struct freq_tbl ftbl_camcc_fast_ahb_clk_src[] = {
500 F(100000000, P_CAMCC_PLL0_OUT_MAIN, 6, 0, 0),
501 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0),
502 F(300000000, P_CAMCC_PLL0_OUT_MAIN, 2, 0, 0),
503 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0),
504 { }
505};
506
507static struct clk_rcg2 camcc_fast_ahb_clk_src = {
508 .cmd_rcgr = 0x603c,
509 .mnd_width = 0,
510 .hid_width = 5,
511 .parent_map = camcc_parent_map_4,
512 .freq_tbl = ftbl_camcc_fast_ahb_clk_src,
513 .clkr.hw.init = &(struct clk_init_data){
514 .name = "camcc_fast_ahb_clk_src",
515 .parent_data = camcc_parent_data_4,
516 .num_parents = ARRAY_SIZE(camcc_parent_data_4),
517 .ops = &clk_rcg2_ops,
518 },
519};
520
521static const struct freq_tbl ftbl_camcc_icp_clk_src[] = {
522 F(240000000, P_CAMCC_PLL0_OUT_MAIN, 2.5, 0, 0),
523 F(384000000, P_CAMCC_PLL3_OUT_MAIN, 1, 0, 0),
524 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0),
525 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0),
526 { }
527};
528
529static struct clk_rcg2 camcc_icp_clk_src = {
530 .cmd_rcgr = 0xe014,
531 .mnd_width = 0,
532 .hid_width = 5,
533 .parent_map = camcc_parent_map_5,
534 .freq_tbl = ftbl_camcc_icp_clk_src,
535 .clkr.hw.init = &(struct clk_init_data){
536 .name = "camcc_icp_clk_src",
537 .parent_data = camcc_parent_data_5,
538 .num_parents = ARRAY_SIZE(camcc_parent_data_5),
539 .ops = &clk_rcg2_ops,
540 },
541};
542
543static const struct freq_tbl ftbl_camcc_ife_0_clk_src[] = {
544 F(240000000, P_CAMCC_PLL0_OUT_MAIN, 2.5, 0, 0),
545 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0),
546 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0),
547 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0),
548 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0),
549 { }
550};
551
552static struct clk_rcg2 camcc_ife_0_clk_src = {
553 .cmd_rcgr = 0x9010,
554 .mnd_width = 0,
555 .hid_width = 5,
556 .parent_map = camcc_parent_map_1,
557 .freq_tbl = ftbl_camcc_ife_0_clk_src,
558 .clkr.hw.init = &(struct clk_init_data){
559 .name = "camcc_ife_0_clk_src",
560 .parent_data = camcc_parent_data_1,
561 .num_parents = ARRAY_SIZE(camcc_parent_data_1),
562 .flags = CLK_SET_RATE_PARENT,
563 .ops = &clk_rcg2_ops,
564 },
565};
566
567static struct clk_rcg2 camcc_ife_0_csid_clk_src = {
568 .cmd_rcgr = 0x903c,
569 .mnd_width = 0,
570 .hid_width = 5,
571 .parent_map = camcc_parent_map_2,
572 .freq_tbl = ftbl_camcc_cphy_rx_clk_src,
573 .clkr.hw.init = &(struct clk_init_data){
574 .name = "camcc_ife_0_csid_clk_src",
575 .parent_data = camcc_parent_data_2,
576 .num_parents = ARRAY_SIZE(camcc_parent_data_2),
577 .ops = &clk_rcg2_ops,
578 },
579};
580
581static struct clk_rcg2 camcc_ife_1_clk_src = {
582 .cmd_rcgr = 0xa010,
583 .mnd_width = 0,
584 .hid_width = 5,
585 .parent_map = camcc_parent_map_1,
586 .freq_tbl = ftbl_camcc_ife_0_clk_src,
587 .clkr.hw.init = &(struct clk_init_data){
588 .name = "camcc_ife_1_clk_src",
589 .parent_data = camcc_parent_data_1,
590 .num_parents = ARRAY_SIZE(camcc_parent_data_1),
591 .flags = CLK_SET_RATE_PARENT,
592 .ops = &clk_rcg2_ops,
593 },
594};
595
596static struct clk_rcg2 camcc_ife_1_csid_clk_src = {
597 .cmd_rcgr = 0xa034,
598 .mnd_width = 0,
599 .hid_width = 5,
600 .parent_map = camcc_parent_map_2,
601 .freq_tbl = ftbl_camcc_cphy_rx_clk_src,
602 .clkr.hw.init = &(struct clk_init_data){
603 .name = "camcc_ife_1_csid_clk_src",
604 .parent_data = camcc_parent_data_2,
605 .num_parents = ARRAY_SIZE(camcc_parent_data_2),
606 .ops = &clk_rcg2_ops,
607 },
608};
609
610static struct clk_rcg2 camcc_ife_2_clk_src = {
611 .cmd_rcgr = 0xb00c,
612 .mnd_width = 0,
613 .hid_width = 5,
614 .parent_map = camcc_parent_map_1,
615 .freq_tbl = ftbl_camcc_ife_0_clk_src,
616 .clkr.hw.init = &(struct clk_init_data){
617 .name = "camcc_ife_2_clk_src",
618 .parent_data = camcc_parent_data_1,
619 .num_parents = ARRAY_SIZE(camcc_parent_data_1),
620 .ops = &clk_rcg2_ops,
621 },
622};
623
624static struct clk_rcg2 camcc_ife_2_csid_clk_src = {
625 .cmd_rcgr = 0xb030,
626 .mnd_width = 0,
627 .hid_width = 5,
628 .parent_map = camcc_parent_map_2,
629 .freq_tbl = ftbl_camcc_cphy_rx_clk_src,
630 .clkr.hw.init = &(struct clk_init_data){
631 .name = "camcc_ife_2_csid_clk_src",
632 .parent_data = camcc_parent_data_2,
633 .num_parents = ARRAY_SIZE(camcc_parent_data_2),
634 .ops = &clk_rcg2_ops,
635 },
636};
637
638static const struct freq_tbl ftbl_camcc_ife_lite_clk_src[] = {
639 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0),
640 F(400000000, P_CAMCC_PLL0_OUT_MAIN, 1.5, 0, 0),
641 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0),
642 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0),
643 { }
644};
645
646static struct clk_rcg2 camcc_ife_lite_clk_src = {
647 .cmd_rcgr = 0xc004,
648 .mnd_width = 0,
649 .hid_width = 5,
650 .parent_map = camcc_parent_map_6,
651 .freq_tbl = ftbl_camcc_ife_lite_clk_src,
652 .clkr.hw.init = &(struct clk_init_data){
653 .name = "camcc_ife_lite_clk_src",
654 .parent_data = camcc_parent_data_6,
655 .num_parents = ARRAY_SIZE(camcc_parent_data_6),
656 .ops = &clk_rcg2_ops,
657 },
658};
659
660static struct clk_rcg2 camcc_ife_lite_csid_clk_src = {
661 .cmd_rcgr = 0xc024,
662 .mnd_width = 0,
663 .hid_width = 5,
664 .parent_map = camcc_parent_map_2,
665 .freq_tbl = ftbl_camcc_cphy_rx_clk_src,
666 .clkr.hw.init = &(struct clk_init_data){
667 .name = "camcc_ife_lite_csid_clk_src",
668 .parent_data = camcc_parent_data_2,
669 .num_parents = ARRAY_SIZE(camcc_parent_data_2),
670 .ops = &clk_rcg2_ops,
671 },
672};
673
674static const struct freq_tbl ftbl_camcc_ipe_0_clk_src[] = {
675 F(240000000, P_CAMCC_PLL2_OUT_MAIN, 2, 0, 0),
676 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0),
677 F(404000000, P_CAMCC_PLL1_OUT_MAIN, 2, 0, 0),
678 F(538666667, P_CAMCC_PLL1_OUT_MAIN, 1.5, 0, 0),
679 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0),
680 { }
681};
682
683static struct clk_rcg2 camcc_ipe_0_clk_src = {
684 .cmd_rcgr = 0x7010,
685 .mnd_width = 0,
686 .hid_width = 5,
687 .parent_map = camcc_parent_map_7,
688 .freq_tbl = ftbl_camcc_ipe_0_clk_src,
689 .clkr.hw.init = &(struct clk_init_data){
690 .name = "camcc_ipe_0_clk_src",
691 .parent_data = camcc_parent_data_7,
692 .num_parents = ARRAY_SIZE(camcc_parent_data_7),
693 .flags = CLK_SET_RATE_PARENT,
694 .ops = &clk_rcg2_ops,
695 },
696};
697
698static const struct freq_tbl ftbl_camcc_jpeg_clk_src[] = {
699 F(66666667, P_CAMCC_PLL0_OUT_MAIN, 9, 0, 0),
700 F(133333333, P_CAMCC_PLL0_OUT_MAIN, 4.5, 0, 0),
701 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0),
702 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0),
703 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0),
704 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0),
705 { }
706};
707
708static struct clk_rcg2 camcc_jpeg_clk_src = {
709 .cmd_rcgr = 0xd004,
710 .mnd_width = 0,
711 .hid_width = 5,
712 .parent_map = camcc_parent_map_1,
713 .freq_tbl = ftbl_camcc_jpeg_clk_src,
714 .clkr.hw.init = &(struct clk_init_data){
715 .name = "camcc_jpeg_clk_src",
716 .parent_data = camcc_parent_data_1,
717 .num_parents = ARRAY_SIZE(camcc_parent_data_1),
718 .ops = &clk_rcg2_ops,
719 },
720};
721
722static const struct freq_tbl ftbl_camcc_lrme_clk_src[] = {
723 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0),
724 F(269333333, P_CAMCC_PLL1_OUT_MAIN, 3, 0, 0),
725 F(323200000, P_CAMCC_PLL1_OUT_MAIN, 2.5, 0, 0),
726 F(404000000, P_CAMCC_PLL1_OUT_MAIN, 2, 0, 0),
727 { }
728};
729
730static struct clk_rcg2 camcc_lrme_clk_src = {
731 .cmd_rcgr = 0x11004,
732 .mnd_width = 0,
733 .hid_width = 5,
734 .parent_map = camcc_parent_map_8,
735 .freq_tbl = ftbl_camcc_lrme_clk_src,
736 .clkr.hw.init = &(struct clk_init_data){
737 .name = "camcc_lrme_clk_src",
738 .parent_data = camcc_parent_data_8,
739 .num_parents = ARRAY_SIZE(camcc_parent_data_8),
740 .ops = &clk_rcg2_ops,
741 },
742};
743
744static const struct freq_tbl ftbl_camcc_mclk0_clk_src[] = {
745 F(19200000, P_CAMCC_PLL2_OUT_EARLY, 1, 1, 50),
746 F(24000000, P_CAMCC_PLL2_OUT_EARLY, 10, 1, 4),
747 F(64000000, P_CAMCC_PLL2_OUT_EARLY, 15, 0, 0),
748 { }
749};
750
751static struct clk_rcg2 camcc_mclk0_clk_src = {
752 .cmd_rcgr = 0x4004,
753 .mnd_width = 8,
754 .hid_width = 5,
755 .parent_map = camcc_parent_map_3,
756 .freq_tbl = ftbl_camcc_mclk0_clk_src,
757 .clkr.hw.init = &(struct clk_init_data){
758 .name = "camcc_mclk0_clk_src",
759 .parent_data = camcc_parent_data_3,
760 .num_parents = ARRAY_SIZE(camcc_parent_data_3),
761 .ops = &clk_rcg2_ops,
762 },
763};
764
765static struct clk_rcg2 camcc_mclk1_clk_src = {
766 .cmd_rcgr = 0x4024,
767 .mnd_width = 8,
768 .hid_width = 5,
769 .parent_map = camcc_parent_map_3,
770 .freq_tbl = ftbl_camcc_mclk0_clk_src,
771 .clkr.hw.init = &(struct clk_init_data){
772 .name = "camcc_mclk1_clk_src",
773 .parent_data = camcc_parent_data_3,
774 .num_parents = ARRAY_SIZE(camcc_parent_data_3),
775 .ops = &clk_rcg2_ops,
776 },
777};
778
779static struct clk_rcg2 camcc_mclk2_clk_src = {
780 .cmd_rcgr = 0x4044,
781 .mnd_width = 8,
782 .hid_width = 5,
783 .parent_map = camcc_parent_map_3,
784 .freq_tbl = ftbl_camcc_mclk0_clk_src,
785 .clkr.hw.init = &(struct clk_init_data){
786 .name = "camcc_mclk2_clk_src",
787 .parent_data = camcc_parent_data_3,
788 .num_parents = ARRAY_SIZE(camcc_parent_data_3),
789 .ops = &clk_rcg2_ops,
790 },
791};
792
793static struct clk_rcg2 camcc_mclk3_clk_src = {
794 .cmd_rcgr = 0x4064,
795 .mnd_width = 8,
796 .hid_width = 5,
797 .parent_map = camcc_parent_map_3,
798 .freq_tbl = ftbl_camcc_mclk0_clk_src,
799 .clkr.hw.init = &(struct clk_init_data){
800 .name = "camcc_mclk3_clk_src",
801 .parent_data = camcc_parent_data_3,
802 .num_parents = ARRAY_SIZE(camcc_parent_data_3),
803 .ops = &clk_rcg2_ops,
804 },
805};
806
807static struct clk_rcg2 camcc_mclk4_clk_src = {
808 .cmd_rcgr = 0x4084,
809 .mnd_width = 8,
810 .hid_width = 5,
811 .parent_map = camcc_parent_map_3,
812 .freq_tbl = ftbl_camcc_mclk0_clk_src,
813 .clkr.hw.init = &(struct clk_init_data){
814 .name = "camcc_mclk4_clk_src",
815 .parent_data = camcc_parent_data_3,
816 .num_parents = ARRAY_SIZE(camcc_parent_data_3),
817 .ops = &clk_rcg2_ops,
818 },
819};
820
821static const struct freq_tbl ftbl_camcc_slow_ahb_clk_src[] = {
822 F(80000000, P_CAMCC_PLL2_OUT_MAIN, 6, 0, 0),
823 { }
824};
825
826static struct clk_rcg2 camcc_slow_ahb_clk_src = {
827 .cmd_rcgr = 0x6058,
828 .mnd_width = 0,
829 .hid_width = 5,
830 .parent_map = camcc_parent_map_9,
831 .freq_tbl = ftbl_camcc_slow_ahb_clk_src,
832 .clkr.hw.init = &(struct clk_init_data){
833 .name = "camcc_slow_ahb_clk_src",
834 .parent_data = camcc_parent_data_9,
835 .num_parents = ARRAY_SIZE(camcc_parent_data_9),
836 .ops = &clk_rcg2_ops,
837 },
838};
839
840static struct clk_branch camcc_bps_ahb_clk = {
841 .halt_reg = 0x6070,
842 .halt_check = BRANCH_HALT,
843 .clkr = {
844 .enable_reg = 0x6070,
845 .enable_mask = BIT(0),
846 .hw.init = &(struct clk_init_data){
847 .name = "camcc_bps_ahb_clk",
848 .parent_hws = (const struct clk_hw*[]){
849 &camcc_slow_ahb_clk_src.clkr.hw
850 },
851 .num_parents = 1,
852 .flags = CLK_SET_RATE_PARENT,
853 .ops = &clk_branch2_ops,
854 },
855 },
856};
857
858static struct clk_branch camcc_bps_areg_clk = {
859 .halt_reg = 0x6054,
860 .halt_check = BRANCH_HALT,
861 .clkr = {
862 .enable_reg = 0x6054,
863 .enable_mask = BIT(0),
864 .hw.init = &(struct clk_init_data){
865 .name = "camcc_bps_areg_clk",
866 .parent_hws = (const struct clk_hw*[]){
867 &camcc_fast_ahb_clk_src.clkr.hw
868 },
869 .num_parents = 1,
870 .flags = CLK_SET_RATE_PARENT,
871 .ops = &clk_branch2_ops,
872 },
873 },
874};
875
876static struct clk_branch camcc_bps_axi_clk = {
877 .halt_reg = 0x6038,
878 .halt_check = BRANCH_HALT,
879 .clkr = {
880 .enable_reg = 0x6038,
881 .enable_mask = BIT(0),
882 .hw.init = &(struct clk_init_data){
883 .name = "camcc_bps_axi_clk",
884 .ops = &clk_branch2_ops,
885 },
886 },
887};
888
889static struct clk_branch camcc_bps_clk = {
890 .halt_reg = 0x6028,
891 .halt_check = BRANCH_HALT,
892 .clkr = {
893 .enable_reg = 0x6028,
894 .enable_mask = BIT(0),
895 .hw.init = &(struct clk_init_data){
896 .name = "camcc_bps_clk",
897 .parent_hws = (const struct clk_hw*[]){
898 &camcc_bps_clk_src.clkr.hw
899 },
900 .num_parents = 1,
901 .flags = CLK_SET_RATE_PARENT,
902 .ops = &clk_branch2_ops,
903 },
904 },
905};
906
907static struct clk_branch camcc_camnoc_axi_clk = {
908 .halt_reg = 0x13004,
909 .halt_check = BRANCH_HALT,
910 .clkr = {
911 .enable_reg = 0x13004,
912 .enable_mask = BIT(0),
913 .hw.init = &(struct clk_init_data){
914 .name = "camcc_camnoc_axi_clk",
915 .ops = &clk_branch2_ops,
916 },
917 },
918};
919
920static struct clk_branch camcc_cci_0_clk = {
921 .halt_reg = 0xf01c,
922 .halt_check = BRANCH_HALT,
923 .clkr = {
924 .enable_reg = 0xf01c,
925 .enable_mask = BIT(0),
926 .hw.init = &(struct clk_init_data){
927 .name = "camcc_cci_0_clk",
928 .parent_hws = (const struct clk_hw*[]){
929 &camcc_cci_0_clk_src.clkr.hw
930 },
931 .num_parents = 1,
932 .flags = CLK_SET_RATE_PARENT,
933 .ops = &clk_branch2_ops,
934 },
935 },
936};
937
938static struct clk_branch camcc_cci_1_clk = {
939 .halt_reg = 0x1001c,
940 .halt_check = BRANCH_HALT,
941 .clkr = {
942 .enable_reg = 0x1001c,
943 .enable_mask = BIT(0),
944 .hw.init = &(struct clk_init_data){
945 .name = "camcc_cci_1_clk",
946 .parent_hws = (const struct clk_hw*[]){
947 &camcc_cci_1_clk_src.clkr.hw
948 },
949 .num_parents = 1,
950 .flags = CLK_SET_RATE_PARENT,
951 .ops = &clk_branch2_ops,
952 },
953 },
954};
955
956static struct clk_branch camcc_core_ahb_clk = {
957 .halt_reg = 0x14010,
958 .halt_check = BRANCH_HALT_VOTED,
959 .clkr = {
960 .enable_reg = 0x14010,
961 .enable_mask = BIT(0),
962 .hw.init = &(struct clk_init_data){
963 .name = "camcc_core_ahb_clk",
964 .parent_hws = (const struct clk_hw*[]){
965 &camcc_slow_ahb_clk_src.clkr.hw
966 },
967 .num_parents = 1,
968 .flags = CLK_SET_RATE_PARENT,
969 .ops = &clk_branch2_ops,
970 },
971 },
972};
973
974static struct clk_branch camcc_cpas_ahb_clk = {
975 .halt_reg = 0x12004,
976 .halt_check = BRANCH_HALT,
977 .clkr = {
978 .enable_reg = 0x12004,
979 .enable_mask = BIT(0),
980 .hw.init = &(struct clk_init_data){
981 .name = "camcc_cpas_ahb_clk",
982 .parent_hws = (const struct clk_hw*[]){
983 &camcc_slow_ahb_clk_src.clkr.hw
984 },
985 .num_parents = 1,
986 .flags = CLK_SET_RATE_PARENT,
987 .ops = &clk_branch2_ops,
988 },
989 },
990};
991
992static struct clk_branch camcc_csi0phytimer_clk = {
993 .halt_reg = 0x501c,
994 .halt_check = BRANCH_HALT,
995 .clkr = {
996 .enable_reg = 0x501c,
997 .enable_mask = BIT(0),
998 .hw.init = &(struct clk_init_data){
999 .name = "camcc_csi0phytimer_clk",
1000 .parent_hws = (const struct clk_hw*[]){
1001 &camcc_csi0phytimer_clk_src.clkr.hw
1002 },
1003 .num_parents = 1,
1004 .flags = CLK_SET_RATE_PARENT,
1005 .ops = &clk_branch2_ops,
1006 },
1007 },
1008};
1009
1010static struct clk_branch camcc_csi1phytimer_clk = {
1011 .halt_reg = 0x5040,
1012 .halt_check = BRANCH_HALT,
1013 .clkr = {
1014 .enable_reg = 0x5040,
1015 .enable_mask = BIT(0),
1016 .hw.init = &(struct clk_init_data){
1017 .name = "camcc_csi1phytimer_clk",
1018 .parent_hws = (const struct clk_hw*[]){
1019 &camcc_csi1phytimer_clk_src.clkr.hw
1020 },
1021 .num_parents = 1,
1022 .flags = CLK_SET_RATE_PARENT,
1023 .ops = &clk_branch2_ops,
1024 },
1025 },
1026};
1027
1028static struct clk_branch camcc_csi2phytimer_clk = {
1029 .halt_reg = 0x5064,
1030 .halt_check = BRANCH_HALT,
1031 .clkr = {
1032 .enable_reg = 0x5064,
1033 .enable_mask = BIT(0),
1034 .hw.init = &(struct clk_init_data){
1035 .name = "camcc_csi2phytimer_clk",
1036 .parent_hws = (const struct clk_hw*[]){
1037 &camcc_csi2phytimer_clk_src.clkr.hw
1038 },
1039 .num_parents = 1,
1040 .flags = CLK_SET_RATE_PARENT,
1041 .ops = &clk_branch2_ops,
1042 },
1043 },
1044};
1045
1046static struct clk_branch camcc_csi3phytimer_clk = {
1047 .halt_reg = 0x5088,
1048 .halt_check = BRANCH_HALT,
1049 .clkr = {
1050 .enable_reg = 0x5088,
1051 .enable_mask = BIT(0),
1052 .hw.init = &(struct clk_init_data){
1053 .name = "camcc_csi3phytimer_clk",
1054 .parent_hws = (const struct clk_hw*[]){
1055 &camcc_csi3phytimer_clk_src.clkr.hw
1056 },
1057 .num_parents = 1,
1058 .flags = CLK_SET_RATE_PARENT,
1059 .ops = &clk_branch2_ops,
1060 },
1061 },
1062};
1063
1064static struct clk_branch camcc_csiphy0_clk = {
1065 .halt_reg = 0x5020,
1066 .halt_check = BRANCH_HALT,
1067 .clkr = {
1068 .enable_reg = 0x5020,
1069 .enable_mask = BIT(0),
1070 .hw.init = &(struct clk_init_data){
1071 .name = "camcc_csiphy0_clk",
1072 .parent_hws = (const struct clk_hw*[]){
1073 &camcc_cphy_rx_clk_src.clkr.hw
1074 },
1075 .num_parents = 1,
1076 .flags = CLK_SET_RATE_PARENT,
1077 .ops = &clk_branch2_ops,
1078 },
1079 },
1080};
1081
1082static struct clk_branch camcc_csiphy1_clk = {
1083 .halt_reg = 0x5044,
1084 .halt_check = BRANCH_HALT,
1085 .clkr = {
1086 .enable_reg = 0x5044,
1087 .enable_mask = BIT(0),
1088 .hw.init = &(struct clk_init_data){
1089 .name = "camcc_csiphy1_clk",
1090 .parent_hws = (const struct clk_hw*[]){
1091 &camcc_cphy_rx_clk_src.clkr.hw
1092 },
1093 .num_parents = 1,
1094 .flags = CLK_SET_RATE_PARENT,
1095 .ops = &clk_branch2_ops,
1096 },
1097 },
1098};
1099
1100static struct clk_branch camcc_csiphy2_clk = {
1101 .halt_reg = 0x5068,
1102 .halt_check = BRANCH_HALT,
1103 .clkr = {
1104 .enable_reg = 0x5068,
1105 .enable_mask = BIT(0),
1106 .hw.init = &(struct clk_init_data){
1107 .name = "camcc_csiphy2_clk",
1108 .parent_hws = (const struct clk_hw*[]){
1109 &camcc_cphy_rx_clk_src.clkr.hw
1110 },
1111 .num_parents = 1,
1112 .flags = CLK_SET_RATE_PARENT,
1113 .ops = &clk_branch2_ops,
1114 },
1115 },
1116};
1117
1118static struct clk_branch camcc_csiphy3_clk = {
1119 .halt_reg = 0x508c,
1120 .halt_check = BRANCH_HALT,
1121 .clkr = {
1122 .enable_reg = 0x508c,
1123 .enable_mask = BIT(0),
1124 .hw.init = &(struct clk_init_data){
1125 .name = "camcc_csiphy3_clk",
1126 .parent_hws = (const struct clk_hw*[]){
1127 &camcc_cphy_rx_clk_src.clkr.hw
1128 },
1129 .num_parents = 1,
1130 .flags = CLK_SET_RATE_PARENT,
1131 .ops = &clk_branch2_ops,
1132 },
1133 },
1134};
1135
1136static struct clk_branch camcc_icp_clk = {
1137 .halt_reg = 0xe02c,
1138 .halt_check = BRANCH_HALT,
1139 .clkr = {
1140 .enable_reg = 0xe02c,
1141 .enable_mask = BIT(0),
1142 .hw.init = &(struct clk_init_data){
1143 .name = "camcc_icp_clk",
1144 .parent_hws = (const struct clk_hw*[]){
1145 &camcc_icp_clk_src.clkr.hw
1146 },
1147 .num_parents = 1,
1148 .flags = CLK_SET_RATE_PARENT,
1149 .ops = &clk_branch2_ops,
1150 },
1151 },
1152};
1153
1154static struct clk_branch camcc_icp_ts_clk = {
1155 .halt_reg = 0xe00c,
1156 .halt_check = BRANCH_HALT,
1157 .clkr = {
1158 .enable_reg = 0xe00c,
1159 .enable_mask = BIT(0),
1160 .hw.init = &(struct clk_init_data){
1161 .name = "camcc_icp_ts_clk",
1162 .ops = &clk_branch2_ops,
1163 },
1164 },
1165};
1166
1167static struct clk_branch camcc_ife_0_axi_clk = {
1168 .halt_reg = 0x9080,
1169 .halt_check = BRANCH_HALT,
1170 .clkr = {
1171 .enable_reg = 0x9080,
1172 .enable_mask = BIT(0),
1173 .hw.init = &(struct clk_init_data){
1174 .name = "camcc_ife_0_axi_clk",
1175 .ops = &clk_branch2_ops,
1176 },
1177 },
1178};
1179
1180static struct clk_branch camcc_ife_0_clk = {
1181 .halt_reg = 0x9028,
1182 .halt_check = BRANCH_HALT,
1183 .clkr = {
1184 .enable_reg = 0x9028,
1185 .enable_mask = BIT(0),
1186 .hw.init = &(struct clk_init_data){
1187 .name = "camcc_ife_0_clk",
1188 .parent_hws = (const struct clk_hw*[]){
1189 &camcc_ife_0_clk_src.clkr.hw
1190 },
1191 .num_parents = 1,
1192 .flags = CLK_SET_RATE_PARENT,
1193 .ops = &clk_branch2_ops,
1194 },
1195 },
1196};
1197
1198static struct clk_branch camcc_ife_0_cphy_rx_clk = {
1199 .halt_reg = 0x907c,
1200 .halt_check = BRANCH_HALT,
1201 .clkr = {
1202 .enable_reg = 0x907c,
1203 .enable_mask = BIT(0),
1204 .hw.init = &(struct clk_init_data){
1205 .name = "camcc_ife_0_cphy_rx_clk",
1206 .parent_hws = (const struct clk_hw*[]){
1207 &camcc_cphy_rx_clk_src.clkr.hw
1208 },
1209 .num_parents = 1,
1210 .flags = CLK_SET_RATE_PARENT,
1211 .ops = &clk_branch2_ops,
1212 },
1213 },
1214};
1215
1216static struct clk_branch camcc_ife_0_csid_clk = {
1217 .halt_reg = 0x9054,
1218 .halt_check = BRANCH_HALT,
1219 .clkr = {
1220 .enable_reg = 0x9054,
1221 .enable_mask = BIT(0),
1222 .hw.init = &(struct clk_init_data){
1223 .name = "camcc_ife_0_csid_clk",
1224 .parent_hws = (const struct clk_hw*[]){
1225 &camcc_ife_0_csid_clk_src.clkr.hw
1226 },
1227 .num_parents = 1,
1228 .flags = CLK_SET_RATE_PARENT,
1229 .ops = &clk_branch2_ops,
1230 },
1231 },
1232};
1233
1234static struct clk_branch camcc_ife_0_dsp_clk = {
1235 .halt_reg = 0x9038,
1236 .halt_check = BRANCH_HALT,
1237 .clkr = {
1238 .enable_reg = 0x9038,
1239 .enable_mask = BIT(0),
1240 .hw.init = &(struct clk_init_data){
1241 .name = "camcc_ife_0_dsp_clk",
1242 .parent_hws = (const struct clk_hw*[]){
1243 &camcc_ife_0_clk_src.clkr.hw
1244 },
1245 .num_parents = 1,
1246 .flags = CLK_SET_RATE_PARENT,
1247 .ops = &clk_branch2_ops,
1248 },
1249 },
1250};
1251
1252static struct clk_branch camcc_ife_1_axi_clk = {
1253 .halt_reg = 0xa058,
1254 .halt_check = BRANCH_HALT,
1255 .clkr = {
1256 .enable_reg = 0xa058,
1257 .enable_mask = BIT(0),
1258 .hw.init = &(struct clk_init_data){
1259 .name = "camcc_ife_1_axi_clk",
1260 .ops = &clk_branch2_ops,
1261 },
1262 },
1263};
1264
1265static struct clk_branch camcc_ife_1_clk = {
1266 .halt_reg = 0xa028,
1267 .halt_check = BRANCH_HALT,
1268 .clkr = {
1269 .enable_reg = 0xa028,
1270 .enable_mask = BIT(0),
1271 .hw.init = &(struct clk_init_data){
1272 .name = "camcc_ife_1_clk",
1273 .parent_hws = (const struct clk_hw*[]){
1274 &camcc_ife_1_clk_src.clkr.hw
1275 },
1276 .num_parents = 1,
1277 .flags = CLK_SET_RATE_PARENT,
1278 .ops = &clk_branch2_ops,
1279 },
1280 },
1281};
1282
1283static struct clk_branch camcc_ife_1_cphy_rx_clk = {
1284 .halt_reg = 0xa054,
1285 .halt_check = BRANCH_HALT,
1286 .clkr = {
1287 .enable_reg = 0xa054,
1288 .enable_mask = BIT(0),
1289 .hw.init = &(struct clk_init_data){
1290 .name = "camcc_ife_1_cphy_rx_clk",
1291 .parent_hws = (const struct clk_hw*[]){
1292 &camcc_cphy_rx_clk_src.clkr.hw
1293 },
1294 .num_parents = 1,
1295 .flags = CLK_SET_RATE_PARENT,
1296 .ops = &clk_branch2_ops,
1297 },
1298 },
1299};
1300
1301static struct clk_branch camcc_ife_1_csid_clk = {
1302 .halt_reg = 0xa04c,
1303 .halt_check = BRANCH_HALT,
1304 .clkr = {
1305 .enable_reg = 0xa04c,
1306 .enable_mask = BIT(0),
1307 .hw.init = &(struct clk_init_data){
1308 .name = "camcc_ife_1_csid_clk",
1309 .parent_hws = (const struct clk_hw*[]){
1310 &camcc_ife_1_csid_clk_src.clkr.hw
1311 },
1312 .num_parents = 1,
1313 .flags = CLK_SET_RATE_PARENT,
1314 .ops = &clk_branch2_ops,
1315 },
1316 },
1317};
1318
1319static struct clk_branch camcc_ife_1_dsp_clk = {
1320 .halt_reg = 0xa030,
1321 .halt_check = BRANCH_HALT,
1322 .clkr = {
1323 .enable_reg = 0xa030,
1324 .enable_mask = BIT(0),
1325 .hw.init = &(struct clk_init_data){
1326 .name = "camcc_ife_1_dsp_clk",
1327 .parent_hws = (const struct clk_hw*[]){
1328 &camcc_ife_1_clk_src.clkr.hw
1329 },
1330 .num_parents = 1,
1331 .flags = CLK_SET_RATE_PARENT,
1332 .ops = &clk_branch2_ops,
1333 },
1334 },
1335};
1336
1337static struct clk_branch camcc_ife_2_axi_clk = {
1338 .halt_reg = 0xb054,
1339 .halt_check = BRANCH_HALT,
1340 .clkr = {
1341 .enable_reg = 0xb054,
1342 .enable_mask = BIT(0),
1343 .hw.init = &(struct clk_init_data){
1344 .name = "camcc_ife_2_axi_clk",
1345 .ops = &clk_branch2_ops,
1346 },
1347 },
1348};
1349
1350static struct clk_branch camcc_ife_2_clk = {
1351 .halt_reg = 0xb024,
1352 .halt_check = BRANCH_HALT,
1353 .clkr = {
1354 .enable_reg = 0xb024,
1355 .enable_mask = BIT(0),
1356 .hw.init = &(struct clk_init_data){
1357 .name = "camcc_ife_2_clk",
1358 .parent_hws = (const struct clk_hw*[]){
1359 &camcc_ife_2_clk_src.clkr.hw
1360 },
1361 .num_parents = 1,
1362 .flags = CLK_SET_RATE_PARENT,
1363 .ops = &clk_branch2_ops,
1364 },
1365 },
1366};
1367
1368static struct clk_branch camcc_ife_2_cphy_rx_clk = {
1369 .halt_reg = 0xb050,
1370 .halt_check = BRANCH_HALT,
1371 .clkr = {
1372 .enable_reg = 0xb050,
1373 .enable_mask = BIT(0),
1374 .hw.init = &(struct clk_init_data){
1375 .name = "camcc_ife_2_cphy_rx_clk",
1376 .parent_hws = (const struct clk_hw*[]){
1377 &camcc_cphy_rx_clk_src.clkr.hw
1378 },
1379 .num_parents = 1,
1380 .flags = CLK_SET_RATE_PARENT,
1381 .ops = &clk_branch2_ops,
1382 },
1383 },
1384};
1385
1386static struct clk_branch camcc_ife_2_csid_clk = {
1387 .halt_reg = 0xb048,
1388 .halt_check = BRANCH_HALT,
1389 .clkr = {
1390 .enable_reg = 0xb048,
1391 .enable_mask = BIT(0),
1392 .hw.init = &(struct clk_init_data){
1393 .name = "camcc_ife_2_csid_clk",
1394 .parent_hws = (const struct clk_hw*[]){
1395 &camcc_ife_2_csid_clk_src.clkr.hw
1396 },
1397 .num_parents = 1,
1398 .flags = CLK_SET_RATE_PARENT,
1399 .ops = &clk_branch2_ops,
1400 },
1401 },
1402};
1403
1404static struct clk_branch camcc_ife_2_dsp_clk = {
1405 .halt_reg = 0xb02c,
1406 .halt_check = BRANCH_HALT,
1407 .clkr = {
1408 .enable_reg = 0xb02c,
1409 .enable_mask = BIT(0),
1410 .hw.init = &(struct clk_init_data){
1411 .name = "camcc_ife_2_dsp_clk",
1412 .parent_hws = (const struct clk_hw*[]){
1413 &camcc_ife_2_clk_src.clkr.hw
1414 },
1415 .num_parents = 1,
1416 .flags = CLK_SET_RATE_PARENT,
1417 .ops = &clk_branch2_ops,
1418 },
1419 },
1420};
1421
1422static struct clk_branch camcc_ife_lite_clk = {
1423 .halt_reg = 0xc01c,
1424 .halt_check = BRANCH_HALT,
1425 .clkr = {
1426 .enable_reg = 0xc01c,
1427 .enable_mask = BIT(0),
1428 .hw.init = &(struct clk_init_data){
1429 .name = "camcc_ife_lite_clk",
1430 .parent_hws = (const struct clk_hw*[]){
1431 &camcc_ife_lite_clk_src.clkr.hw
1432 },
1433 .num_parents = 1,
1434 .flags = CLK_SET_RATE_PARENT,
1435 .ops = &clk_branch2_ops,
1436 },
1437 },
1438};
1439
1440static struct clk_branch camcc_ife_lite_cphy_rx_clk = {
1441 .halt_reg = 0xc044,
1442 .halt_check = BRANCH_HALT,
1443 .clkr = {
1444 .enable_reg = 0xc044,
1445 .enable_mask = BIT(0),
1446 .hw.init = &(struct clk_init_data){
1447 .name = "camcc_ife_lite_cphy_rx_clk",
1448 .parent_hws = (const struct clk_hw*[]){
1449 &camcc_cphy_rx_clk_src.clkr.hw
1450 },
1451 .num_parents = 1,
1452 .flags = CLK_SET_RATE_PARENT,
1453 .ops = &clk_branch2_ops,
1454 },
1455 },
1456};
1457
1458static struct clk_branch camcc_ife_lite_csid_clk = {
1459 .halt_reg = 0xc03c,
1460 .halt_check = BRANCH_HALT,
1461 .clkr = {
1462 .enable_reg = 0xc03c,
1463 .enable_mask = BIT(0),
1464 .hw.init = &(struct clk_init_data){
1465 .name = "camcc_ife_lite_csid_clk",
1466 .parent_hws = (const struct clk_hw*[]){
1467 &camcc_ife_lite_csid_clk_src.clkr.hw
1468 },
1469 .num_parents = 1,
1470 .flags = CLK_SET_RATE_PARENT,
1471 .ops = &clk_branch2_ops,
1472 },
1473 },
1474};
1475
1476static struct clk_branch camcc_ipe_0_ahb_clk = {
1477 .halt_reg = 0x7040,
1478 .halt_check = BRANCH_HALT,
1479 .clkr = {
1480 .enable_reg = 0x7040,
1481 .enable_mask = BIT(0),
1482 .hw.init = &(struct clk_init_data){
1483 .name = "camcc_ipe_0_ahb_clk",
1484 .parent_hws = (const struct clk_hw*[]){
1485 &camcc_slow_ahb_clk_src.clkr.hw
1486 },
1487 .num_parents = 1,
1488 .flags = CLK_SET_RATE_PARENT,
1489 .ops = &clk_branch2_ops,
1490 },
1491 },
1492};
1493
1494static struct clk_branch camcc_ipe_0_areg_clk = {
1495 .halt_reg = 0x703c,
1496 .halt_check = BRANCH_HALT,
1497 .clkr = {
1498 .enable_reg = 0x703c,
1499 .enable_mask = BIT(0),
1500 .hw.init = &(struct clk_init_data){
1501 .name = "camcc_ipe_0_areg_clk",
1502 .parent_hws = (const struct clk_hw*[]){
1503 &camcc_fast_ahb_clk_src.clkr.hw
1504 },
1505 .num_parents = 1,
1506 .flags = CLK_SET_RATE_PARENT,
1507 .ops = &clk_branch2_ops,
1508 },
1509 },
1510};
1511
1512static struct clk_branch camcc_ipe_0_axi_clk = {
1513 .halt_reg = 0x7038,
1514 .halt_check = BRANCH_HALT,
1515 .clkr = {
1516 .enable_reg = 0x7038,
1517 .enable_mask = BIT(0),
1518 .hw.init = &(struct clk_init_data){
1519 .name = "camcc_ipe_0_axi_clk",
1520 .ops = &clk_branch2_ops,
1521 },
1522 },
1523};
1524
1525static struct clk_branch camcc_ipe_0_clk = {
1526 .halt_reg = 0x7028,
1527 .halt_check = BRANCH_HALT,
1528 .clkr = {
1529 .enable_reg = 0x7028,
1530 .enable_mask = BIT(0),
1531 .hw.init = &(struct clk_init_data){
1532 .name = "camcc_ipe_0_clk",
1533 .parent_hws = (const struct clk_hw*[]){
1534 &camcc_ipe_0_clk_src.clkr.hw
1535 },
1536 .num_parents = 1,
1537 .flags = CLK_SET_RATE_PARENT,
1538 .ops = &clk_branch2_ops,
1539 },
1540 },
1541};
1542
1543static struct clk_branch camcc_jpeg_clk = {
1544 .halt_reg = 0xd01c,
1545 .halt_check = BRANCH_HALT,
1546 .clkr = {
1547 .enable_reg = 0xd01c,
1548 .enable_mask = BIT(0),
1549 .hw.init = &(struct clk_init_data){
1550 .name = "camcc_jpeg_clk",
1551 .parent_hws = (const struct clk_hw*[]){
1552 &camcc_jpeg_clk_src.clkr.hw
1553 },
1554 .num_parents = 1,
1555 .flags = CLK_SET_RATE_PARENT,
1556 .ops = &clk_branch2_ops,
1557 },
1558 },
1559};
1560
1561static struct clk_branch camcc_lrme_clk = {
1562 .halt_reg = 0x1101c,
1563 .halt_check = BRANCH_HALT,
1564 .clkr = {
1565 .enable_reg = 0x1101c,
1566 .enable_mask = BIT(0),
1567 .hw.init = &(struct clk_init_data){
1568 .name = "camcc_lrme_clk",
1569 .parent_hws = (const struct clk_hw*[]){
1570 &camcc_lrme_clk_src.clkr.hw
1571 },
1572 .num_parents = 1,
1573 .flags = CLK_SET_RATE_PARENT,
1574 .ops = &clk_branch2_ops,
1575 },
1576 },
1577};
1578
1579static struct clk_branch camcc_mclk0_clk = {
1580 .halt_reg = 0x401c,
1581 .halt_check = BRANCH_HALT,
1582 .clkr = {
1583 .enable_reg = 0x401c,
1584 .enable_mask = BIT(0),
1585 .hw.init = &(struct clk_init_data){
1586 .name = "camcc_mclk0_clk",
1587 .parent_hws = (const struct clk_hw*[]){
1588 &camcc_mclk0_clk_src.clkr.hw
1589 },
1590 .num_parents = 1,
1591 .flags = CLK_SET_RATE_PARENT,
1592 .ops = &clk_branch2_ops,
1593 },
1594 },
1595};
1596
1597static struct clk_branch camcc_mclk1_clk = {
1598 .halt_reg = 0x403c,
1599 .halt_check = BRANCH_HALT,
1600 .clkr = {
1601 .enable_reg = 0x403c,
1602 .enable_mask = BIT(0),
1603 .hw.init = &(struct clk_init_data){
1604 .name = "camcc_mclk1_clk",
1605 .parent_hws = (const struct clk_hw*[]){
1606 &camcc_mclk1_clk_src.clkr.hw
1607 },
1608 .num_parents = 1,
1609 .flags = CLK_SET_RATE_PARENT,
1610 .ops = &clk_branch2_ops,
1611 },
1612 },
1613};
1614
1615static struct clk_branch camcc_mclk2_clk = {
1616 .halt_reg = 0x405c,
1617 .halt_check = BRANCH_HALT,
1618 .clkr = {
1619 .enable_reg = 0x405c,
1620 .enable_mask = BIT(0),
1621 .hw.init = &(struct clk_init_data){
1622 .name = "camcc_mclk2_clk",
1623 .parent_hws = (const struct clk_hw*[]){
1624 &camcc_mclk2_clk_src.clkr.hw
1625 },
1626 .num_parents = 1,
1627 .flags = CLK_SET_RATE_PARENT,
1628 .ops = &clk_branch2_ops,
1629 },
1630 },
1631};
1632
1633static struct clk_branch camcc_mclk3_clk = {
1634 .halt_reg = 0x407c,
1635 .halt_check = BRANCH_HALT,
1636 .clkr = {
1637 .enable_reg = 0x407c,
1638 .enable_mask = BIT(0),
1639 .hw.init = &(struct clk_init_data){
1640 .name = "camcc_mclk3_clk",
1641 .parent_hws = (const struct clk_hw*[]){
1642 &camcc_mclk3_clk_src.clkr.hw
1643 },
1644 .num_parents = 1,
1645 .flags = CLK_SET_RATE_PARENT,
1646 .ops = &clk_branch2_ops,
1647 },
1648 },
1649};
1650
1651static struct clk_branch camcc_mclk4_clk = {
1652 .halt_reg = 0x409c,
1653 .halt_check = BRANCH_HALT,
1654 .clkr = {
1655 .enable_reg = 0x409c,
1656 .enable_mask = BIT(0),
1657 .hw.init = &(struct clk_init_data){
1658 .name = "camcc_mclk4_clk",
1659 .parent_hws = (const struct clk_hw*[]){
1660 &camcc_mclk4_clk_src.clkr.hw
1661 },
1662 .num_parents = 1,
1663 .flags = CLK_SET_RATE_PARENT,
1664 .ops = &clk_branch2_ops,
1665 },
1666 },
1667};
1668
1669static struct clk_branch camcc_soc_ahb_clk = {
1670 .halt_reg = 0x1400c,
1671 .halt_check = BRANCH_HALT,
1672 .clkr = {
1673 .enable_reg = 0x1400c,
1674 .enable_mask = BIT(0),
1675 .hw.init = &(struct clk_init_data){
1676 .name = "camcc_soc_ahb_clk",
1677 .ops = &clk_branch2_ops,
1678 },
1679 },
1680};
1681
1682static struct clk_branch camcc_sys_tmr_clk = {
1683 .halt_reg = 0xe034,
1684 .halt_check = BRANCH_HALT,
1685 .clkr = {
1686 .enable_reg = 0xe034,
1687 .enable_mask = BIT(0),
1688 .hw.init = &(struct clk_init_data){
1689 .name = "camcc_sys_tmr_clk",
1690 .ops = &clk_branch2_ops,
1691 },
1692 },
1693};
1694
1695static struct gdsc bps_gdsc = {
1696 .gdscr = 0x6004,
1697 .pd = {
1698 .name = "bps_gdsc",
1699 },
1700 .pwrsts = PWRSTS_OFF_ON,
1701 .flags = VOTABLE,
1702};
1703
1704static struct gdsc ipe_0_gdsc = {
1705 .gdscr = 0x7004,
1706 .pd = {
1707 .name = "ipe_0_gdsc",
1708 },
1709 .pwrsts = PWRSTS_OFF_ON,
1710 .flags = VOTABLE,
1711};
1712
1713static struct gdsc ife_0_gdsc = {
1714 .gdscr = 0x9004,
1715 .pd = {
1716 .name = "ife_0_gdsc",
1717 },
1718 .pwrsts = PWRSTS_OFF_ON,
1719};
1720
1721static struct gdsc ife_1_gdsc = {
1722 .gdscr = 0xa004,
1723 .pd = {
1724 .name = "ife_1_gdsc",
1725 },
1726 .pwrsts = PWRSTS_OFF_ON,
1727};
1728
1729static struct gdsc ife_2_gdsc = {
1730 .gdscr = 0xb004,
1731 .pd = {
1732 .name = "ife_2_gdsc",
1733 },
1734 .pwrsts = PWRSTS_OFF_ON,
1735};
1736
1737static struct gdsc titan_top_gdsc = {
1738 .gdscr = 0x14004,
1739 .pd = {
1740 .name = "titan_top_gdsc",
1741 },
1742 .pwrsts = PWRSTS_OFF_ON,
1743};
1744
1745static struct clk_hw *camcc_sm6350_hws[] = {
1746 [CAMCC_PLL2_OUT_EARLY] = &camcc_pll2_out_early.hw,
1747};
1748
1749static struct clk_regmap *camcc_sm6350_clocks[] = {
1750 [CAMCC_BPS_AHB_CLK] = &camcc_bps_ahb_clk.clkr,
1751 [CAMCC_BPS_AREG_CLK] = &camcc_bps_areg_clk.clkr,
1752 [CAMCC_BPS_AXI_CLK] = &camcc_bps_axi_clk.clkr,
1753 [CAMCC_BPS_CLK] = &camcc_bps_clk.clkr,
1754 [CAMCC_BPS_CLK_SRC] = &camcc_bps_clk_src.clkr,
1755 [CAMCC_CAMNOC_AXI_CLK] = &camcc_camnoc_axi_clk.clkr,
1756 [CAMCC_CCI_0_CLK] = &camcc_cci_0_clk.clkr,
1757 [CAMCC_CCI_0_CLK_SRC] = &camcc_cci_0_clk_src.clkr,
1758 [CAMCC_CCI_1_CLK] = &camcc_cci_1_clk.clkr,
1759 [CAMCC_CCI_1_CLK_SRC] = &camcc_cci_1_clk_src.clkr,
1760 [CAMCC_CORE_AHB_CLK] = &camcc_core_ahb_clk.clkr,
1761 [CAMCC_CPAS_AHB_CLK] = &camcc_cpas_ahb_clk.clkr,
1762 [CAMCC_CPHY_RX_CLK_SRC] = &camcc_cphy_rx_clk_src.clkr,
1763 [CAMCC_CSI0PHYTIMER_CLK] = &camcc_csi0phytimer_clk.clkr,
1764 [CAMCC_CSI0PHYTIMER_CLK_SRC] = &camcc_csi0phytimer_clk_src.clkr,
1765 [CAMCC_CSI1PHYTIMER_CLK] = &camcc_csi1phytimer_clk.clkr,
1766 [CAMCC_CSI1PHYTIMER_CLK_SRC] = &camcc_csi1phytimer_clk_src.clkr,
1767 [CAMCC_CSI2PHYTIMER_CLK] = &camcc_csi2phytimer_clk.clkr,
1768 [CAMCC_CSI2PHYTIMER_CLK_SRC] = &camcc_csi2phytimer_clk_src.clkr,
1769 [CAMCC_CSI3PHYTIMER_CLK] = &camcc_csi3phytimer_clk.clkr,
1770 [CAMCC_CSI3PHYTIMER_CLK_SRC] = &camcc_csi3phytimer_clk_src.clkr,
1771 [CAMCC_CSIPHY0_CLK] = &camcc_csiphy0_clk.clkr,
1772 [CAMCC_CSIPHY1_CLK] = &camcc_csiphy1_clk.clkr,
1773 [CAMCC_CSIPHY2_CLK] = &camcc_csiphy2_clk.clkr,
1774 [CAMCC_CSIPHY3_CLK] = &camcc_csiphy3_clk.clkr,
1775 [CAMCC_FAST_AHB_CLK_SRC] = &camcc_fast_ahb_clk_src.clkr,
1776 [CAMCC_ICP_CLK] = &camcc_icp_clk.clkr,
1777 [CAMCC_ICP_CLK_SRC] = &camcc_icp_clk_src.clkr,
1778 [CAMCC_ICP_TS_CLK] = &camcc_icp_ts_clk.clkr,
1779 [CAMCC_IFE_0_AXI_CLK] = &camcc_ife_0_axi_clk.clkr,
1780 [CAMCC_IFE_0_CLK] = &camcc_ife_0_clk.clkr,
1781 [CAMCC_IFE_0_CLK_SRC] = &camcc_ife_0_clk_src.clkr,
1782 [CAMCC_IFE_0_CPHY_RX_CLK] = &camcc_ife_0_cphy_rx_clk.clkr,
1783 [CAMCC_IFE_0_CSID_CLK] = &camcc_ife_0_csid_clk.clkr,
1784 [CAMCC_IFE_0_CSID_CLK_SRC] = &camcc_ife_0_csid_clk_src.clkr,
1785 [CAMCC_IFE_0_DSP_CLK] = &camcc_ife_0_dsp_clk.clkr,
1786 [CAMCC_IFE_1_AXI_CLK] = &camcc_ife_1_axi_clk.clkr,
1787 [CAMCC_IFE_1_CLK] = &camcc_ife_1_clk.clkr,
1788 [CAMCC_IFE_1_CLK_SRC] = &camcc_ife_1_clk_src.clkr,
1789 [CAMCC_IFE_1_CPHY_RX_CLK] = &camcc_ife_1_cphy_rx_clk.clkr,
1790 [CAMCC_IFE_1_CSID_CLK] = &camcc_ife_1_csid_clk.clkr,
1791 [CAMCC_IFE_1_CSID_CLK_SRC] = &camcc_ife_1_csid_clk_src.clkr,
1792 [CAMCC_IFE_1_DSP_CLK] = &camcc_ife_1_dsp_clk.clkr,
1793 [CAMCC_IFE_2_AXI_CLK] = &camcc_ife_2_axi_clk.clkr,
1794 [CAMCC_IFE_2_CLK] = &camcc_ife_2_clk.clkr,
1795 [CAMCC_IFE_2_CLK_SRC] = &camcc_ife_2_clk_src.clkr,
1796 [CAMCC_IFE_2_CPHY_RX_CLK] = &camcc_ife_2_cphy_rx_clk.clkr,
1797 [CAMCC_IFE_2_CSID_CLK] = &camcc_ife_2_csid_clk.clkr,
1798 [CAMCC_IFE_2_CSID_CLK_SRC] = &camcc_ife_2_csid_clk_src.clkr,
1799 [CAMCC_IFE_2_DSP_CLK] = &camcc_ife_2_dsp_clk.clkr,
1800 [CAMCC_IFE_LITE_CLK] = &camcc_ife_lite_clk.clkr,
1801 [CAMCC_IFE_LITE_CLK_SRC] = &camcc_ife_lite_clk_src.clkr,
1802 [CAMCC_IFE_LITE_CPHY_RX_CLK] = &camcc_ife_lite_cphy_rx_clk.clkr,
1803 [CAMCC_IFE_LITE_CSID_CLK] = &camcc_ife_lite_csid_clk.clkr,
1804 [CAMCC_IFE_LITE_CSID_CLK_SRC] = &camcc_ife_lite_csid_clk_src.clkr,
1805 [CAMCC_IPE_0_AHB_CLK] = &camcc_ipe_0_ahb_clk.clkr,
1806 [CAMCC_IPE_0_AREG_CLK] = &camcc_ipe_0_areg_clk.clkr,
1807 [CAMCC_IPE_0_AXI_CLK] = &camcc_ipe_0_axi_clk.clkr,
1808 [CAMCC_IPE_0_CLK] = &camcc_ipe_0_clk.clkr,
1809 [CAMCC_IPE_0_CLK_SRC] = &camcc_ipe_0_clk_src.clkr,
1810 [CAMCC_JPEG_CLK] = &camcc_jpeg_clk.clkr,
1811 [CAMCC_JPEG_CLK_SRC] = &camcc_jpeg_clk_src.clkr,
1812 [CAMCC_LRME_CLK] = &camcc_lrme_clk.clkr,
1813 [CAMCC_LRME_CLK_SRC] = &camcc_lrme_clk_src.clkr,
1814 [CAMCC_MCLK0_CLK] = &camcc_mclk0_clk.clkr,
1815 [CAMCC_MCLK0_CLK_SRC] = &camcc_mclk0_clk_src.clkr,
1816 [CAMCC_MCLK1_CLK] = &camcc_mclk1_clk.clkr,
1817 [CAMCC_MCLK1_CLK_SRC] = &camcc_mclk1_clk_src.clkr,
1818 [CAMCC_MCLK2_CLK] = &camcc_mclk2_clk.clkr,
1819 [CAMCC_MCLK2_CLK_SRC] = &camcc_mclk2_clk_src.clkr,
1820 [CAMCC_MCLK3_CLK] = &camcc_mclk3_clk.clkr,
1821 [CAMCC_MCLK3_CLK_SRC] = &camcc_mclk3_clk_src.clkr,
1822 [CAMCC_MCLK4_CLK] = &camcc_mclk4_clk.clkr,
1823 [CAMCC_MCLK4_CLK_SRC] = &camcc_mclk4_clk_src.clkr,
1824 [CAMCC_PLL0] = &camcc_pll0.clkr,
1825 [CAMCC_PLL0_OUT_EVEN] = &camcc_pll0_out_even.clkr,
1826 [CAMCC_PLL1] = &camcc_pll1.clkr,
1827 [CAMCC_PLL1_OUT_EVEN] = &camcc_pll1_out_even.clkr,
1828 [CAMCC_PLL2] = &camcc_pll2.clkr,
1829 [CAMCC_PLL2_OUT_MAIN] = &camcc_pll2_out_main.clkr,
1830 [CAMCC_PLL3] = &camcc_pll3.clkr,
1831 [CAMCC_SLOW_AHB_CLK_SRC] = &camcc_slow_ahb_clk_src.clkr,
1832 [CAMCC_SOC_AHB_CLK] = &camcc_soc_ahb_clk.clkr,
1833 [CAMCC_SYS_TMR_CLK] = &camcc_sys_tmr_clk.clkr,
1834};
1835
1836static struct gdsc *camcc_sm6350_gdscs[] = {
1837 [BPS_GDSC] = &bps_gdsc,
1838 [IPE_0_GDSC] = &ipe_0_gdsc,
1839 [IFE_0_GDSC] = &ife_0_gdsc,
1840 [IFE_1_GDSC] = &ife_1_gdsc,
1841 [IFE_2_GDSC] = &ife_2_gdsc,
1842 [TITAN_TOP_GDSC] = &titan_top_gdsc,
1843};
1844
1845static const struct regmap_config camcc_sm6350_regmap_config = {
1846 .reg_bits = 32,
1847 .reg_stride = 4,
1848 .val_bits = 32,
1849 .max_register = 0x16000,
1850 .fast_io = true,
1851};
1852
1853static const struct qcom_cc_desc camcc_sm6350_desc = {
1854 .config = &camcc_sm6350_regmap_config,
1855 .clk_hws = camcc_sm6350_hws,
1856 .num_clk_hws = ARRAY_SIZE(camcc_sm6350_hws),
1857 .clks = camcc_sm6350_clocks,
1858 .num_clks = ARRAY_SIZE(camcc_sm6350_clocks),
1859 .gdscs = camcc_sm6350_gdscs,
1860 .num_gdscs = ARRAY_SIZE(camcc_sm6350_gdscs),
1861};
1862
1863static const struct of_device_id camcc_sm6350_match_table[] = {
1864 { .compatible = "qcom,sm6350-camcc" },
1865 { }
1866};
1867MODULE_DEVICE_TABLE(of, camcc_sm6350_match_table);
1868
1869static int camcc_sm6350_probe(struct platform_device *pdev)
1870{
1871 struct regmap *regmap;
1872
1873 regmap = qcom_cc_map(pdev, desc: &camcc_sm6350_desc);
1874 if (IS_ERR(ptr: regmap))
1875 return PTR_ERR(ptr: regmap);
1876
1877 clk_fabia_pll_configure(pll: &camcc_pll0, regmap, config: &camcc_pll0_config);
1878 clk_fabia_pll_configure(pll: &camcc_pll1, regmap, config: &camcc_pll1_config);
1879 clk_agera_pll_configure(pll: &camcc_pll2, regmap, config: &camcc_pll2_config);
1880 clk_fabia_pll_configure(pll: &camcc_pll3, regmap, config: &camcc_pll3_config);
1881
1882 return qcom_cc_really_probe(pdev, desc: &camcc_sm6350_desc, regmap);
1883}
1884
1885static struct platform_driver camcc_sm6350_driver = {
1886 .probe = camcc_sm6350_probe,
1887 .driver = {
1888 .name = "sm6350-camcc",
1889 .of_match_table = camcc_sm6350_match_table,
1890 },
1891};
1892
1893module_platform_driver(camcc_sm6350_driver);
1894
1895MODULE_DESCRIPTION("QTI CAMCC SM6350 Driver");
1896MODULE_LICENSE("GPL");
1897

source code of linux/drivers/clk/qcom/camcc-sm6350.c