1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Copyright (c) 2018, The Linux Foundation. All rights reserved.
4 */
5
6 #include <linux/kernel.h>
7 #include <linux/err.h>
8 #include <linux/platform_device.h>
9 #include <linux/module.h>
10 #include <linux/of.h>
11 #include <linux/of_device.h>
12 #include <linux/clk-provider.h>
13 #include <linux/regmap.h>
14
15 #include <linux/reset-controller.h>
16 #include <dt-bindings/clock/qcom,gcc-ipq6018.h>
17 #include <dt-bindings/reset/qcom,gcc-ipq6018.h>
18
19 #include "common.h"
20 #include "clk-regmap.h"
21 #include "clk-pll.h"
22 #include "clk-rcg.h"
23 #include "clk-branch.h"
24 #include "clk-alpha-pll.h"
25 #include "clk-regmap-divider.h"
26 #include "clk-regmap-mux.h"
27 #include "reset.h"
28
29 #define F(f, s, h, m, n) { (f), (s), (2 * (h) - 1), (m), (n) }
30
31 enum {
32 P_XO,
33 P_BIAS_PLL,
34 P_UNIPHY0_RX,
35 P_UNIPHY0_TX,
36 P_UNIPHY1_RX,
37 P_BIAS_PLL_NSS_NOC,
38 P_UNIPHY1_TX,
39 P_PCIE20_PHY0_PIPE,
40 P_USB3PHY_0_PIPE,
41 P_GPLL0,
42 P_GPLL0_DIV2,
43 P_GPLL2,
44 P_GPLL4,
45 P_GPLL6,
46 P_SLEEP_CLK,
47 P_UBI32_PLL,
48 P_NSS_CRYPTO_PLL,
49 P_PI_SLEEP,
50 };
51
52 static struct clk_alpha_pll gpll0_main = {
53 .offset = 0x21000,
54 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
55 .clkr = {
56 .enable_reg = 0x0b000,
57 .enable_mask = BIT(0),
58 .hw.init = &(struct clk_init_data){
59 .name = "gpll0_main",
60 .parent_data = &(const struct clk_parent_data){
61 .fw_name = "xo",
62 },
63 .num_parents = 1,
64 .ops = &clk_alpha_pll_ops,
65 },
66 },
67 };
68
69 static struct clk_fixed_factor gpll0_out_main_div2 = {
70 .mult = 1,
71 .div = 2,
72 .hw.init = &(struct clk_init_data){
73 .name = "gpll0_out_main_div2",
74 .parent_hws = (const struct clk_hw *[]){
75 &gpll0_main.clkr.hw },
76 .num_parents = 1,
77 .ops = &clk_fixed_factor_ops,
78 .flags = CLK_SET_RATE_PARENT,
79 },
80 };
81
82 static struct clk_alpha_pll_postdiv gpll0 = {
83 .offset = 0x21000,
84 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
85 .width = 4,
86 .clkr.hw.init = &(struct clk_init_data){
87 .name = "gpll0",
88 .parent_hws = (const struct clk_hw *[]){
89 &gpll0_main.clkr.hw },
90 .num_parents = 1,
91 .ops = &clk_alpha_pll_postdiv_ro_ops,
92 .flags = CLK_SET_RATE_PARENT,
93 },
94 };
95
96 static const struct clk_parent_data gcc_xo_gpll0_gpll0_out_main_div2[] = {
97 { .fw_name = "xo" },
98 { .hw = &gpll0.clkr.hw},
99 { .hw = &gpll0_out_main_div2.hw},
100 };
101
102 static const struct parent_map gcc_xo_gpll0_gpll0_out_main_div2_map[] = {
103 { P_XO, 0 },
104 { P_GPLL0, 1 },
105 { P_GPLL0_DIV2, 4 },
106 };
107
108 static struct clk_alpha_pll ubi32_pll_main = {
109 .offset = 0x25000,
110 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_HUAYRA],
111 .flags = SUPPORTS_DYNAMIC_UPDATE,
112 .clkr = {
113 .enable_reg = 0x0b000,
114 .enable_mask = BIT(6),
115 .hw.init = &(struct clk_init_data){
116 .name = "ubi32_pll_main",
117 .parent_data = &(const struct clk_parent_data){
118 .fw_name = "xo",
119 },
120 .num_parents = 1,
121 .ops = &clk_alpha_pll_huayra_ops,
122 },
123 },
124 };
125
126 static struct clk_alpha_pll_postdiv ubi32_pll = {
127 .offset = 0x25000,
128 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_HUAYRA],
129 .width = 2,
130 .clkr.hw.init = &(struct clk_init_data){
131 .name = "ubi32_pll",
132 .parent_hws = (const struct clk_hw *[]){
133 &ubi32_pll_main.clkr.hw },
134 .num_parents = 1,
135 .ops = &clk_alpha_pll_postdiv_ro_ops,
136 .flags = CLK_SET_RATE_PARENT,
137 },
138 };
139
140 static struct clk_alpha_pll gpll6_main = {
141 .offset = 0x37000,
142 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_BRAMMO],
143 .clkr = {
144 .enable_reg = 0x0b000,
145 .enable_mask = BIT(7),
146 .hw.init = &(struct clk_init_data){
147 .name = "gpll6_main",
148 .parent_data = &(const struct clk_parent_data){
149 .fw_name = "xo",
150 },
151 .num_parents = 1,
152 .ops = &clk_alpha_pll_ops,
153 },
154 },
155 };
156
157 static struct clk_alpha_pll_postdiv gpll6 = {
158 .offset = 0x37000,
159 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_BRAMMO],
160 .width = 2,
161 .clkr.hw.init = &(struct clk_init_data){
162 .name = "gpll6",
163 .parent_hws = (const struct clk_hw *[]){
164 &gpll6_main.clkr.hw },
165 .num_parents = 1,
166 .ops = &clk_alpha_pll_postdiv_ro_ops,
167 .flags = CLK_SET_RATE_PARENT,
168 },
169 };
170
171 static struct clk_alpha_pll gpll4_main = {
172 .offset = 0x24000,
173 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
174 .clkr = {
175 .enable_reg = 0x0b000,
176 .enable_mask = BIT(5),
177 .hw.init = &(struct clk_init_data){
178 .name = "gpll4_main",
179 .parent_data = &(const struct clk_parent_data){
180 .fw_name = "xo",
181 },
182 .num_parents = 1,
183 .ops = &clk_alpha_pll_ops,
184 },
185 },
186 };
187
188 static struct clk_alpha_pll_postdiv gpll4 = {
189 .offset = 0x24000,
190 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
191 .width = 4,
192 .clkr.hw.init = &(struct clk_init_data){
193 .name = "gpll4",
194 .parent_hws = (const struct clk_hw *[]){
195 &gpll4_main.clkr.hw },
196 .num_parents = 1,
197 .ops = &clk_alpha_pll_postdiv_ro_ops,
198 .flags = CLK_SET_RATE_PARENT,
199 },
200 };
201
202 static const struct freq_tbl ftbl_pcnoc_bfdcd_clk_src[] = {
203 F(24000000, P_XO, 1, 0, 0),
204 F(50000000, P_GPLL0, 16, 0, 0),
205 F(100000000, P_GPLL0, 8, 0, 0),
206 { }
207 };
208
209 static struct clk_rcg2 pcnoc_bfdcd_clk_src = {
210 .cmd_rcgr = 0x27000,
211 .freq_tbl = ftbl_pcnoc_bfdcd_clk_src,
212 .hid_width = 5,
213 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
214 .clkr.hw.init = &(struct clk_init_data){
215 .name = "pcnoc_bfdcd_clk_src",
216 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
217 .num_parents = 3,
218 .ops = &clk_rcg2_ops,
219 },
220 };
221
222 static struct clk_alpha_pll gpll2_main = {
223 .offset = 0x4a000,
224 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
225 .clkr = {
226 .enable_reg = 0x0b000,
227 .enable_mask = BIT(2),
228 .hw.init = &(struct clk_init_data){
229 .name = "gpll2_main",
230 .parent_data = &(const struct clk_parent_data){
231 .fw_name = "xo",
232 },
233 .num_parents = 1,
234 .ops = &clk_alpha_pll_ops,
235 },
236 },
237 };
238
239 static struct clk_alpha_pll_postdiv gpll2 = {
240 .offset = 0x4a000,
241 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
242 .width = 4,
243 .clkr.hw.init = &(struct clk_init_data){
244 .name = "gpll2",
245 .parent_hws = (const struct clk_hw *[]){
246 &gpll2_main.clkr.hw },
247 .num_parents = 1,
248 .ops = &clk_alpha_pll_postdiv_ro_ops,
249 .flags = CLK_SET_RATE_PARENT,
250 },
251 };
252
253 static struct clk_alpha_pll nss_crypto_pll_main = {
254 .offset = 0x22000,
255 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
256 .clkr = {
257 .enable_reg = 0x0b000,
258 .enable_mask = BIT(4),
259 .hw.init = &(struct clk_init_data){
260 .name = "nss_crypto_pll_main",
261 .parent_data = &(const struct clk_parent_data){
262 .fw_name = "xo",
263 },
264 .num_parents = 1,
265 .ops = &clk_alpha_pll_ops,
266 },
267 },
268 };
269
270 static struct clk_alpha_pll_postdiv nss_crypto_pll = {
271 .offset = 0x22000,
272 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
273 .width = 4,
274 .clkr.hw.init = &(struct clk_init_data){
275 .name = "nss_crypto_pll",
276 .parent_hws = (const struct clk_hw *[]){
277 &nss_crypto_pll_main.clkr.hw },
278 .num_parents = 1,
279 .ops = &clk_alpha_pll_postdiv_ro_ops,
280 .flags = CLK_SET_RATE_PARENT,
281 },
282 };
283
284 static const struct freq_tbl ftbl_qdss_tsctr_clk_src[] = {
285 F(160000000, P_GPLL0_DIV2, 2.5, 0, 0),
286 F(320000000, P_GPLL0, 2.5, 0, 0),
287 F(600000000, P_GPLL4, 2, 0, 0),
288 { }
289 };
290
291 static const struct clk_parent_data gcc_xo_gpll4_gpll0_gpll6_gpll0_div2[] = {
292 { .fw_name = "xo" },
293 { .hw = &gpll4.clkr.hw },
294 { .hw = &gpll0.clkr.hw },
295 { .hw = &gpll6.clkr.hw },
296 { .hw = &gpll0_out_main_div2.hw },
297 };
298
299 static const struct parent_map gcc_xo_gpll4_gpll0_gpll6_gpll0_div2_map[] = {
300 { P_XO, 0 },
301 { P_GPLL4, 1 },
302 { P_GPLL0, 2 },
303 { P_GPLL6, 3 },
304 { P_GPLL0_DIV2, 4 },
305 };
306
307 static struct clk_rcg2 qdss_tsctr_clk_src = {
308 .cmd_rcgr = 0x29064,
309 .freq_tbl = ftbl_qdss_tsctr_clk_src,
310 .hid_width = 5,
311 .parent_map = gcc_xo_gpll4_gpll0_gpll6_gpll0_div2_map,
312 .clkr.hw.init = &(struct clk_init_data){
313 .name = "qdss_tsctr_clk_src",
314 .parent_data = gcc_xo_gpll4_gpll0_gpll6_gpll0_div2,
315 .num_parents = 5,
316 .ops = &clk_rcg2_ops,
317 },
318 };
319
320 static struct clk_fixed_factor qdss_dap_sync_clk_src = {
321 .mult = 1,
322 .div = 4,
323 .hw.init = &(struct clk_init_data){
324 .name = "qdss_dap_sync_clk_src",
325 .parent_hws = (const struct clk_hw *[]){
326 &qdss_tsctr_clk_src.clkr.hw },
327 .num_parents = 1,
328 .ops = &clk_fixed_factor_ops,
329 },
330 };
331
332 static const struct freq_tbl ftbl_qdss_at_clk_src[] = {
333 F(66670000, P_GPLL0_DIV2, 6, 0, 0),
334 F(240000000, P_GPLL4, 5, 0, 0),
335 { }
336 };
337
338 static struct clk_rcg2 qdss_at_clk_src = {
339 .cmd_rcgr = 0x2900c,
340 .freq_tbl = ftbl_qdss_at_clk_src,
341 .hid_width = 5,
342 .parent_map = gcc_xo_gpll4_gpll0_gpll6_gpll0_div2_map,
343 .clkr.hw.init = &(struct clk_init_data){
344 .name = "qdss_at_clk_src",
345 .parent_data = gcc_xo_gpll4_gpll0_gpll6_gpll0_div2,
346 .num_parents = 5,
347 .ops = &clk_rcg2_ops,
348 },
349 };
350
351 static struct clk_fixed_factor qdss_tsctr_div2_clk_src = {
352 .mult = 1,
353 .div = 2,
354 .hw.init = &(struct clk_init_data){
355 .name = "qdss_tsctr_div2_clk_src",
356 .parent_hws = (const struct clk_hw *[]){
357 &qdss_tsctr_clk_src.clkr.hw },
358 .num_parents = 1,
359 .flags = CLK_SET_RATE_PARENT,
360 .ops = &clk_fixed_factor_ops,
361 },
362 };
363
364 static const struct freq_tbl ftbl_nss_ppe_clk_src[] = {
365 F(24000000, P_XO, 1, 0, 0),
366 F(300000000, P_BIAS_PLL, 1, 0, 0),
367 { }
368 };
369
370 static const struct clk_parent_data gcc_xo_bias_gpll0_gpll4_nss_ubi32[] = {
371 { .fw_name = "xo" },
372 { .fw_name = "bias_pll_cc_clk" },
373 { .hw = &gpll0.clkr.hw },
374 { .hw = &gpll4.clkr.hw },
375 { .hw = &nss_crypto_pll.clkr.hw },
376 { .hw = &ubi32_pll.clkr.hw },
377 };
378
379 static const struct parent_map gcc_xo_bias_gpll0_gpll4_nss_ubi32_map[] = {
380 { P_XO, 0 },
381 { P_BIAS_PLL, 1 },
382 { P_GPLL0, 2 },
383 { P_GPLL4, 3 },
384 { P_NSS_CRYPTO_PLL, 4 },
385 { P_UBI32_PLL, 5 },
386 };
387
388 static struct clk_rcg2 nss_ppe_clk_src = {
389 .cmd_rcgr = 0x68080,
390 .freq_tbl = ftbl_nss_ppe_clk_src,
391 .hid_width = 5,
392 .parent_map = gcc_xo_bias_gpll0_gpll4_nss_ubi32_map,
393 .clkr.hw.init = &(struct clk_init_data){
394 .name = "nss_ppe_clk_src",
395 .parent_data = gcc_xo_bias_gpll0_gpll4_nss_ubi32,
396 .num_parents = 6,
397 .ops = &clk_rcg2_ops,
398 },
399 };
400
401 static struct clk_branch gcc_xo_clk_src = {
402 .halt_reg = 0x30018,
403 .clkr = {
404 .enable_reg = 0x30018,
405 .enable_mask = BIT(1),
406 .hw.init = &(struct clk_init_data){
407 .name = "gcc_xo_clk_src",
408 .parent_data = &(const struct clk_parent_data){
409 .fw_name = "xo",
410 },
411 .num_parents = 1,
412 .flags = CLK_SET_RATE_PARENT,
413 .ops = &clk_branch2_ops,
414 },
415 },
416 };
417
418 static const struct freq_tbl ftbl_nss_ce_clk_src[] = {
419 F(24000000, P_XO, 1, 0, 0),
420 F(200000000, P_GPLL0, 4, 0, 0),
421 { }
422 };
423
424 static const struct clk_parent_data gcc_xo_gpll0[] = {
425 { .fw_name = "xo" },
426 { .hw = &gpll0.clkr.hw },
427 };
428
429 static const struct parent_map gcc_xo_gpll0_map[] = {
430 { P_XO, 0 },
431 { P_GPLL0, 1 },
432 };
433
434 static struct clk_rcg2 nss_ce_clk_src = {
435 .cmd_rcgr = 0x68098,
436 .freq_tbl = ftbl_nss_ce_clk_src,
437 .hid_width = 5,
438 .parent_map = gcc_xo_gpll0_map,
439 .clkr.hw.init = &(struct clk_init_data){
440 .name = "nss_ce_clk_src",
441 .parent_data = gcc_xo_gpll0,
442 .num_parents = 2,
443 .ops = &clk_rcg2_ops,
444 },
445 };
446
447 static struct clk_branch gcc_sleep_clk_src = {
448 .halt_reg = 0x30000,
449 .clkr = {
450 .enable_reg = 0x30000,
451 .enable_mask = BIT(1),
452 .hw.init = &(struct clk_init_data){
453 .name = "gcc_sleep_clk_src",
454 .parent_data = &(const struct clk_parent_data){
455 .fw_name = "sleep_clk",
456 },
457 .num_parents = 1,
458 .ops = &clk_branch2_ops,
459 },
460 },
461 };
462
463 static const struct freq_tbl ftbl_snoc_nssnoc_bfdcd_clk_src[] = {
464 F(24000000, P_XO, 1, 0, 0),
465 F(50000000, P_GPLL0_DIV2, 8, 0, 0),
466 F(100000000, P_GPLL0, 8, 0, 0),
467 F(133333333, P_GPLL0, 6, 0, 0),
468 F(160000000, P_GPLL0, 5, 0, 0),
469 F(200000000, P_GPLL0, 4, 0, 0),
470 F(266666667, P_GPLL0, 3, 0, 0),
471 { }
472 };
473
474 static const struct clk_parent_data
475 gcc_xo_gpll0_gpll6_gpll0_out_main_div2[] = {
476 { .fw_name = "xo" },
477 { .hw = &gpll0.clkr.hw },
478 { .hw = &gpll6.clkr.hw },
479 { .hw = &gpll0_out_main_div2.hw },
480 };
481
482 static const struct parent_map gcc_xo_gpll0_gpll6_gpll0_out_main_div2_map[] = {
483 { P_XO, 0 },
484 { P_GPLL0, 1 },
485 { P_GPLL6, 2 },
486 { P_GPLL0_DIV2, 3 },
487 };
488
489 static struct clk_rcg2 snoc_nssnoc_bfdcd_clk_src = {
490 .cmd_rcgr = 0x76054,
491 .freq_tbl = ftbl_snoc_nssnoc_bfdcd_clk_src,
492 .hid_width = 5,
493 .parent_map = gcc_xo_gpll0_gpll6_gpll0_out_main_div2_map,
494 .clkr.hw.init = &(struct clk_init_data){
495 .name = "snoc_nssnoc_bfdcd_clk_src",
496 .parent_data = gcc_xo_gpll0_gpll6_gpll0_out_main_div2,
497 .num_parents = 4,
498 .ops = &clk_rcg2_ops,
499 },
500 };
501
502 static const struct freq_tbl ftbl_apss_ahb_clk_src[] = {
503 F(24000000, P_XO, 1, 0, 0),
504 F(25000000, P_GPLL0_DIV2, 16, 0, 0),
505 F(50000000, P_GPLL0, 16, 0, 0),
506 F(100000000, P_GPLL0, 8, 0, 0),
507 { }
508 };
509
510 static struct clk_rcg2 apss_ahb_clk_src = {
511 .cmd_rcgr = 0x46000,
512 .freq_tbl = ftbl_apss_ahb_clk_src,
513 .hid_width = 5,
514 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
515 .clkr.hw.init = &(struct clk_init_data){
516 .name = "apss_ahb_clk_src",
517 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
518 .num_parents = 3,
519 .ops = &clk_rcg2_ops,
520 },
521 };
522
523 static const struct freq_tbl ftbl_nss_port5_rx_clk_src[] = {
524 F(24000000, P_XO, 1, 0, 0),
525 F(25000000, P_UNIPHY1_RX, 12.5, 0, 0),
526 F(25000000, P_UNIPHY0_RX, 5, 0, 0),
527 F(78125000, P_UNIPHY1_RX, 4, 0, 0),
528 F(125000000, P_UNIPHY1_RX, 2.5, 0, 0),
529 F(125000000, P_UNIPHY0_RX, 1, 0, 0),
530 F(156250000, P_UNIPHY1_RX, 2, 0, 0),
531 F(312500000, P_UNIPHY1_RX, 1, 0, 0),
532 { }
533 };
534
535 static const struct clk_parent_data
536 gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias[] = {
537 { .fw_name = "xo" },
538 { .fw_name = "uniphy0_gcc_rx_clk" },
539 { .fw_name = "uniphy0_gcc_tx_clk" },
540 { .fw_name = "uniphy1_gcc_rx_clk" },
541 { .fw_name = "uniphy1_gcc_tx_clk" },
542 { .hw = &ubi32_pll.clkr.hw },
543 { .fw_name = "bias_pll_cc_clk" },
544 };
545
546 static const struct parent_map
547 gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias_map[] = {
548 { P_XO, 0 },
549 { P_UNIPHY0_RX, 1 },
550 { P_UNIPHY0_TX, 2 },
551 { P_UNIPHY1_RX, 3 },
552 { P_UNIPHY1_TX, 4 },
553 { P_UBI32_PLL, 5 },
554 { P_BIAS_PLL, 6 },
555 };
556
557 static struct clk_rcg2 nss_port5_rx_clk_src = {
558 .cmd_rcgr = 0x68060,
559 .freq_tbl = ftbl_nss_port5_rx_clk_src,
560 .hid_width = 5,
561 .parent_map = gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias_map,
562 .clkr.hw.init = &(struct clk_init_data){
563 .name = "nss_port5_rx_clk_src",
564 .parent_data = gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias,
565 .num_parents = 7,
566 .ops = &clk_rcg2_ops,
567 },
568 };
569
570 static const struct freq_tbl ftbl_nss_port5_tx_clk_src[] = {
571 F(24000000, P_XO, 1, 0, 0),
572 F(25000000, P_UNIPHY1_TX, 12.5, 0, 0),
573 F(25000000, P_UNIPHY0_TX, 5, 0, 0),
574 F(78125000, P_UNIPHY1_TX, 4, 0, 0),
575 F(125000000, P_UNIPHY1_TX, 2.5, 0, 0),
576 F(125000000, P_UNIPHY0_TX, 1, 0, 0),
577 F(156250000, P_UNIPHY1_TX, 2, 0, 0),
578 F(312500000, P_UNIPHY1_TX, 1, 0, 0),
579 { }
580 };
581
582 static const struct clk_parent_data
583 gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias[] = {
584 { .fw_name = "xo" },
585 { .fw_name = "uniphy0_gcc_tx_clk" },
586 { .fw_name = "uniphy0_gcc_rx_clk" },
587 { .fw_name = "uniphy1_gcc_tx_clk" },
588 { .fw_name = "uniphy1_gcc_rx_clk" },
589 { .hw = &ubi32_pll.clkr.hw },
590 { .fw_name = "bias_pll_cc_clk" },
591 };
592
593 static const struct parent_map
594 gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias_map[] = {
595 { P_XO, 0 },
596 { P_UNIPHY0_TX, 1 },
597 { P_UNIPHY0_RX, 2 },
598 { P_UNIPHY1_TX, 3 },
599 { P_UNIPHY1_RX, 4 },
600 { P_UBI32_PLL, 5 },
601 { P_BIAS_PLL, 6 },
602 };
603
604 static struct clk_rcg2 nss_port5_tx_clk_src = {
605 .cmd_rcgr = 0x68068,
606 .freq_tbl = ftbl_nss_port5_tx_clk_src,
607 .hid_width = 5,
608 .parent_map = gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias_map,
609 .clkr.hw.init = &(struct clk_init_data){
610 .name = "nss_port5_tx_clk_src",
611 .parent_data = gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias,
612 .num_parents = 7,
613 .ops = &clk_rcg2_ops,
614 },
615 };
616
617 static const struct freq_tbl ftbl_pcie_axi_clk_src[] = {
618 F(24000000, P_XO, 1, 0, 0),
619 F(200000000, P_GPLL0, 4, 0, 0),
620 F(240000000, P_GPLL4, 5, 0, 0),
621 { }
622 };
623
624 static const struct freq_tbl ftbl_pcie_rchng_clk_src[] = {
625 F(24000000, P_XO, 1, 0, 0),
626 F(100000000, P_GPLL0, 8, 0, 0),
627 { }
628 };
629
630 static const struct clk_parent_data gcc_xo_gpll0_gpll4[] = {
631 { .fw_name = "xo" },
632 { .hw = &gpll0.clkr.hw },
633 { .hw = &gpll4.clkr.hw },
634 };
635
636 static const struct parent_map gcc_xo_gpll0_gpll4_map[] = {
637 { P_XO, 0 },
638 { P_GPLL0, 1 },
639 { P_GPLL4, 2 },
640 };
641
642 static struct clk_rcg2 pcie0_axi_clk_src = {
643 .cmd_rcgr = 0x75054,
644 .freq_tbl = ftbl_pcie_axi_clk_src,
645 .hid_width = 5,
646 .parent_map = gcc_xo_gpll0_gpll4_map,
647 .clkr.hw.init = &(struct clk_init_data){
648 .name = "pcie0_axi_clk_src",
649 .parent_data = gcc_xo_gpll0_gpll4,
650 .num_parents = 3,
651 .ops = &clk_rcg2_ops,
652 },
653 };
654
655 static const struct freq_tbl ftbl_usb0_master_clk_src[] = {
656 F(80000000, P_GPLL0_DIV2, 5, 0, 0),
657 F(100000000, P_GPLL0, 8, 0, 0),
658 F(133330000, P_GPLL0, 6, 0, 0),
659 F(200000000, P_GPLL0, 4, 0, 0),
660 { }
661 };
662
663 static const struct clk_parent_data gcc_xo_gpll0_out_main_div2_gpll0[] = {
664 { .fw_name = "xo" },
665 { .hw = &gpll0_out_main_div2.hw },
666 { .hw = &gpll0.clkr.hw },
667 };
668
669 static const struct parent_map gcc_xo_gpll0_out_main_div2_gpll0_map[] = {
670 { P_XO, 0 },
671 { P_GPLL0_DIV2, 2 },
672 { P_GPLL0, 1 },
673 };
674
675 static struct clk_rcg2 usb0_master_clk_src = {
676 .cmd_rcgr = 0x3e00c,
677 .freq_tbl = ftbl_usb0_master_clk_src,
678 .mnd_width = 8,
679 .hid_width = 5,
680 .parent_map = gcc_xo_gpll0_out_main_div2_gpll0_map,
681 .clkr.hw.init = &(struct clk_init_data){
682 .name = "usb0_master_clk_src",
683 .parent_data = gcc_xo_gpll0_out_main_div2_gpll0,
684 .num_parents = 3,
685 .ops = &clk_rcg2_ops,
686 },
687 };
688
689 static struct clk_regmap_div apss_ahb_postdiv_clk_src = {
690 .reg = 0x46018,
691 .shift = 4,
692 .width = 4,
693 .clkr = {
694 .hw.init = &(struct clk_init_data){
695 .name = "apss_ahb_postdiv_clk_src",
696 .parent_hws = (const struct clk_hw *[]){
697 &apss_ahb_clk_src.clkr.hw },
698 .num_parents = 1,
699 .ops = &clk_regmap_div_ops,
700 },
701 },
702 };
703
704 static struct clk_fixed_factor gcc_xo_div4_clk_src = {
705 .mult = 1,
706 .div = 4,
707 .hw.init = &(struct clk_init_data){
708 .name = "gcc_xo_div4_clk_src",
709 .parent_hws = (const struct clk_hw *[]){
710 &gcc_xo_clk_src.clkr.hw },
711 .num_parents = 1,
712 .ops = &clk_fixed_factor_ops,
713 .flags = CLK_SET_RATE_PARENT,
714 },
715 };
716
717 static const struct freq_tbl ftbl_nss_port1_rx_clk_src[] = {
718 F(24000000, P_XO, 1, 0, 0),
719 F(25000000, P_UNIPHY0_RX, 5, 0, 0),
720 F(125000000, P_UNIPHY0_RX, 1, 0, 0),
721 { }
722 };
723
724 static const struct clk_parent_data gcc_xo_uniphy0_rx_tx_ubi32_bias[] = {
725 { .fw_name = "xo" },
726 { .fw_name = "uniphy0_gcc_rx_clk" },
727 { .fw_name = "uniphy0_gcc_tx_clk" },
728 { .hw = &ubi32_pll.clkr.hw },
729 { .fw_name = "bias_pll_cc_clk" },
730 };
731
732 static const struct parent_map gcc_xo_uniphy0_rx_tx_ubi32_bias_map[] = {
733 { P_XO, 0 },
734 { P_UNIPHY0_RX, 1 },
735 { P_UNIPHY0_TX, 2 },
736 { P_UBI32_PLL, 5 },
737 { P_BIAS_PLL, 6 },
738 };
739
740 static struct clk_rcg2 nss_port1_rx_clk_src = {
741 .cmd_rcgr = 0x68020,
742 .freq_tbl = ftbl_nss_port1_rx_clk_src,
743 .hid_width = 5,
744 .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
745 .clkr.hw.init = &(struct clk_init_data){
746 .name = "nss_port1_rx_clk_src",
747 .parent_data = gcc_xo_uniphy0_rx_tx_ubi32_bias,
748 .num_parents = 5,
749 .ops = &clk_rcg2_ops,
750 },
751 };
752
753 static const struct freq_tbl ftbl_nss_port1_tx_clk_src[] = {
754 F(24000000, P_XO, 1, 0, 0),
755 F(25000000, P_UNIPHY0_TX, 5, 0, 0),
756 F(125000000, P_UNIPHY0_TX, 1, 0, 0),
757 { }
758 };
759
760 static const struct clk_parent_data gcc_xo_uniphy0_tx_rx_ubi32_bias[] = {
761 { .fw_name = "xo" },
762 { .fw_name = "uniphy0_gcc_tx_clk" },
763 { .fw_name = "uniphy0_gcc_rx_clk" },
764 { .hw = &ubi32_pll.clkr.hw },
765 { .fw_name = "bias_pll_cc_clk" },
766 };
767
768 static const struct parent_map gcc_xo_uniphy0_tx_rx_ubi32_bias_map[] = {
769 { P_XO, 0 },
770 { P_UNIPHY0_TX, 1 },
771 { P_UNIPHY0_RX, 2 },
772 { P_UBI32_PLL, 5 },
773 { P_BIAS_PLL, 6 },
774 };
775
776 static struct clk_rcg2 nss_port1_tx_clk_src = {
777 .cmd_rcgr = 0x68028,
778 .freq_tbl = ftbl_nss_port1_tx_clk_src,
779 .hid_width = 5,
780 .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
781 .clkr.hw.init = &(struct clk_init_data){
782 .name = "nss_port1_tx_clk_src",
783 .parent_data = gcc_xo_uniphy0_tx_rx_ubi32_bias,
784 .num_parents = 5,
785 .ops = &clk_rcg2_ops,
786 },
787 };
788
789 static struct clk_rcg2 nss_port2_rx_clk_src = {
790 .cmd_rcgr = 0x68030,
791 .freq_tbl = ftbl_nss_port1_rx_clk_src,
792 .hid_width = 5,
793 .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
794 .clkr.hw.init = &(struct clk_init_data){
795 .name = "nss_port2_rx_clk_src",
796 .parent_data = gcc_xo_uniphy0_rx_tx_ubi32_bias,
797 .num_parents = 5,
798 .ops = &clk_rcg2_ops,
799 },
800 };
801
802 static struct clk_rcg2 nss_port2_tx_clk_src = {
803 .cmd_rcgr = 0x68038,
804 .freq_tbl = ftbl_nss_port1_tx_clk_src,
805 .hid_width = 5,
806 .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
807 .clkr.hw.init = &(struct clk_init_data){
808 .name = "nss_port2_tx_clk_src",
809 .parent_data = gcc_xo_uniphy0_tx_rx_ubi32_bias,
810 .num_parents = 5,
811 .ops = &clk_rcg2_ops,
812 },
813 };
814
815 static struct clk_rcg2 nss_port3_rx_clk_src = {
816 .cmd_rcgr = 0x68040,
817 .freq_tbl = ftbl_nss_port1_rx_clk_src,
818 .hid_width = 5,
819 .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
820 .clkr.hw.init = &(struct clk_init_data){
821 .name = "nss_port3_rx_clk_src",
822 .parent_data = gcc_xo_uniphy0_rx_tx_ubi32_bias,
823 .num_parents = 5,
824 .ops = &clk_rcg2_ops,
825 },
826 };
827
828 static struct clk_rcg2 nss_port3_tx_clk_src = {
829 .cmd_rcgr = 0x68048,
830 .freq_tbl = ftbl_nss_port1_tx_clk_src,
831 .hid_width = 5,
832 .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
833 .clkr.hw.init = &(struct clk_init_data){
834 .name = "nss_port3_tx_clk_src",
835 .parent_data = gcc_xo_uniphy0_tx_rx_ubi32_bias,
836 .num_parents = 5,
837 .ops = &clk_rcg2_ops,
838 },
839 };
840
841 static struct clk_rcg2 nss_port4_rx_clk_src = {
842 .cmd_rcgr = 0x68050,
843 .freq_tbl = ftbl_nss_port1_rx_clk_src,
844 .hid_width = 5,
845 .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
846 .clkr.hw.init = &(struct clk_init_data){
847 .name = "nss_port4_rx_clk_src",
848 .parent_data = gcc_xo_uniphy0_rx_tx_ubi32_bias,
849 .num_parents = 5,
850 .ops = &clk_rcg2_ops,
851 },
852 };
853
854 static struct clk_rcg2 nss_port4_tx_clk_src = {
855 .cmd_rcgr = 0x68058,
856 .freq_tbl = ftbl_nss_port1_tx_clk_src,
857 .hid_width = 5,
858 .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
859 .clkr.hw.init = &(struct clk_init_data){
860 .name = "nss_port4_tx_clk_src",
861 .parent_data = gcc_xo_uniphy0_tx_rx_ubi32_bias,
862 .num_parents = 5,
863 .ops = &clk_rcg2_ops,
864 },
865 };
866
867 static struct clk_regmap_div nss_port5_rx_div_clk_src = {
868 .reg = 0x68440,
869 .shift = 0,
870 .width = 4,
871 .clkr = {
872 .hw.init = &(struct clk_init_data){
873 .name = "nss_port5_rx_div_clk_src",
874 .parent_hws = (const struct clk_hw *[]){
875 &nss_port5_rx_clk_src.clkr.hw },
876 .num_parents = 1,
877 .ops = &clk_regmap_div_ops,
878 .flags = CLK_SET_RATE_PARENT,
879 },
880 },
881 };
882
883 static struct clk_regmap_div nss_port5_tx_div_clk_src = {
884 .reg = 0x68444,
885 .shift = 0,
886 .width = 4,
887 .clkr = {
888 .hw.init = &(struct clk_init_data){
889 .name = "nss_port5_tx_div_clk_src",
890 .parent_hws = (const struct clk_hw *[]){
891 &nss_port5_tx_clk_src.clkr.hw },
892 .num_parents = 1,
893 .ops = &clk_regmap_div_ops,
894 .flags = CLK_SET_RATE_PARENT,
895 },
896 },
897 };
898
899 static const struct freq_tbl ftbl_apss_axi_clk_src[] = {
900 F(24000000, P_XO, 1, 0, 0),
901 F(100000000, P_GPLL0_DIV2, 4, 0, 0),
902 F(200000000, P_GPLL0, 4, 0, 0),
903 F(308570000, P_GPLL6, 3.5, 0, 0),
904 F(400000000, P_GPLL0, 2, 0, 0),
905 F(533000000, P_GPLL0, 1.5, 0, 0),
906 { }
907 };
908
909 static const struct clk_parent_data gcc_xo_gpll0_gpll6_ubi32_gpll0_div2[] = {
910 { .fw_name = "xo" },
911 { .hw = &gpll0.clkr.hw },
912 { .hw = &gpll6.clkr.hw },
913 { .hw = &ubi32_pll.clkr.hw },
914 { .hw = &gpll0_out_main_div2.hw },
915 };
916
917 static const struct parent_map
918 gcc_xo_gpll0_gpll6_ubi32_gpll0_div2_map[] = {
919 { P_XO, 0 },
920 { P_GPLL0, 1 },
921 { P_GPLL6, 2 },
922 { P_UBI32_PLL, 3 },
923 { P_GPLL0_DIV2, 6 },
924 };
925
926 static struct clk_rcg2 apss_axi_clk_src = {
927 .cmd_rcgr = 0x38048,
928 .freq_tbl = ftbl_apss_axi_clk_src,
929 .hid_width = 5,
930 .parent_map = gcc_xo_gpll0_gpll6_ubi32_gpll0_div2_map,
931 .clkr.hw.init = &(struct clk_init_data){
932 .name = "apss_axi_clk_src",
933 .parent_data = gcc_xo_gpll0_gpll6_ubi32_gpll0_div2,
934 .num_parents = 5,
935 .ops = &clk_rcg2_ops,
936 },
937 };
938
939 static const struct freq_tbl ftbl_nss_crypto_clk_src[] = {
940 F(24000000, P_XO, 1, 0, 0),
941 F(300000000, P_NSS_CRYPTO_PLL, 2, 0, 0),
942 { }
943 };
944
945 static const struct clk_parent_data gcc_xo_nss_crypto_pll_gpll0[] = {
946 { .fw_name = "xo" },
947 { .hw = &nss_crypto_pll.clkr.hw },
948 { .hw = &gpll0.clkr.hw },
949 };
950
951 static const struct parent_map gcc_xo_nss_crypto_pll_gpll0_map[] = {
952 { P_XO, 0 },
953 { P_NSS_CRYPTO_PLL, 1 },
954 { P_GPLL0, 2 },
955 };
956
957 static struct clk_rcg2 nss_crypto_clk_src = {
958 .cmd_rcgr = 0x68144,
959 .freq_tbl = ftbl_nss_crypto_clk_src,
960 .mnd_width = 16,
961 .hid_width = 5,
962 .parent_map = gcc_xo_nss_crypto_pll_gpll0_map,
963 .clkr.hw.init = &(struct clk_init_data){
964 .name = "nss_crypto_clk_src",
965 .parent_data = gcc_xo_nss_crypto_pll_gpll0,
966 .num_parents = 3,
967 .ops = &clk_rcg2_ops,
968 },
969 };
970
971 static struct clk_regmap_div nss_port1_rx_div_clk_src = {
972 .reg = 0x68400,
973 .shift = 0,
974 .width = 4,
975 .clkr = {
976 .hw.init = &(struct clk_init_data){
977 .name = "nss_port1_rx_div_clk_src",
978 .parent_hws = (const struct clk_hw *[]){
979 &nss_port1_rx_clk_src.clkr.hw },
980 .num_parents = 1,
981 .ops = &clk_regmap_div_ops,
982 .flags = CLK_SET_RATE_PARENT,
983 },
984 },
985 };
986
987 static struct clk_regmap_div nss_port1_tx_div_clk_src = {
988 .reg = 0x68404,
989 .shift = 0,
990 .width = 4,
991 .clkr = {
992 .hw.init = &(struct clk_init_data){
993 .name = "nss_port1_tx_div_clk_src",
994 .parent_hws = (const struct clk_hw *[]){
995 &nss_port1_tx_clk_src.clkr.hw },
996 .num_parents = 1,
997 .ops = &clk_regmap_div_ops,
998 .flags = CLK_SET_RATE_PARENT,
999 },
1000 },
1001 };
1002
1003 static struct clk_regmap_div nss_port2_rx_div_clk_src = {
1004 .reg = 0x68410,
1005 .shift = 0,
1006 .width = 4,
1007 .clkr = {
1008 .hw.init = &(struct clk_init_data){
1009 .name = "nss_port2_rx_div_clk_src",
1010 .parent_hws = (const struct clk_hw *[]){
1011 &nss_port2_rx_clk_src.clkr.hw },
1012 .num_parents = 1,
1013 .ops = &clk_regmap_div_ops,
1014 .flags = CLK_SET_RATE_PARENT,
1015 },
1016 },
1017 };
1018
1019 static struct clk_regmap_div nss_port2_tx_div_clk_src = {
1020 .reg = 0x68414,
1021 .shift = 0,
1022 .width = 4,
1023 .clkr = {
1024 .hw.init = &(struct clk_init_data){
1025 .name = "nss_port2_tx_div_clk_src",
1026 .parent_hws = (const struct clk_hw *[]){
1027 &nss_port2_tx_clk_src.clkr.hw },
1028 .num_parents = 1,
1029 .ops = &clk_regmap_div_ops,
1030 .flags = CLK_SET_RATE_PARENT,
1031 },
1032 },
1033 };
1034
1035 static struct clk_regmap_div nss_port3_rx_div_clk_src = {
1036 .reg = 0x68420,
1037 .shift = 0,
1038 .width = 4,
1039 .clkr = {
1040 .hw.init = &(struct clk_init_data){
1041 .name = "nss_port3_rx_div_clk_src",
1042 .parent_hws = (const struct clk_hw *[]){
1043 &nss_port3_rx_clk_src.clkr.hw },
1044 .num_parents = 1,
1045 .ops = &clk_regmap_div_ops,
1046 .flags = CLK_SET_RATE_PARENT,
1047 },
1048 },
1049 };
1050
1051 static struct clk_regmap_div nss_port3_tx_div_clk_src = {
1052 .reg = 0x68424,
1053 .shift = 0,
1054 .width = 4,
1055 .clkr = {
1056 .hw.init = &(struct clk_init_data){
1057 .name = "nss_port3_tx_div_clk_src",
1058 .parent_hws = (const struct clk_hw *[]){
1059 &nss_port3_tx_clk_src.clkr.hw },
1060 .num_parents = 1,
1061 .ops = &clk_regmap_div_ops,
1062 .flags = CLK_SET_RATE_PARENT,
1063 },
1064 },
1065 };
1066
1067 static struct clk_regmap_div nss_port4_rx_div_clk_src = {
1068 .reg = 0x68430,
1069 .shift = 0,
1070 .width = 4,
1071 .clkr = {
1072 .hw.init = &(struct clk_init_data){
1073 .name = "nss_port4_rx_div_clk_src",
1074 .parent_hws = (const struct clk_hw *[]){
1075 &nss_port4_rx_clk_src.clkr.hw },
1076 .num_parents = 1,
1077 .ops = &clk_regmap_div_ops,
1078 .flags = CLK_SET_RATE_PARENT,
1079 },
1080 },
1081 };
1082
1083 static struct clk_regmap_div nss_port4_tx_div_clk_src = {
1084 .reg = 0x68434,
1085 .shift = 0,
1086 .width = 4,
1087 .clkr = {
1088 .hw.init = &(struct clk_init_data){
1089 .name = "nss_port4_tx_div_clk_src",
1090 .parent_hws = (const struct clk_hw *[]){
1091 &nss_port4_tx_clk_src.clkr.hw },
1092 .num_parents = 1,
1093 .ops = &clk_regmap_div_ops,
1094 .flags = CLK_SET_RATE_PARENT,
1095 },
1096 },
1097 };
1098
1099 static const struct freq_tbl ftbl_nss_ubi_clk_src[] = {
1100 F(24000000, P_XO, 1, 0, 0),
1101 F(149760000, P_UBI32_PLL, 10, 0, 0),
1102 F(187200000, P_UBI32_PLL, 8, 0, 0),
1103 F(249600000, P_UBI32_PLL, 6, 0, 0),
1104 F(374400000, P_UBI32_PLL, 4, 0, 0),
1105 F(748800000, P_UBI32_PLL, 2, 0, 0),
1106 F(1497600000, P_UBI32_PLL, 1, 0, 0),
1107 { }
1108 };
1109
1110 static const struct clk_parent_data
1111 gcc_xo_ubi32_pll_gpll0_gpll2_gpll4_gpll6[] = {
1112 { .fw_name = "xo" },
1113 { .hw = &ubi32_pll.clkr.hw },
1114 { .hw = &gpll0.clkr.hw },
1115 { .hw = &gpll2.clkr.hw },
1116 { .hw = &gpll4.clkr.hw },
1117 { .hw = &gpll6.clkr.hw },
1118 };
1119
1120 static const struct parent_map gcc_xo_ubi32_gpll0_gpll2_gpll4_gpll6_map[] = {
1121 { P_XO, 0 },
1122 { P_UBI32_PLL, 1 },
1123 { P_GPLL0, 2 },
1124 { P_GPLL2, 3 },
1125 { P_GPLL4, 4 },
1126 { P_GPLL6, 5 },
1127 };
1128
1129 static struct clk_rcg2 nss_ubi0_clk_src = {
1130 .cmd_rcgr = 0x68104,
1131 .freq_tbl = ftbl_nss_ubi_clk_src,
1132 .hid_width = 5,
1133 .parent_map = gcc_xo_ubi32_gpll0_gpll2_gpll4_gpll6_map,
1134 .clkr.hw.init = &(struct clk_init_data){
1135 .name = "nss_ubi0_clk_src",
1136 .parent_data = gcc_xo_ubi32_pll_gpll0_gpll2_gpll4_gpll6,
1137 .num_parents = 6,
1138 .ops = &clk_rcg2_ops,
1139 .flags = CLK_SET_RATE_PARENT,
1140 },
1141 };
1142
1143 static const struct freq_tbl ftbl_adss_pwm_clk_src[] = {
1144 F(24000000, P_XO, 1, 0, 0),
1145 F(100000000, P_GPLL0, 8, 0, 0),
1146 { }
1147 };
1148
1149 static struct clk_rcg2 adss_pwm_clk_src = {
1150 .cmd_rcgr = 0x1c008,
1151 .freq_tbl = ftbl_adss_pwm_clk_src,
1152 .hid_width = 5,
1153 .parent_map = gcc_xo_gpll0_map,
1154 .clkr.hw.init = &(struct clk_init_data){
1155 .name = "adss_pwm_clk_src",
1156 .parent_data = gcc_xo_gpll0,
1157 .num_parents = 2,
1158 .ops = &clk_rcg2_ops,
1159 },
1160 };
1161
1162 static const struct freq_tbl ftbl_blsp1_qup_i2c_apps_clk_src[] = {
1163 F(24000000, P_XO, 1, 0, 0),
1164 F(25000000, P_GPLL0_DIV2, 16, 0, 0),
1165 F(50000000, P_GPLL0, 16, 0, 0),
1166 { }
1167 };
1168
1169 static struct clk_rcg2 blsp1_qup1_i2c_apps_clk_src = {
1170 .cmd_rcgr = 0x0200c,
1171 .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
1172 .hid_width = 5,
1173 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1174 .clkr.hw.init = &(struct clk_init_data){
1175 .name = "blsp1_qup1_i2c_apps_clk_src",
1176 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1177 .num_parents = 3,
1178 .ops = &clk_rcg2_ops,
1179 },
1180 };
1181
1182 static const struct freq_tbl ftbl_blsp1_qup_spi_apps_clk_src[] = {
1183 F(960000, P_XO, 10, 2, 5),
1184 F(4800000, P_XO, 5, 0, 0),
1185 F(9600000, P_XO, 2, 4, 5),
1186 F(12500000, P_GPLL0_DIV2, 16, 1, 2),
1187 F(16000000, P_GPLL0, 10, 1, 5),
1188 F(24000000, P_XO, 1, 0, 0),
1189 F(25000000, P_GPLL0, 16, 1, 2),
1190 F(50000000, P_GPLL0, 16, 0, 0),
1191 { }
1192 };
1193
1194 static struct clk_rcg2 blsp1_qup1_spi_apps_clk_src = {
1195 .cmd_rcgr = 0x02024,
1196 .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
1197 .mnd_width = 8,
1198 .hid_width = 5,
1199 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1200 .clkr.hw.init = &(struct clk_init_data){
1201 .name = "blsp1_qup1_spi_apps_clk_src",
1202 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1203 .num_parents = 3,
1204 .ops = &clk_rcg2_ops,
1205 },
1206 };
1207
1208 static struct clk_rcg2 blsp1_qup2_i2c_apps_clk_src = {
1209 .cmd_rcgr = 0x03000,
1210 .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
1211 .hid_width = 5,
1212 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1213 .clkr.hw.init = &(struct clk_init_data){
1214 .name = "blsp1_qup2_i2c_apps_clk_src",
1215 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1216 .num_parents = 3,
1217 .ops = &clk_rcg2_ops,
1218 },
1219 };
1220
1221 static struct clk_rcg2 blsp1_qup2_spi_apps_clk_src = {
1222 .cmd_rcgr = 0x03014,
1223 .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
1224 .mnd_width = 8,
1225 .hid_width = 5,
1226 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1227 .clkr.hw.init = &(struct clk_init_data){
1228 .name = "blsp1_qup2_spi_apps_clk_src",
1229 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1230 .num_parents = 3,
1231 .ops = &clk_rcg2_ops,
1232 },
1233 };
1234
1235 static struct clk_rcg2 blsp1_qup3_i2c_apps_clk_src = {
1236 .cmd_rcgr = 0x04000,
1237 .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
1238 .hid_width = 5,
1239 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1240 .clkr.hw.init = &(struct clk_init_data){
1241 .name = "blsp1_qup3_i2c_apps_clk_src",
1242 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1243 .num_parents = 3,
1244 .ops = &clk_rcg2_ops,
1245 },
1246 };
1247
1248 static struct clk_rcg2 blsp1_qup3_spi_apps_clk_src = {
1249 .cmd_rcgr = 0x04014,
1250 .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
1251 .mnd_width = 8,
1252 .hid_width = 5,
1253 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1254 .clkr.hw.init = &(struct clk_init_data){
1255 .name = "blsp1_qup3_spi_apps_clk_src",
1256 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1257 .num_parents = 3,
1258 .ops = &clk_rcg2_ops,
1259 },
1260 };
1261
1262 static struct clk_rcg2 blsp1_qup4_i2c_apps_clk_src = {
1263 .cmd_rcgr = 0x05000,
1264 .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
1265 .hid_width = 5,
1266 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1267 .clkr.hw.init = &(struct clk_init_data){
1268 .name = "blsp1_qup4_i2c_apps_clk_src",
1269 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1270 .num_parents = 3,
1271 .ops = &clk_rcg2_ops,
1272 },
1273 };
1274
1275 static struct clk_rcg2 blsp1_qup4_spi_apps_clk_src = {
1276 .cmd_rcgr = 0x05014,
1277 .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
1278 .mnd_width = 8,
1279 .hid_width = 5,
1280 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1281 .clkr.hw.init = &(struct clk_init_data){
1282 .name = "blsp1_qup4_spi_apps_clk_src",
1283 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1284 .num_parents = 3,
1285 .ops = &clk_rcg2_ops,
1286 },
1287 };
1288
1289 static struct clk_rcg2 blsp1_qup5_i2c_apps_clk_src = {
1290 .cmd_rcgr = 0x06000,
1291 .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
1292 .hid_width = 5,
1293 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1294 .clkr.hw.init = &(struct clk_init_data){
1295 .name = "blsp1_qup5_i2c_apps_clk_src",
1296 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1297 .num_parents = 3,
1298 .ops = &clk_rcg2_ops,
1299 },
1300 };
1301
1302 static struct clk_rcg2 blsp1_qup5_spi_apps_clk_src = {
1303 .cmd_rcgr = 0x06014,
1304 .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
1305 .mnd_width = 8,
1306 .hid_width = 5,
1307 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1308 .clkr.hw.init = &(struct clk_init_data){
1309 .name = "blsp1_qup5_spi_apps_clk_src",
1310 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1311 .num_parents = 3,
1312 .ops = &clk_rcg2_ops,
1313 },
1314 };
1315
1316 static struct clk_rcg2 blsp1_qup6_i2c_apps_clk_src = {
1317 .cmd_rcgr = 0x07000,
1318 .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
1319 .hid_width = 5,
1320 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1321 .clkr.hw.init = &(struct clk_init_data){
1322 .name = "blsp1_qup6_i2c_apps_clk_src",
1323 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1324 .num_parents = 3,
1325 .ops = &clk_rcg2_ops,
1326 },
1327 };
1328
1329 static struct clk_rcg2 blsp1_qup6_spi_apps_clk_src = {
1330 .cmd_rcgr = 0x07014,
1331 .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
1332 .mnd_width = 8,
1333 .hid_width = 5,
1334 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1335 .clkr.hw.init = &(struct clk_init_data){
1336 .name = "blsp1_qup6_spi_apps_clk_src",
1337 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1338 .num_parents = 3,
1339 .ops = &clk_rcg2_ops,
1340 },
1341 };
1342
1343 static const struct freq_tbl ftbl_blsp1_uart_apps_clk_src[] = {
1344 F(3686400, P_GPLL0_DIV2, 1, 144, 15625),
1345 F(7372800, P_GPLL0_DIV2, 1, 288, 15625),
1346 F(14745600, P_GPLL0_DIV2, 1, 576, 15625),
1347 F(16000000, P_GPLL0_DIV2, 5, 1, 5),
1348 F(24000000, P_XO, 1, 0, 0),
1349 F(24000000, P_GPLL0, 1, 3, 100),
1350 F(25000000, P_GPLL0, 16, 1, 2),
1351 F(32000000, P_GPLL0, 1, 1, 25),
1352 F(40000000, P_GPLL0, 1, 1, 20),
1353 F(46400000, P_GPLL0, 1, 29, 500),
1354 F(48000000, P_GPLL0, 1, 3, 50),
1355 F(51200000, P_GPLL0, 1, 8, 125),
1356 F(56000000, P_GPLL0, 1, 7, 100),
1357 F(58982400, P_GPLL0, 1, 1152, 15625),
1358 F(60000000, P_GPLL0, 1, 3, 40),
1359 F(64000000, P_GPLL0, 12.5, 1, 1),
1360 { }
1361 };
1362
1363 static struct clk_rcg2 blsp1_uart1_apps_clk_src = {
1364 .cmd_rcgr = 0x02044,
1365 .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
1366 .mnd_width = 16,
1367 .hid_width = 5,
1368 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1369 .clkr.hw.init = &(struct clk_init_data){
1370 .name = "blsp1_uart1_apps_clk_src",
1371 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1372 .num_parents = 3,
1373 .ops = &clk_rcg2_ops,
1374 },
1375 };
1376
1377 static struct clk_rcg2 blsp1_uart2_apps_clk_src = {
1378 .cmd_rcgr = 0x03034,
1379 .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
1380 .mnd_width = 16,
1381 .hid_width = 5,
1382 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1383 .clkr.hw.init = &(struct clk_init_data){
1384 .name = "blsp1_uart2_apps_clk_src",
1385 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1386 .num_parents = 3,
1387 .ops = &clk_rcg2_ops,
1388 },
1389 };
1390
1391 static struct clk_rcg2 blsp1_uart3_apps_clk_src = {
1392 .cmd_rcgr = 0x04034,
1393 .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
1394 .mnd_width = 16,
1395 .hid_width = 5,
1396 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1397 .clkr.hw.init = &(struct clk_init_data){
1398 .name = "blsp1_uart3_apps_clk_src",
1399 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1400 .num_parents = 3,
1401 .ops = &clk_rcg2_ops,
1402 },
1403 };
1404
1405 static struct clk_rcg2 blsp1_uart4_apps_clk_src = {
1406 .cmd_rcgr = 0x05034,
1407 .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
1408 .mnd_width = 16,
1409 .hid_width = 5,
1410 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1411 .clkr.hw.init = &(struct clk_init_data){
1412 .name = "blsp1_uart4_apps_clk_src",
1413 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1414 .num_parents = 3,
1415 .ops = &clk_rcg2_ops,
1416 },
1417 };
1418
1419 static struct clk_rcg2 blsp1_uart5_apps_clk_src = {
1420 .cmd_rcgr = 0x06034,
1421 .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
1422 .mnd_width = 16,
1423 .hid_width = 5,
1424 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1425 .clkr.hw.init = &(struct clk_init_data){
1426 .name = "blsp1_uart5_apps_clk_src",
1427 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1428 .num_parents = 3,
1429 .ops = &clk_rcg2_ops,
1430 },
1431 };
1432
1433 static struct clk_rcg2 blsp1_uart6_apps_clk_src = {
1434 .cmd_rcgr = 0x07034,
1435 .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
1436 .mnd_width = 16,
1437 .hid_width = 5,
1438 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1439 .clkr.hw.init = &(struct clk_init_data){
1440 .name = "blsp1_uart6_apps_clk_src",
1441 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1442 .num_parents = 3,
1443 .ops = &clk_rcg2_ops,
1444 },
1445 };
1446
1447 static const struct freq_tbl ftbl_crypto_clk_src[] = {
1448 F(40000000, P_GPLL0_DIV2, 10, 0, 0),
1449 F(80000000, P_GPLL0, 10, 0, 0),
1450 F(100000000, P_GPLL0, 8, 0, 0),
1451 F(160000000, P_GPLL0, 5, 0, 0),
1452 { }
1453 };
1454
1455 static struct clk_rcg2 crypto_clk_src = {
1456 .cmd_rcgr = 0x16004,
1457 .freq_tbl = ftbl_crypto_clk_src,
1458 .hid_width = 5,
1459 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1460 .clkr.hw.init = &(struct clk_init_data){
1461 .name = "crypto_clk_src",
1462 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1463 .num_parents = 3,
1464 .ops = &clk_rcg2_ops,
1465 },
1466 };
1467
1468 static const struct freq_tbl ftbl_gp_clk_src[] = {
1469 F(24000000, P_XO, 1, 0, 0),
1470 F(50000000, P_GPLL0_DIV2, 8, 0, 0),
1471 F(100000000, P_GPLL0, 8, 0, 0),
1472 F(200000000, P_GPLL0, 4, 0, 0),
1473 F(266666666, P_GPLL0, 3, 0, 0),
1474 { }
1475 };
1476
1477 static const struct clk_parent_data gcc_xo_gpll0_gpll6_gpll0_sleep_clk[] = {
1478 { .fw_name = "xo" },
1479 { .hw = &gpll0.clkr.hw },
1480 { .hw = &gpll6.clkr.hw },
1481 { .hw = &gpll0_out_main_div2.hw },
1482 { .fw_name = "sleep_clk" },
1483 };
1484
1485 static const struct parent_map gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map[] = {
1486 { P_XO, 0 },
1487 { P_GPLL0, 1 },
1488 { P_GPLL6, 2 },
1489 { P_GPLL0_DIV2, 4 },
1490 { P_SLEEP_CLK, 6 },
1491 };
1492
1493 static struct clk_rcg2 gp1_clk_src = {
1494 .cmd_rcgr = 0x08004,
1495 .freq_tbl = ftbl_gp_clk_src,
1496 .mnd_width = 8,
1497 .hid_width = 5,
1498 .parent_map = gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map,
1499 .clkr.hw.init = &(struct clk_init_data){
1500 .name = "gp1_clk_src",
1501 .parent_data = gcc_xo_gpll0_gpll6_gpll0_sleep_clk,
1502 .num_parents = 5,
1503 .ops = &clk_rcg2_ops,
1504 },
1505 };
1506
1507 static struct clk_rcg2 gp2_clk_src = {
1508 .cmd_rcgr = 0x09004,
1509 .freq_tbl = ftbl_gp_clk_src,
1510 .mnd_width = 8,
1511 .hid_width = 5,
1512 .parent_map = gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map,
1513 .clkr.hw.init = &(struct clk_init_data){
1514 .name = "gp2_clk_src",
1515 .parent_data = gcc_xo_gpll0_gpll6_gpll0_sleep_clk,
1516 .num_parents = 5,
1517 .ops = &clk_rcg2_ops,
1518 },
1519 };
1520
1521 static struct clk_rcg2 gp3_clk_src = {
1522 .cmd_rcgr = 0x0a004,
1523 .freq_tbl = ftbl_gp_clk_src,
1524 .mnd_width = 8,
1525 .hid_width = 5,
1526 .parent_map = gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map,
1527 .clkr.hw.init = &(struct clk_init_data){
1528 .name = "gp3_clk_src",
1529 .parent_data = gcc_xo_gpll0_gpll6_gpll0_sleep_clk,
1530 .num_parents = 5,
1531 .ops = &clk_rcg2_ops,
1532 },
1533 };
1534
1535 static struct clk_fixed_factor nss_ppe_cdiv_clk_src = {
1536 .mult = 1,
1537 .div = 4,
1538 .hw.init = &(struct clk_init_data){
1539 .name = "nss_ppe_cdiv_clk_src",
1540 .parent_hws = (const struct clk_hw *[]){
1541 &nss_ppe_clk_src.clkr.hw },
1542 .num_parents = 1,
1543 .ops = &clk_fixed_factor_ops,
1544 .flags = CLK_SET_RATE_PARENT,
1545 },
1546 };
1547
1548 static struct clk_regmap_div nss_ubi0_div_clk_src = {
1549 .reg = 0x68118,
1550 .shift = 0,
1551 .width = 4,
1552 .clkr = {
1553 .hw.init = &(struct clk_init_data){
1554 .name = "nss_ubi0_div_clk_src",
1555 .parent_hws = (const struct clk_hw *[]){
1556 &nss_ubi0_clk_src.clkr.hw },
1557 .num_parents = 1,
1558 .ops = &clk_regmap_div_ro_ops,
1559 .flags = CLK_SET_RATE_PARENT,
1560 },
1561 },
1562 };
1563
1564 static const struct freq_tbl ftbl_pcie_aux_clk_src[] = {
1565 F(24000000, P_XO, 1, 0, 0),
1566 };
1567
1568 static const struct clk_parent_data gcc_xo_gpll0_core_pi_sleep_clk[] = {
1569 { .fw_name = "xo" },
1570 { .hw = &gpll0.clkr.hw },
1571 { .fw_name = "sleep_clk" },
1572 };
1573
1574 static const struct parent_map gcc_xo_gpll0_core_pi_sleep_clk_map[] = {
1575 { P_XO, 0 },
1576 { P_GPLL0, 2 },
1577 { P_PI_SLEEP, 6 },
1578 };
1579
1580 static struct clk_rcg2 pcie0_aux_clk_src = {
1581 .cmd_rcgr = 0x75024,
1582 .freq_tbl = ftbl_pcie_aux_clk_src,
1583 .mnd_width = 16,
1584 .hid_width = 5,
1585 .parent_map = gcc_xo_gpll0_core_pi_sleep_clk_map,
1586 .clkr.hw.init = &(struct clk_init_data){
1587 .name = "pcie0_aux_clk_src",
1588 .parent_data = gcc_xo_gpll0_core_pi_sleep_clk,
1589 .num_parents = 3,
1590 .ops = &clk_rcg2_ops,
1591 },
1592 };
1593
1594 static const struct clk_parent_data gcc_pcie20_phy0_pipe_clk_xo[] = {
1595 { .fw_name = "pcie20_phy0_pipe_clk" },
1596 { .fw_name = "xo" },
1597 };
1598
1599 static const struct parent_map gcc_pcie20_phy0_pipe_clk_xo_map[] = {
1600 { P_PCIE20_PHY0_PIPE, 0 },
1601 { P_XO, 2 },
1602 };
1603
1604 static struct clk_regmap_mux pcie0_pipe_clk_src = {
1605 .reg = 0x7501c,
1606 .shift = 8,
1607 .width = 2,
1608 .parent_map = gcc_pcie20_phy0_pipe_clk_xo_map,
1609 .clkr = {
1610 .hw.init = &(struct clk_init_data){
1611 .name = "pcie0_pipe_clk_src",
1612 .parent_data = gcc_pcie20_phy0_pipe_clk_xo,
1613 .num_parents = 2,
1614 .ops = &clk_regmap_mux_closest_ops,
1615 .flags = CLK_SET_RATE_PARENT,
1616 },
1617 },
1618 };
1619
1620 static const struct freq_tbl ftbl_sdcc_apps_clk_src[] = {
1621 F(144000, P_XO, 16, 12, 125),
1622 F(400000, P_XO, 12, 1, 5),
1623 F(24000000, P_GPLL2, 12, 1, 4),
1624 F(48000000, P_GPLL2, 12, 1, 2),
1625 F(96000000, P_GPLL2, 12, 0, 0),
1626 F(177777778, P_GPLL0, 4.5, 0, 0),
1627 F(192000000, P_GPLL2, 6, 0, 0),
1628 F(384000000, P_GPLL2, 3, 0, 0),
1629 { }
1630 };
1631
1632 static const struct clk_parent_data
1633 gcc_xo_gpll0_gpll2_gpll0_out_main_div2[] = {
1634 { .fw_name = "xo" },
1635 { .hw = &gpll0.clkr.hw },
1636 { .hw = &gpll2.clkr.hw },
1637 { .hw = &gpll0_out_main_div2.hw },
1638 };
1639
1640 static const struct parent_map gcc_xo_gpll0_gpll2_gpll0_out_main_div2_map[] = {
1641 { P_XO, 0 },
1642 { P_GPLL0, 1 },
1643 { P_GPLL2, 2 },
1644 { P_GPLL0_DIV2, 4 },
1645 };
1646
1647 static struct clk_rcg2 sdcc1_apps_clk_src = {
1648 .cmd_rcgr = 0x42004,
1649 .freq_tbl = ftbl_sdcc_apps_clk_src,
1650 .mnd_width = 8,
1651 .hid_width = 5,
1652 .parent_map = gcc_xo_gpll0_gpll2_gpll0_out_main_div2_map,
1653 .clkr.hw.init = &(struct clk_init_data){
1654 .name = "sdcc1_apps_clk_src",
1655 .parent_data = gcc_xo_gpll0_gpll2_gpll0_out_main_div2,
1656 .num_parents = 4,
1657 .ops = &clk_rcg2_ops,
1658 },
1659 };
1660
1661 static const struct freq_tbl ftbl_usb_aux_clk_src[] = {
1662 F(24000000, P_XO, 1, 0, 0),
1663 { }
1664 };
1665
1666 static struct clk_rcg2 usb0_aux_clk_src = {
1667 .cmd_rcgr = 0x3e05c,
1668 .freq_tbl = ftbl_usb_aux_clk_src,
1669 .mnd_width = 16,
1670 .hid_width = 5,
1671 .parent_map = gcc_xo_gpll0_core_pi_sleep_clk_map,
1672 .clkr.hw.init = &(struct clk_init_data){
1673 .name = "usb0_aux_clk_src",
1674 .parent_data = gcc_xo_gpll0_core_pi_sleep_clk,
1675 .num_parents = 3,
1676 .ops = &clk_rcg2_ops,
1677 },
1678 };
1679
1680 static const struct freq_tbl ftbl_usb_mock_utmi_clk_src[] = {
1681 F(24000000, P_XO, 1, 0, 0),
1682 F(60000000, P_GPLL6, 6, 1, 3),
1683 { }
1684 };
1685
1686 static const struct clk_parent_data
1687 gcc_xo_gpll6_gpll0_gpll0_out_main_div2[] = {
1688 { .fw_name = "xo" },
1689 { .hw = &gpll6.clkr.hw },
1690 { .hw = &gpll0.clkr.hw },
1691 { .hw = &gpll0_out_main_div2.hw },
1692 };
1693
1694 static const struct parent_map gcc_xo_gpll6_gpll0_gpll0_out_main_div2_map[] = {
1695 { P_XO, 0 },
1696 { P_GPLL6, 1 },
1697 { P_GPLL0, 3 },
1698 { P_GPLL0_DIV2, 4 },
1699 };
1700
1701 static struct clk_rcg2 usb0_mock_utmi_clk_src = {
1702 .cmd_rcgr = 0x3e020,
1703 .freq_tbl = ftbl_usb_mock_utmi_clk_src,
1704 .mnd_width = 8,
1705 .hid_width = 5,
1706 .parent_map = gcc_xo_gpll6_gpll0_gpll0_out_main_div2_map,
1707 .clkr.hw.init = &(struct clk_init_data){
1708 .name = "usb0_mock_utmi_clk_src",
1709 .parent_data = gcc_xo_gpll6_gpll0_gpll0_out_main_div2,
1710 .num_parents = 4,
1711 .ops = &clk_rcg2_ops,
1712 },
1713 };
1714
1715 static const struct clk_parent_data gcc_usb3phy_0_cc_pipe_clk_xo[] = {
1716 { .fw_name = "usb3phy_0_cc_pipe_clk" },
1717 { .fw_name = "xo" },
1718 };
1719
1720 static const struct parent_map gcc_usb3phy_0_cc_pipe_clk_xo_map[] = {
1721 { P_USB3PHY_0_PIPE, 0 },
1722 { P_XO, 2 },
1723 };
1724
1725 static struct clk_regmap_mux usb0_pipe_clk_src = {
1726 .reg = 0x3e048,
1727 .shift = 8,
1728 .width = 2,
1729 .parent_map = gcc_usb3phy_0_cc_pipe_clk_xo_map,
1730 .clkr = {
1731 .hw.init = &(struct clk_init_data){
1732 .name = "usb0_pipe_clk_src",
1733 .parent_data = gcc_usb3phy_0_cc_pipe_clk_xo,
1734 .num_parents = 2,
1735 .ops = &clk_regmap_mux_closest_ops,
1736 .flags = CLK_SET_RATE_PARENT,
1737 },
1738 },
1739 };
1740
1741 static const struct freq_tbl ftbl_sdcc_ice_core_clk_src[] = {
1742 F(80000000, P_GPLL0_DIV2, 5, 0, 0),
1743 F(160000000, P_GPLL0, 5, 0, 0),
1744 F(216000000, P_GPLL6, 5, 0, 0),
1745 F(308570000, P_GPLL6, 3.5, 0, 0),
1746 };
1747
1748 static const struct clk_parent_data gcc_xo_gpll0_gpll6_gpll0_div2[] = {
1749 { .fw_name = "xo"},
1750 { .hw = &gpll0.clkr.hw },
1751 { .hw = &gpll6.clkr.hw },
1752 { .hw = &gpll0_out_main_div2.hw },
1753 };
1754
1755 static const struct parent_map gcc_xo_gpll0_gpll6_gpll0_div2_map[] = {
1756 { P_XO, 0 },
1757 { P_GPLL0, 1 },
1758 { P_GPLL6, 2 },
1759 { P_GPLL0_DIV2, 4 },
1760 };
1761
1762 static struct clk_rcg2 sdcc1_ice_core_clk_src = {
1763 .cmd_rcgr = 0x5d000,
1764 .freq_tbl = ftbl_sdcc_ice_core_clk_src,
1765 .mnd_width = 8,
1766 .hid_width = 5,
1767 .parent_map = gcc_xo_gpll0_gpll6_gpll0_div2_map,
1768 .clkr.hw.init = &(struct clk_init_data){
1769 .name = "sdcc1_ice_core_clk_src",
1770 .parent_data = gcc_xo_gpll0_gpll6_gpll0_div2,
1771 .num_parents = 4,
1772 .ops = &clk_rcg2_ops,
1773 },
1774 };
1775
1776 static const struct freq_tbl ftbl_qdss_stm_clk_src[] = {
1777 F(24000000, P_XO, 1, 0, 0),
1778 F(50000000, P_GPLL0_DIV2, 8, 0, 0),
1779 F(100000000, P_GPLL0, 8, 0, 0),
1780 F(200000000, P_GPLL0, 4, 0, 0),
1781 { }
1782 };
1783
1784 static struct clk_rcg2 qdss_stm_clk_src = {
1785 .cmd_rcgr = 0x2902C,
1786 .freq_tbl = ftbl_qdss_stm_clk_src,
1787 .hid_width = 5,
1788 .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1789 .clkr.hw.init = &(struct clk_init_data){
1790 .name = "qdss_stm_clk_src",
1791 .parent_data = gcc_xo_gpll0_gpll0_out_main_div2,
1792 .num_parents = 3,
1793 .ops = &clk_rcg2_ops,
1794 },
1795 };
1796
1797 static const struct freq_tbl ftbl_qdss_traceclkin_clk_src[] = {
1798 F(80000000, P_GPLL0_DIV2, 5, 0, 0),
1799 F(160000000, P_GPLL0, 5, 0, 0),
1800 F(300000000, P_GPLL4, 4, 0, 0),
1801 { }
1802 };
1803
1804 static const struct clk_parent_data gcc_xo_gpll4_gpll0_gpll0_div2[] = {
1805 { .fw_name = "xo" },
1806 { .hw = &gpll4.clkr.hw },
1807 { .hw = &gpll0.clkr.hw },
1808 { .hw = &gpll0_out_main_div2.hw },
1809 };
1810
1811 static const struct parent_map gcc_xo_gpll4_gpll0_gpll0_div2_map[] = {
1812 { P_XO, 0 },
1813 { P_GPLL4, 1 },
1814 { P_GPLL0, 2 },
1815 { P_GPLL0_DIV2, 4 },
1816 };
1817
1818 static struct clk_rcg2 qdss_traceclkin_clk_src = {
1819 .cmd_rcgr = 0x29048,
1820 .freq_tbl = ftbl_qdss_traceclkin_clk_src,
1821 .hid_width = 5,
1822 .parent_map = gcc_xo_gpll4_gpll0_gpll0_div2_map,
1823 .clkr.hw.init = &(struct clk_init_data){
1824 .name = "qdss_traceclkin_clk_src",
1825 .parent_data = gcc_xo_gpll4_gpll0_gpll0_div2,
1826 .num_parents = 4,
1827 .ops = &clk_rcg2_ops,
1828 },
1829 };
1830
1831 static struct clk_rcg2 usb1_mock_utmi_clk_src = {
1832 .cmd_rcgr = 0x3f020,
1833 .freq_tbl = ftbl_usb_mock_utmi_clk_src,
1834 .mnd_width = 8,
1835 .hid_width = 5,
1836 .parent_map = gcc_xo_gpll6_gpll0_gpll0_out_main_div2_map,
1837 .clkr.hw.init = &(struct clk_init_data){
1838 .name = "usb1_mock_utmi_clk_src",
1839 .parent_data = gcc_xo_gpll6_gpll0_gpll0_out_main_div2,
1840 .num_parents = 4,
1841 .ops = &clk_rcg2_ops,
1842 },
1843 };
1844
1845 static struct clk_branch gcc_adss_pwm_clk = {
1846 .halt_reg = 0x1c020,
1847 .clkr = {
1848 .enable_reg = 0x1c020,
1849 .enable_mask = BIT(0),
1850 .hw.init = &(struct clk_init_data){
1851 .name = "gcc_adss_pwm_clk",
1852 .parent_hws = (const struct clk_hw *[]){
1853 &adss_pwm_clk_src.clkr.hw },
1854 .num_parents = 1,
1855 .flags = CLK_SET_RATE_PARENT,
1856 .ops = &clk_branch2_ops,
1857 },
1858 },
1859 };
1860
1861 static struct clk_branch gcc_apss_ahb_clk = {
1862 .halt_reg = 0x4601c,
1863 .halt_check = BRANCH_HALT_VOTED,
1864 .clkr = {
1865 .enable_reg = 0x0b004,
1866 .enable_mask = BIT(14),
1867 .hw.init = &(struct clk_init_data){
1868 .name = "gcc_apss_ahb_clk",
1869 .parent_hws = (const struct clk_hw *[]){
1870 &apss_ahb_postdiv_clk_src.clkr.hw },
1871 .num_parents = 1,
1872 .flags = CLK_SET_RATE_PARENT,
1873 .ops = &clk_branch2_ops,
1874 },
1875 },
1876 };
1877
1878 static const struct freq_tbl ftbl_system_noc_bfdcd_clk_src[] = {
1879 F(24000000, P_XO, 1, 0, 0),
1880 F(50000000, P_GPLL0_DIV2, 8, 0, 0),
1881 F(100000000, P_GPLL0, 8, 0, 0),
1882 F(133333333, P_GPLL0, 6, 0, 0),
1883 F(160000000, P_GPLL0, 5, 0, 0),
1884 F(200000000, P_GPLL0, 4, 0, 0),
1885 F(266666667, P_GPLL0, 3, 0, 0),
1886 { }
1887 };
1888
1889 static struct clk_rcg2 system_noc_bfdcd_clk_src = {
1890 .cmd_rcgr = 0x26004,
1891 .freq_tbl = ftbl_system_noc_bfdcd_clk_src,
1892 .hid_width = 5,
1893 .parent_map = gcc_xo_gpll0_gpll6_gpll0_out_main_div2_map,
1894 .clkr.hw.init = &(struct clk_init_data){
1895 .name = "system_noc_bfdcd_clk_src",
1896 .parent_data = gcc_xo_gpll0_gpll6_gpll0_out_main_div2,
1897 .num_parents = 4,
1898 .ops = &clk_rcg2_ops,
1899 },
1900 };
1901
1902 static const struct freq_tbl ftbl_ubi32_mem_noc_bfdcd_clk_src[] = {
1903 F(24000000, P_XO, 1, 0, 0),
1904 F(307670000, P_BIAS_PLL_NSS_NOC, 1.5, 0, 0),
1905 F(533333333, P_GPLL0, 1.5, 0, 0),
1906 { }
1907 };
1908
1909 static const struct clk_parent_data
1910 gcc_xo_gpll0_gpll2_bias_pll_nss_noc_clk[] = {
1911 { .fw_name = "xo" },
1912 { .hw = &gpll0.clkr.hw },
1913 { .hw = &gpll2.clkr.hw },
1914 { .fw_name = "bias_pll_nss_noc_clk" },
1915 };
1916
1917 static const struct parent_map gcc_xo_gpll0_gpll2_bias_pll_nss_noc_clk_map[] = {
1918 { P_XO, 0 },
1919 { P_GPLL0, 1 },
1920 { P_GPLL2, 3 },
1921 { P_BIAS_PLL_NSS_NOC, 4 },
1922 };
1923
1924 static struct clk_rcg2 ubi32_mem_noc_bfdcd_clk_src = {
1925 .cmd_rcgr = 0x68088,
1926 .freq_tbl = ftbl_ubi32_mem_noc_bfdcd_clk_src,
1927 .hid_width = 5,
1928 .parent_map = gcc_xo_gpll0_gpll2_bias_pll_nss_noc_clk_map,
1929 .clkr.hw.init = &(struct clk_init_data){
1930 .name = "ubi32_mem_noc_bfdcd_clk_src",
1931 .parent_data = gcc_xo_gpll0_gpll2_bias_pll_nss_noc_clk,
1932 .num_parents = 4,
1933 .ops = &clk_rcg2_ops,
1934 },
1935 };
1936
1937 static struct clk_branch gcc_apss_axi_clk = {
1938 .halt_reg = 0x46020,
1939 .halt_check = BRANCH_HALT_VOTED,
1940 .clkr = {
1941 .enable_reg = 0x0b004,
1942 .enable_mask = BIT(13),
1943 .hw.init = &(struct clk_init_data){
1944 .name = "gcc_apss_axi_clk",
1945 .parent_hws = (const struct clk_hw *[]){
1946 &apss_axi_clk_src.clkr.hw },
1947 .num_parents = 1,
1948 .flags = CLK_SET_RATE_PARENT,
1949 .ops = &clk_branch2_ops,
1950 },
1951 },
1952 };
1953
1954 static struct clk_branch gcc_blsp1_ahb_clk = {
1955 .halt_reg = 0x01008,
1956 .halt_check = BRANCH_HALT_VOTED,
1957 .clkr = {
1958 .enable_reg = 0x0b004,
1959 .enable_mask = BIT(10),
1960 .hw.init = &(struct clk_init_data){
1961 .name = "gcc_blsp1_ahb_clk",
1962 .parent_hws = (const struct clk_hw *[]){
1963 &pcnoc_bfdcd_clk_src.clkr.hw },
1964 .num_parents = 1,
1965 .flags = CLK_SET_RATE_PARENT,
1966 .ops = &clk_branch2_ops,
1967 },
1968 },
1969 };
1970
1971 static struct clk_branch gcc_blsp1_qup1_i2c_apps_clk = {
1972 .halt_reg = 0x02008,
1973 .clkr = {
1974 .enable_reg = 0x02008,
1975 .enable_mask = BIT(0),
1976 .hw.init = &(struct clk_init_data){
1977 .name = "gcc_blsp1_qup1_i2c_apps_clk",
1978 .parent_hws = (const struct clk_hw *[]){
1979 &blsp1_qup1_i2c_apps_clk_src.clkr.hw },
1980 .num_parents = 1,
1981 .flags = CLK_SET_RATE_PARENT,
1982 .ops = &clk_branch2_ops,
1983 },
1984 },
1985 };
1986
1987 static struct clk_branch gcc_blsp1_qup1_spi_apps_clk = {
1988 .halt_reg = 0x02004,
1989 .clkr = {
1990 .enable_reg = 0x02004,
1991 .enable_mask = BIT(0),
1992 .hw.init = &(struct clk_init_data){
1993 .name = "gcc_blsp1_qup1_spi_apps_clk",
1994 .parent_hws = (const struct clk_hw *[]){
1995 &blsp1_qup1_spi_apps_clk_src.clkr.hw },
1996 .num_parents = 1,
1997 .flags = CLK_SET_RATE_PARENT,
1998 .ops = &clk_branch2_ops,
1999 },
2000 },
2001 };
2002
2003 static struct clk_branch gcc_blsp1_qup2_i2c_apps_clk = {
2004 .halt_reg = 0x03010,
2005 .clkr = {
2006 .enable_reg = 0x03010,
2007 .enable_mask = BIT(0),
2008 .hw.init = &(struct clk_init_data){
2009 .name = "gcc_blsp1_qup2_i2c_apps_clk",
2010 .parent_hws = (const struct clk_hw *[]){
2011 &blsp1_qup2_i2c_apps_clk_src.clkr.hw },
2012 .num_parents = 1,
2013 .flags = CLK_SET_RATE_PARENT,
2014 .ops = &clk_branch2_ops,
2015 },
2016 },
2017 };
2018
2019 static struct clk_branch gcc_blsp1_qup2_spi_apps_clk = {
2020 .halt_reg = 0x0300c,
2021 .clkr = {
2022 .enable_reg = 0x0300c,
2023 .enable_mask = BIT(0),
2024 .hw.init = &(struct clk_init_data){
2025 .name = "gcc_blsp1_qup2_spi_apps_clk",
2026 .parent_hws = (const struct clk_hw *[]){
2027 &blsp1_qup2_spi_apps_clk_src.clkr.hw },
2028 .num_parents = 1,
2029 .flags = CLK_SET_RATE_PARENT,
2030 .ops = &clk_branch2_ops,
2031 },
2032 },
2033 };
2034
2035 static struct clk_branch gcc_blsp1_qup3_i2c_apps_clk = {
2036 .halt_reg = 0x04010,
2037 .clkr = {
2038 .enable_reg = 0x04010,
2039 .enable_mask = BIT(0),
2040 .hw.init = &(struct clk_init_data){
2041 .name = "gcc_blsp1_qup3_i2c_apps_clk",
2042 .parent_hws = (const struct clk_hw *[]){
2043 &blsp1_qup3_i2c_apps_clk_src.clkr.hw },
2044 .num_parents = 1,
2045 .flags = CLK_SET_RATE_PARENT,
2046 .ops = &clk_branch2_ops,
2047 },
2048 },
2049 };
2050
2051 static struct clk_branch gcc_blsp1_qup3_spi_apps_clk = {
2052 .halt_reg = 0x0400c,
2053 .clkr = {
2054 .enable_reg = 0x0400c,
2055 .enable_mask = BIT(0),
2056 .hw.init = &(struct clk_init_data){
2057 .name = "gcc_blsp1_qup3_spi_apps_clk",
2058 .parent_hws = (const struct clk_hw *[]){
2059 &blsp1_qup3_spi_apps_clk_src.clkr.hw },
2060 .num_parents = 1,
2061 .flags = CLK_SET_RATE_PARENT,
2062 .ops = &clk_branch2_ops,
2063 },
2064 },
2065 };
2066
2067 static struct clk_branch gcc_blsp1_qup4_i2c_apps_clk = {
2068 .halt_reg = 0x05010,
2069 .clkr = {
2070 .enable_reg = 0x05010,
2071 .enable_mask = BIT(0),
2072 .hw.init = &(struct clk_init_data){
2073 .name = "gcc_blsp1_qup4_i2c_apps_clk",
2074 .parent_hws = (const struct clk_hw *[]){
2075 &blsp1_qup4_i2c_apps_clk_src.clkr.hw },
2076 .num_parents = 1,
2077 .flags = CLK_SET_RATE_PARENT,
2078 .ops = &clk_branch2_ops,
2079 },
2080 },
2081 };
2082
2083 static struct clk_branch gcc_blsp1_qup4_spi_apps_clk = {
2084 .halt_reg = 0x0500c,
2085 .clkr = {
2086 .enable_reg = 0x0500c,
2087 .enable_mask = BIT(0),
2088 .hw.init = &(struct clk_init_data){
2089 .name = "gcc_blsp1_qup4_spi_apps_clk",
2090 .parent_hws = (const struct clk_hw *[]){
2091 &blsp1_qup4_spi_apps_clk_src.clkr.hw },
2092 .num_parents = 1,
2093 .flags = CLK_SET_RATE_PARENT,
2094 .ops = &clk_branch2_ops,
2095 },
2096 },
2097 };
2098
2099 static struct clk_branch gcc_blsp1_qup5_i2c_apps_clk = {
2100 .halt_reg = 0x06010,
2101 .clkr = {
2102 .enable_reg = 0x06010,
2103 .enable_mask = BIT(0),
2104 .hw.init = &(struct clk_init_data){
2105 .name = "gcc_blsp1_qup5_i2c_apps_clk",
2106 .parent_hws = (const struct clk_hw *[]){
2107 &blsp1_qup5_i2c_apps_clk_src.clkr.hw },
2108 .num_parents = 1,
2109 .flags = CLK_SET_RATE_PARENT,
2110 .ops = &clk_branch2_ops,
2111 },
2112 },
2113 };
2114
2115 static struct clk_branch gcc_blsp1_qup5_spi_apps_clk = {
2116 .halt_reg = 0x0600c,
2117 .clkr = {
2118 .enable_reg = 0x0600c,
2119 .enable_mask = BIT(0),
2120 .hw.init = &(struct clk_init_data){
2121 .name = "gcc_blsp1_qup5_spi_apps_clk",
2122 .parent_hws = (const struct clk_hw *[]){
2123 &blsp1_qup5_spi_apps_clk_src.clkr.hw },
2124 .num_parents = 1,
2125 .flags = CLK_SET_RATE_PARENT,
2126 .ops = &clk_branch2_ops,
2127 },
2128 },
2129 };
2130
2131 static struct clk_branch gcc_blsp1_qup6_spi_apps_clk = {
2132 .halt_reg = 0x0700c,
2133 .clkr = {
2134 .enable_reg = 0x0700c,
2135 .enable_mask = BIT(0),
2136 .hw.init = &(struct clk_init_data){
2137 .name = "gcc_blsp1_qup6_spi_apps_clk",
2138 .parent_hws = (const struct clk_hw *[]){
2139 &blsp1_qup6_spi_apps_clk_src.clkr.hw },
2140 .num_parents = 1,
2141 .flags = CLK_SET_RATE_PARENT,
2142 .ops = &clk_branch2_ops,
2143 },
2144 },
2145 };
2146
2147 static struct clk_branch gcc_blsp1_uart1_apps_clk = {
2148 .halt_reg = 0x0203c,
2149 .clkr = {
2150 .enable_reg = 0x0203c,
2151 .enable_mask = BIT(0),
2152 .hw.init = &(struct clk_init_data){
2153 .name = "gcc_blsp1_uart1_apps_clk",
2154 .parent_hws = (const struct clk_hw *[]){
2155 &blsp1_uart1_apps_clk_src.clkr.hw },
2156 .num_parents = 1,
2157 .flags = CLK_SET_RATE_PARENT,
2158 .ops = &clk_branch2_ops,
2159 },
2160 },
2161 };
2162
2163 static struct clk_branch gcc_blsp1_uart2_apps_clk = {
2164 .halt_reg = 0x0302c,
2165 .clkr = {
2166 .enable_reg = 0x0302c,
2167 .enable_mask = BIT(0),
2168 .hw.init = &(struct clk_init_data){
2169 .name = "gcc_blsp1_uart2_apps_clk",
2170 .parent_hws = (const struct clk_hw *[]){
2171 &blsp1_uart2_apps_clk_src.clkr.hw },
2172 .num_parents = 1,
2173 .flags = CLK_SET_RATE_PARENT,
2174 .ops = &clk_branch2_ops,
2175 },
2176 },
2177 };
2178
2179 static struct clk_branch gcc_blsp1_uart3_apps_clk = {
2180 .halt_reg = 0x0402c,
2181 .clkr = {
2182 .enable_reg = 0x0402c,
2183 .enable_mask = BIT(0),
2184 .hw.init = &(struct clk_init_data){
2185 .name = "gcc_blsp1_uart3_apps_clk",
2186 .parent_hws = (const struct clk_hw *[]){
2187 &blsp1_uart3_apps_clk_src.clkr.hw },
2188 .num_parents = 1,
2189 .flags = CLK_SET_RATE_PARENT,
2190 .ops = &clk_branch2_ops,
2191 },
2192 },
2193 };
2194
2195 static struct clk_branch gcc_blsp1_uart4_apps_clk = {
2196 .halt_reg = 0x0502c,
2197 .clkr = {
2198 .enable_reg = 0x0502c,
2199 .enable_mask = BIT(0),
2200 .hw.init = &(struct clk_init_data){
2201 .name = "gcc_blsp1_uart4_apps_clk",
2202 .parent_hws = (const struct clk_hw *[]){
2203 &blsp1_uart4_apps_clk_src.clkr.hw },
2204 .num_parents = 1,
2205 .flags = CLK_SET_RATE_PARENT,
2206 .ops = &clk_branch2_ops,
2207 },
2208 },
2209 };
2210
2211 static struct clk_branch gcc_blsp1_uart5_apps_clk = {
2212 .halt_reg = 0x0602c,
2213 .clkr = {
2214 .enable_reg = 0x0602c,
2215 .enable_mask = BIT(0),
2216 .hw.init = &(struct clk_init_data){
2217 .name = "gcc_blsp1_uart5_apps_clk",
2218 .parent_hws = (const struct clk_hw *[]){
2219 &blsp1_uart5_apps_clk_src.clkr.hw },
2220 .num_parents = 1,
2221 .flags = CLK_SET_RATE_PARENT,
2222 .ops = &clk_branch2_ops,
2223 },
2224 },
2225 };
2226
2227 static struct clk_branch gcc_blsp1_uart6_apps_clk = {
2228 .halt_reg = 0x0702c,
2229 .clkr = {
2230 .enable_reg = 0x0702c,
2231 .enable_mask = BIT(0),
2232 .hw.init = &(struct clk_init_data){
2233 .name = "gcc_blsp1_uart6_apps_clk",
2234 .parent_hws = (const struct clk_hw *[]){
2235 &blsp1_uart6_apps_clk_src.clkr.hw },
2236 .num_parents = 1,
2237 .flags = CLK_SET_RATE_PARENT,
2238 .ops = &clk_branch2_ops,
2239 },
2240 },
2241 };
2242
2243 static struct clk_branch gcc_crypto_ahb_clk = {
2244 .halt_reg = 0x16024,
2245 .halt_check = BRANCH_HALT_VOTED,
2246 .clkr = {
2247 .enable_reg = 0x0b004,
2248 .enable_mask = BIT(0),
2249 .hw.init = &(struct clk_init_data){
2250 .name = "gcc_crypto_ahb_clk",
2251 .parent_hws = (const struct clk_hw *[]){
2252 &pcnoc_bfdcd_clk_src.clkr.hw },
2253 .num_parents = 1,
2254 .flags = CLK_SET_RATE_PARENT,
2255 .ops = &clk_branch2_ops,
2256 },
2257 },
2258 };
2259
2260 static struct clk_branch gcc_crypto_axi_clk = {
2261 .halt_reg = 0x16020,
2262 .halt_check = BRANCH_HALT_VOTED,
2263 .clkr = {
2264 .enable_reg = 0x0b004,
2265 .enable_mask = BIT(1),
2266 .hw.init = &(struct clk_init_data){
2267 .name = "gcc_crypto_axi_clk",
2268 .parent_hws = (const struct clk_hw *[]){
2269 &pcnoc_bfdcd_clk_src.clkr.hw },
2270 .num_parents = 1,
2271 .flags = CLK_SET_RATE_PARENT,
2272 .ops = &clk_branch2_ops,
2273 },
2274 },
2275 };
2276
2277 static struct clk_branch gcc_crypto_clk = {
2278 .halt_reg = 0x1601c,
2279 .halt_check = BRANCH_HALT_VOTED,
2280 .clkr = {
2281 .enable_reg = 0x0b004,
2282 .enable_mask = BIT(2),
2283 .hw.init = &(struct clk_init_data){
2284 .name = "gcc_crypto_clk",
2285 .parent_hws = (const struct clk_hw *[]){
2286 &crypto_clk_src.clkr.hw },
2287 .num_parents = 1,
2288 .flags = CLK_SET_RATE_PARENT,
2289 .ops = &clk_branch2_ops,
2290 },
2291 },
2292 };
2293
2294 static struct clk_fixed_factor gpll6_out_main_div2 = {
2295 .mult = 1,
2296 .div = 2,
2297 .hw.init = &(struct clk_init_data){
2298 .name = "gpll6_out_main_div2",
2299 .parent_hws = (const struct clk_hw *[]){
2300 &gpll6_main.clkr.hw },
2301 .num_parents = 1,
2302 .ops = &clk_fixed_factor_ops,
2303 .flags = CLK_SET_RATE_PARENT,
2304 },
2305 };
2306
2307 static struct clk_branch gcc_xo_clk = {
2308 .halt_reg = 0x30030,
2309 .clkr = {
2310 .enable_reg = 0x30030,
2311 .enable_mask = BIT(0),
2312 .hw.init = &(struct clk_init_data){
2313 .name = "gcc_xo_clk",
2314 .parent_hws = (const struct clk_hw *[]){
2315 &gcc_xo_clk_src.clkr.hw },
2316 .num_parents = 1,
2317 .flags = CLK_SET_RATE_PARENT,
2318 .ops = &clk_branch2_ops,
2319 },
2320 },
2321 };
2322
2323 static struct clk_branch gcc_gp1_clk = {
2324 .halt_reg = 0x08000,
2325 .clkr = {
2326 .enable_reg = 0x08000,
2327 .enable_mask = BIT(0),
2328 .hw.init = &(struct clk_init_data){
2329 .name = "gcc_gp1_clk",
2330 .parent_hws = (const struct clk_hw *[]){
2331 &gp1_clk_src.clkr.hw },
2332 .num_parents = 1,
2333 .flags = CLK_SET_RATE_PARENT,
2334 .ops = &clk_branch2_ops,
2335 },
2336 },
2337 };
2338
2339 static struct clk_branch gcc_gp2_clk = {
2340 .halt_reg = 0x09000,
2341 .clkr = {
2342 .enable_reg = 0x09000,
2343 .enable_mask = BIT(0),
2344 .hw.init = &(struct clk_init_data){
2345 .name = "gcc_gp2_clk",
2346 .parent_hws = (const struct clk_hw *[]){
2347 &gp2_clk_src.clkr.hw },
2348 .num_parents = 1,
2349 .flags = CLK_SET_RATE_PARENT,
2350 .ops = &clk_branch2_ops,
2351 },
2352 },
2353 };
2354
2355 static struct clk_branch gcc_gp3_clk = {
2356 .halt_reg = 0x0a000,
2357 .clkr = {
2358 .enable_reg = 0x0a000,
2359 .enable_mask = BIT(0),
2360 .hw.init = &(struct clk_init_data){
2361 .name = "gcc_gp3_clk",
2362 .parent_hws = (const struct clk_hw *[]){
2363 &gp3_clk_src.clkr.hw },
2364 .num_parents = 1,
2365 .flags = CLK_SET_RATE_PARENT,
2366 .ops = &clk_branch2_ops,
2367 },
2368 },
2369 };
2370
2371 static struct clk_branch gcc_mdio_ahb_clk = {
2372 .halt_reg = 0x58004,
2373 .clkr = {
2374 .enable_reg = 0x58004,
2375 .enable_mask = BIT(0),
2376 .hw.init = &(struct clk_init_data){
2377 .name = "gcc_mdio_ahb_clk",
2378 .parent_hws = (const struct clk_hw *[]){
2379 &pcnoc_bfdcd_clk_src.clkr.hw },
2380 .num_parents = 1,
2381 .flags = CLK_SET_RATE_PARENT,
2382 .ops = &clk_branch2_ops,
2383 },
2384 },
2385 };
2386
2387 static struct clk_branch gcc_crypto_ppe_clk = {
2388 .halt_reg = 0x68310,
2389 .clkr = {
2390 .enable_reg = 0x68310,
2391 .enable_mask = BIT(0),
2392 .hw.init = &(struct clk_init_data){
2393 .name = "gcc_crypto_ppe_clk",
2394 .parent_hws = (const struct clk_hw *[]){
2395 &nss_ppe_clk_src.clkr.hw },
2396 .num_parents = 1,
2397 .flags = CLK_SET_RATE_PARENT,
2398 .ops = &clk_branch2_ops,
2399 },
2400 },
2401 };
2402
2403 static struct clk_branch gcc_nss_ce_apb_clk = {
2404 .halt_reg = 0x68174,
2405 .clkr = {
2406 .enable_reg = 0x68174,
2407 .enable_mask = BIT(0),
2408 .hw.init = &(struct clk_init_data){
2409 .name = "gcc_nss_ce_apb_clk",
2410 .parent_hws = (const struct clk_hw *[]){
2411 &nss_ce_clk_src.clkr.hw },
2412 .num_parents = 1,
2413 .flags = CLK_SET_RATE_PARENT,
2414 .ops = &clk_branch2_ops,
2415 },
2416 },
2417 };
2418
2419 static struct clk_branch gcc_nss_ce_axi_clk = {
2420 .halt_reg = 0x68170,
2421 .clkr = {
2422 .enable_reg = 0x68170,
2423 .enable_mask = BIT(0),
2424 .hw.init = &(struct clk_init_data){
2425 .name = "gcc_nss_ce_axi_clk",
2426 .parent_hws = (const struct clk_hw *[]){
2427 &nss_ce_clk_src.clkr.hw },
2428 .num_parents = 1,
2429 .flags = CLK_SET_RATE_PARENT,
2430 .ops = &clk_branch2_ops,
2431 },
2432 },
2433 };
2434
2435 static struct clk_branch gcc_nss_cfg_clk = {
2436 .halt_reg = 0x68160,
2437 .clkr = {
2438 .enable_reg = 0x68160,
2439 .enable_mask = BIT(0),
2440 .hw.init = &(struct clk_init_data){
2441 .name = "gcc_nss_cfg_clk",
2442 .parent_hws = (const struct clk_hw *[]){
2443 &pcnoc_bfdcd_clk_src.clkr.hw },
2444 .num_parents = 1,
2445 .flags = CLK_SET_RATE_PARENT,
2446 .ops = &clk_branch2_ops,
2447 },
2448 },
2449 };
2450
2451 static struct clk_branch gcc_nss_crypto_clk = {
2452 .halt_reg = 0x68164,
2453 .clkr = {
2454 .enable_reg = 0x68164,
2455 .enable_mask = BIT(0),
2456 .hw.init = &(struct clk_init_data){
2457 .name = "gcc_nss_crypto_clk",
2458 .parent_hws = (const struct clk_hw *[]){
2459 &nss_crypto_clk_src.clkr.hw },
2460 .num_parents = 1,
2461 .flags = CLK_SET_RATE_PARENT,
2462 .ops = &clk_branch2_ops,
2463 },
2464 },
2465 };
2466
2467 static struct clk_branch gcc_nss_csr_clk = {
2468 .halt_reg = 0x68318,
2469 .clkr = {
2470 .enable_reg = 0x68318,
2471 .enable_mask = BIT(0),
2472 .hw.init = &(struct clk_init_data){
2473 .name = "gcc_nss_csr_clk",
2474 .parent_hws = (const struct clk_hw *[]){
2475 &nss_ce_clk_src.clkr.hw },
2476 .num_parents = 1,
2477 .flags = CLK_SET_RATE_PARENT,
2478 .ops = &clk_branch2_ops,
2479 },
2480 },
2481 };
2482
2483 static struct clk_branch gcc_nss_edma_cfg_clk = {
2484 .halt_reg = 0x6819C,
2485 .clkr = {
2486 .enable_reg = 0x6819C,
2487 .enable_mask = BIT(0),
2488 .hw.init = &(struct clk_init_data){
2489 .name = "gcc_nss_edma_cfg_clk",
2490 .parent_hws = (const struct clk_hw *[]){
2491 &nss_ppe_clk_src.clkr.hw },
2492 .num_parents = 1,
2493 .flags = CLK_SET_RATE_PARENT,
2494 .ops = &clk_branch2_ops,
2495 },
2496 },
2497 };
2498
2499 static struct clk_branch gcc_nss_edma_clk = {
2500 .halt_reg = 0x68198,
2501 .clkr = {
2502 .enable_reg = 0x68198,
2503 .enable_mask = BIT(0),
2504 .hw.init = &(struct clk_init_data){
2505 .name = "gcc_nss_edma_clk",
2506 .parent_hws = (const struct clk_hw *[]){
2507 &nss_ppe_clk_src.clkr.hw },
2508 .num_parents = 1,
2509 .flags = CLK_SET_RATE_PARENT,
2510 .ops = &clk_branch2_ops,
2511 },
2512 },
2513 };
2514
2515 static struct clk_branch gcc_nss_noc_clk = {
2516 .halt_reg = 0x68168,
2517 .clkr = {
2518 .enable_reg = 0x68168,
2519 .enable_mask = BIT(0),
2520 .hw.init = &(struct clk_init_data){
2521 .name = "gcc_nss_noc_clk",
2522 .parent_hws = (const struct clk_hw *[]){
2523 &snoc_nssnoc_bfdcd_clk_src.clkr.hw },
2524 .num_parents = 1,
2525 .flags = CLK_SET_RATE_PARENT,
2526 .ops = &clk_branch2_ops,
2527 },
2528 },
2529 };
2530
2531 static struct clk_branch gcc_ubi0_utcm_clk = {
2532 .halt_reg = 0x2606c,
2533 .clkr = {
2534 .enable_reg = 0x2606c,
2535 .enable_mask = BIT(0),
2536 .hw.init = &(struct clk_init_data){
2537 .name = "gcc_ubi0_utcm_clk",
2538 .parent_hws = (const struct clk_hw *[]){
2539 &snoc_nssnoc_bfdcd_clk_src.clkr.hw },
2540 .num_parents = 1,
2541 .flags = CLK_SET_RATE_PARENT,
2542 .ops = &clk_branch2_ops,
2543 },
2544 },
2545 };
2546
2547 static struct clk_branch gcc_snoc_nssnoc_clk = {
2548 .halt_reg = 0x26070,
2549 .clkr = {
2550 .enable_reg = 0x26070,
2551 .enable_mask = BIT(0),
2552 .hw.init = &(struct clk_init_data){
2553 .name = "gcc_snoc_nssnoc_clk",
2554 .parent_hws = (const struct clk_hw *[]){
2555 &snoc_nssnoc_bfdcd_clk_src.clkr.hw },
2556 .num_parents = 1,
2557 .flags = CLK_SET_RATE_PARENT,
2558 .ops = &clk_branch2_ops,
2559 },
2560 },
2561 };
2562
2563 static const struct freq_tbl ftbl_wcss_ahb_clk_src[] = {
2564 F(24000000, P_XO, 1, 0, 0),
2565 F(133333333, P_GPLL0, 6, 0, 0),
2566 { }
2567 };
2568
2569 static const struct freq_tbl ftbl_q6_axi_clk_src[] = {
2570 F(24000000, P_XO, 1, 0, 0),
2571 F(400000000, P_GPLL0, 2, 0, 0),
2572 { }
2573 };
2574
2575 static struct clk_rcg2 wcss_ahb_clk_src = {
2576 .cmd_rcgr = 0x59020,
2577 .freq_tbl = ftbl_wcss_ahb_clk_src,
2578 .hid_width = 5,
2579 .parent_map = gcc_xo_gpll0_map,
2580 .clkr.hw.init = &(struct clk_init_data){
2581 .name = "wcss_ahb_clk_src",
2582 .parent_data = gcc_xo_gpll0,
2583 .num_parents = 2,
2584 .ops = &clk_rcg2_ops,
2585 },
2586 };
2587
2588 static const struct clk_parent_data gcc_xo_gpll0_gpll2_gpll4_gpll6[] = {
2589 { .fw_name = "xo" },
2590 { .hw = &gpll0.clkr.hw },
2591 { .hw = &gpll2.clkr.hw },
2592 { .hw = &gpll4.clkr.hw },
2593 { .hw = &gpll6.clkr.hw },
2594 };
2595
2596 static const struct parent_map gcc_xo_gpll0_gpll2_gpll4_gpll6_map[] = {
2597 { P_XO, 0 },
2598 { P_GPLL0, 1 },
2599 { P_GPLL2, 2 },
2600 { P_GPLL4, 3 },
2601 { P_GPLL6, 4 },
2602 };
2603
2604 static struct clk_rcg2 q6_axi_clk_src = {
2605 .cmd_rcgr = 0x59120,
2606 .freq_tbl = ftbl_q6_axi_clk_src,
2607 .hid_width = 5,
2608 .parent_map = gcc_xo_gpll0_gpll2_gpll4_gpll6_map,
2609 .clkr.hw.init = &(struct clk_init_data){
2610 .name = "q6_axi_clk_src",
2611 .parent_data = gcc_xo_gpll0_gpll2_gpll4_gpll6,
2612 .num_parents = 5,
2613 .ops = &clk_rcg2_ops,
2614 },
2615 };
2616
2617 static const struct freq_tbl ftbl_lpass_core_axim_clk_src[] = {
2618 F(24000000, P_XO, 1, 0, 0),
2619 F(100000000, P_GPLL0, 8, 0, 0),
2620 { }
2621 };
2622
2623 static struct clk_rcg2 lpass_core_axim_clk_src = {
2624 .cmd_rcgr = 0x1F020,
2625 .freq_tbl = ftbl_lpass_core_axim_clk_src,
2626 .hid_width = 5,
2627 .parent_map = gcc_xo_gpll0_map,
2628 .clkr.hw.init = &(struct clk_init_data){
2629 .name = "lpass_core_axim_clk_src",
2630 .parent_data = gcc_xo_gpll0,
2631 .num_parents = 2,
2632 .ops = &clk_rcg2_ops,
2633 },
2634 };
2635
2636 static const struct freq_tbl ftbl_lpass_snoc_cfg_clk_src[] = {
2637 F(24000000, P_XO, 1, 0, 0),
2638 F(266666667, P_GPLL0, 3, 0, 0),
2639 { }
2640 };
2641
2642 static struct clk_rcg2 lpass_snoc_cfg_clk_src = {
2643 .cmd_rcgr = 0x1F040,
2644 .freq_tbl = ftbl_lpass_snoc_cfg_clk_src,
2645 .hid_width = 5,
2646 .parent_map = gcc_xo_gpll0_map,
2647 .clkr.hw.init = &(struct clk_init_data){
2648 .name = "lpass_snoc_cfg_clk_src",
2649 .parent_data = gcc_xo_gpll0,
2650 .num_parents = 2,
2651 .ops = &clk_rcg2_ops,
2652 },
2653 };
2654
2655 static const struct freq_tbl ftbl_lpass_q6_axim_clk_src[] = {
2656 F(24000000, P_XO, 1, 0, 0),
2657 F(400000000, P_GPLL0, 2, 0, 0),
2658 { }
2659 };
2660
2661 static struct clk_rcg2 lpass_q6_axim_clk_src = {
2662 .cmd_rcgr = 0x1F008,
2663 .freq_tbl = ftbl_lpass_q6_axim_clk_src,
2664 .hid_width = 5,
2665 .parent_map = gcc_xo_gpll0_map,
2666 .clkr.hw.init = &(struct clk_init_data){
2667 .name = "lpass_q6_axim_clk_src",
2668 .parent_data = gcc_xo_gpll0,
2669 .num_parents = 2,
2670 .ops = &clk_rcg2_ops,
2671 },
2672 };
2673
2674 static struct freq_tbl ftbl_rbcpr_wcss_clk_src[] = {
2675 F(24000000, P_XO, 1, 0, 0),
2676 F(50000000, P_GPLL0, 16, 0, 0),
2677 { }
2678 };
2679
2680 static struct clk_rcg2 rbcpr_wcss_clk_src = {
2681 .cmd_rcgr = 0x3a00c,
2682 .freq_tbl = ftbl_rbcpr_wcss_clk_src,
2683 .hid_width = 5,
2684 .parent_map = gcc_xo_gpll0_out_main_div2_gpll0_map,
2685 .clkr.hw.init = &(struct clk_init_data){
2686 .name = "rbcpr_wcss_clk_src",
2687 .parent_data = gcc_xo_gpll0_out_main_div2_gpll0,
2688 .num_parents = 3,
2689 .ops = &clk_rcg2_ops,
2690 },
2691 };
2692
2693 static struct clk_branch gcc_lpass_core_axim_clk = {
2694 .halt_reg = 0x1F028,
2695 .clkr = {
2696 .enable_reg = 0x1F028,
2697 .enable_mask = BIT(0),
2698 .hw.init = &(struct clk_init_data){
2699 .name = "gcc_lpass_core_axim_clk",
2700 .parent_hws = (const struct clk_hw *[]){
2701 &lpass_core_axim_clk_src.clkr.hw },
2702 .num_parents = 1,
2703 .flags = CLK_SET_RATE_PARENT,
2704 .ops = &clk_branch2_ops,
2705 },
2706 },
2707 };
2708
2709 static struct clk_branch gcc_lpass_snoc_cfg_clk = {
2710 .halt_reg = 0x1F048,
2711 .clkr = {
2712 .enable_reg = 0x1F048,
2713 .enable_mask = BIT(0),
2714 .hw.init = &(struct clk_init_data){
2715 .name = "gcc_lpass_snoc_cfg_clk",
2716 .parent_hws = (const struct clk_hw *[]){
2717 &lpass_snoc_cfg_clk_src.clkr.hw },
2718 .num_parents = 1,
2719 .flags = CLK_SET_RATE_PARENT,
2720 .ops = &clk_branch2_ops,
2721 },
2722 },
2723 };
2724
2725 static struct clk_branch gcc_lpass_q6_axim_clk = {
2726 .halt_reg = 0x1F010,
2727 .clkr = {
2728 .enable_reg = 0x1F010,
2729 .enable_mask = BIT(0),
2730 .hw.init = &(struct clk_init_data){
2731 .name = "gcc_lpass_q6_axim_clk",
2732 .parent_hws = (const struct clk_hw *[]){
2733 &lpass_q6_axim_clk_src.clkr.hw },
2734 .num_parents = 1,
2735 .flags = CLK_SET_RATE_PARENT,
2736 .ops = &clk_branch2_ops,
2737 },
2738 },
2739 };
2740
2741 static struct clk_branch gcc_lpass_q6_atbm_at_clk = {
2742 .halt_reg = 0x1F018,
2743 .clkr = {
2744 .enable_reg = 0x1F018,
2745 .enable_mask = BIT(0),
2746 .hw.init = &(struct clk_init_data){
2747 .name = "gcc_lpass_q6_atbm_at_clk",
2748 .parent_hws = (const struct clk_hw *[]){
2749 &qdss_at_clk_src.clkr.hw },
2750 .num_parents = 1,
2751 .flags = CLK_SET_RATE_PARENT,
2752 .ops = &clk_branch2_ops,
2753 },
2754 },
2755 };
2756
2757 static struct clk_branch gcc_lpass_q6_pclkdbg_clk = {
2758 .halt_reg = 0x1F01C,
2759 .clkr = {
2760 .enable_reg = 0x1F01C,
2761 .enable_mask = BIT(0),
2762 .hw.init = &(struct clk_init_data){
2763 .name = "gcc_lpass_q6_pclkdbg_clk",
2764 .parent_hws = (const struct clk_hw *[]){
2765 &qdss_dap_sync_clk_src.hw },
2766 .num_parents = 1,
2767 .flags = CLK_SET_RATE_PARENT,
2768 .ops = &clk_branch2_ops,
2769 },
2770 },
2771 };
2772
2773 static struct clk_branch gcc_lpass_q6ss_tsctr_1to2_clk = {
2774 .halt_reg = 0x1F014,
2775 .clkr = {
2776 .enable_reg = 0x1F014,
2777 .enable_mask = BIT(0),
2778 .hw.init = &(struct clk_init_data){
2779 .name = "gcc_lpass_q6ss_tsctr_1to2_clk",
2780 .parent_hws = (const struct clk_hw *[]){
2781 &qdss_tsctr_div2_clk_src.hw },
2782 .num_parents = 1,
2783 .flags = CLK_SET_RATE_PARENT,
2784 .ops = &clk_branch2_ops,
2785 },
2786 },
2787 };
2788
2789 static struct clk_branch gcc_lpass_q6ss_trig_clk = {
2790 .halt_reg = 0x1F038,
2791 .clkr = {
2792 .enable_reg = 0x1F038,
2793 .enable_mask = BIT(0),
2794 .hw.init = &(struct clk_init_data){
2795 .name = "gcc_lpass_q6ss_trig_clk",
2796 .parent_hws = (const struct clk_hw *[]){
2797 &qdss_dap_sync_clk_src.hw },
2798 .num_parents = 1,
2799 .flags = CLK_SET_RATE_PARENT,
2800 .ops = &clk_branch2_ops,
2801 },
2802 },
2803 };
2804
2805 static struct clk_branch gcc_lpass_tbu_clk = {
2806 .halt_reg = 0x12094,
2807 .clkr = {
2808 .enable_reg = 0xb00c,
2809 .enable_mask = BIT(10),
2810 .hw.init = &(struct clk_init_data){
2811 .name = "gcc_lpass_tbu_clk",
2812 .parent_hws = (const struct clk_hw *[]){
2813 &lpass_q6_axim_clk_src.clkr.hw },
2814 .num_parents = 1,
2815 .flags = CLK_SET_RATE_PARENT,
2816 .ops = &clk_branch2_ops,
2817 },
2818 },
2819 };
2820
2821 static struct clk_branch gcc_pcnoc_lpass_clk = {
2822 .halt_reg = 0x27020,
2823 .clkr = {
2824 .enable_reg = 0x27020,
2825 .enable_mask = BIT(0),
2826 .hw.init = &(struct clk_init_data){
2827 .name = "gcc_pcnoc_lpass_clk",
2828 .parent_hws = (const struct clk_hw *[]){
2829 &lpass_core_axim_clk_src.clkr.hw },
2830 .num_parents = 1,
2831 .flags = CLK_SET_RATE_PARENT,
2832 .ops = &clk_branch2_ops,
2833 },
2834 },
2835 };
2836
2837 static struct clk_branch gcc_mem_noc_lpass_clk = {
2838 .halt_reg = 0x1D044,
2839 .clkr = {
2840 .enable_reg = 0x1D044,
2841 .enable_mask = BIT(0),
2842 .hw.init = &(struct clk_init_data){
2843 .name = "gcc_mem_noc_lpass_clk",
2844 .parent_hws = (const struct clk_hw *[]){
2845 &lpass_q6_axim_clk_src.clkr.hw },
2846 .num_parents = 1,
2847 .flags = CLK_SET_RATE_PARENT,
2848 .ops = &clk_branch2_ops,
2849 },
2850 },
2851 };
2852
2853 static struct clk_branch gcc_snoc_lpass_cfg_clk = {
2854 .halt_reg = 0x26074,
2855 .clkr = {
2856 .enable_reg = 0x26074,
2857 .enable_mask = BIT(0),
2858 .hw.init = &(struct clk_init_data){
2859 .name = "gcc_snoc_lpass_cfg_clk",
2860 .parent_hws = (const struct clk_hw *[]){
2861 &lpass_snoc_cfg_clk_src.clkr.hw },
2862 .num_parents = 1,
2863 .flags = CLK_SET_RATE_PARENT,
2864 .ops = &clk_branch2_ops,
2865 },
2866 },
2867 };
2868
2869 static struct clk_branch gcc_mem_noc_ubi32_clk = {
2870 .halt_reg = 0x1D03C,
2871 .clkr = {
2872 .enable_reg = 0x1D03C,
2873 .enable_mask = BIT(0),
2874 .hw.init = &(struct clk_init_data){
2875 .name = "gcc_mem_noc_ubi32_clk",
2876 .parent_hws = (const struct clk_hw *[]){
2877 &ubi32_mem_noc_bfdcd_clk_src.clkr.hw },
2878 .num_parents = 1,
2879 .flags = CLK_SET_RATE_PARENT,
2880 .ops = &clk_branch2_ops,
2881 },
2882 },
2883 };
2884
2885 static struct clk_branch gcc_nss_port1_rx_clk = {
2886 .halt_reg = 0x68240,
2887 .clkr = {
2888 .enable_reg = 0x68240,
2889 .enable_mask = BIT(0),
2890 .hw.init = &(struct clk_init_data){
2891 .name = "gcc_nss_port1_rx_clk",
2892 .parent_hws = (const struct clk_hw *[]){
2893 &nss_port1_rx_div_clk_src.clkr.hw },
2894 .num_parents = 1,
2895 .flags = CLK_SET_RATE_PARENT,
2896 .ops = &clk_branch2_ops,
2897 },
2898 },
2899 };
2900
2901 static struct clk_branch gcc_nss_port1_tx_clk = {
2902 .halt_reg = 0x68244,
2903 .clkr = {
2904 .enable_reg = 0x68244,
2905 .enable_mask = BIT(0),
2906 .hw.init = &(struct clk_init_data){
2907 .name = "gcc_nss_port1_tx_clk",
2908 .parent_hws = (const struct clk_hw *[]){
2909 &nss_port1_tx_div_clk_src.clkr.hw },
2910 .num_parents = 1,
2911 .flags = CLK_SET_RATE_PARENT,
2912 .ops = &clk_branch2_ops,
2913 },
2914 },
2915 };
2916
2917 static struct clk_branch gcc_nss_port2_rx_clk = {
2918 .halt_reg = 0x68248,
2919 .clkr = {
2920 .enable_reg = 0x68248,
2921 .enable_mask = BIT(0),
2922 .hw.init = &(struct clk_init_data){
2923 .name = "gcc_nss_port2_rx_clk",
2924 .parent_hws = (const struct clk_hw *[]){
2925 &nss_port2_rx_div_clk_src.clkr.hw },
2926 .num_parents = 1,
2927 .flags = CLK_SET_RATE_PARENT,
2928 .ops = &clk_branch2_ops,
2929 },
2930 },
2931 };
2932
2933 static struct clk_branch gcc_nss_port2_tx_clk = {
2934 .halt_reg = 0x6824c,
2935 .clkr = {
2936 .enable_reg = 0x6824c,
2937 .enable_mask = BIT(0),
2938 .hw.init = &(struct clk_init_data){
2939 .name = "gcc_nss_port2_tx_clk",
2940 .parent_hws = (const struct clk_hw *[]){
2941 &nss_port2_tx_div_clk_src.clkr.hw },
2942 .num_parents = 1,
2943 .flags = CLK_SET_RATE_PARENT,
2944 .ops = &clk_branch2_ops,
2945 },
2946 },
2947 };
2948
2949 static struct clk_branch gcc_nss_port3_rx_clk = {
2950 .halt_reg = 0x68250,
2951 .clkr = {
2952 .enable_reg = 0x68250,
2953 .enable_mask = BIT(0),
2954 .hw.init = &(struct clk_init_data){
2955 .name = "gcc_nss_port3_rx_clk",
2956 .parent_hws = (const struct clk_hw *[]){
2957 &nss_port3_rx_div_clk_src.clkr.hw },
2958 .num_parents = 1,
2959 .flags = CLK_SET_RATE_PARENT,
2960 .ops = &clk_branch2_ops,
2961 },
2962 },
2963 };
2964
2965 static struct clk_branch gcc_nss_port3_tx_clk = {
2966 .halt_reg = 0x68254,
2967 .clkr = {
2968 .enable_reg = 0x68254,
2969 .enable_mask = BIT(0),
2970 .hw.init = &(struct clk_init_data){
2971 .name = "gcc_nss_port3_tx_clk",
2972 .parent_hws = (const struct clk_hw *[]){
2973 &nss_port3_tx_div_clk_src.clkr.hw },
2974 .num_parents = 1,
2975 .flags = CLK_SET_RATE_PARENT,
2976 .ops = &clk_branch2_ops,
2977 },
2978 },
2979 };
2980
2981 static struct clk_branch gcc_nss_port4_rx_clk = {
2982 .halt_reg = 0x68258,
2983 .clkr = {
2984 .enable_reg = 0x68258,
2985 .enable_mask = BIT(0),
2986 .hw.init = &(struct clk_init_data){
2987 .name = "gcc_nss_port4_rx_clk",
2988 .parent_hws = (const struct clk_hw *[]){
2989 &nss_port4_rx_div_clk_src.clkr.hw },
2990 .num_parents = 1,
2991 .flags = CLK_SET_RATE_PARENT,
2992 .ops = &clk_branch2_ops,
2993 },
2994 },
2995 };
2996
2997 static struct clk_branch gcc_nss_port4_tx_clk = {
2998 .halt_reg = 0x6825c,
2999 .clkr = {
3000 .enable_reg = 0x6825c,
3001 .enable_mask = BIT(0),
3002 .hw.init = &(struct clk_init_data){
3003 .name = "gcc_nss_port4_tx_clk",
3004 .parent_hws = (const struct clk_hw *[]){
3005 &nss_port4_tx_div_clk_src.clkr.hw },
3006 .num_parents = 1,
3007 .flags = CLK_SET_RATE_PARENT,
3008 .ops = &clk_branch2_ops,
3009 },
3010 },
3011 };
3012
3013 static struct clk_branch gcc_nss_port5_rx_clk = {
3014 .halt_reg = 0x68260,
3015 .clkr = {
3016 .enable_reg = 0x68260,
3017 .enable_mask = BIT(0),
3018 .hw.init = &(struct clk_init_data){
3019 .name = "gcc_nss_port5_rx_clk",
3020 .parent_hws = (const struct clk_hw *[]){
3021 &nss_port5_rx_div_clk_src.clkr.hw },
3022 .num_parents = 1,
3023 .flags = CLK_SET_RATE_PARENT,
3024 .ops = &clk_branch2_ops,
3025 },
3026 },
3027 };
3028
3029 static struct clk_branch gcc_nss_port5_tx_clk = {
3030 .halt_reg = 0x68264,
3031 .clkr = {
3032 .enable_reg = 0x68264,
3033 .enable_mask = BIT(0),
3034 .hw.init = &(struct clk_init_data){
3035 .name = "gcc_nss_port5_tx_clk",
3036 .parent_hws = (const struct clk_hw *[]){
3037 &nss_port5_tx_div_clk_src.clkr.hw },
3038 .num_parents = 1,
3039 .flags = CLK_SET_RATE_PARENT,
3040 .ops = &clk_branch2_ops,
3041 },
3042 },
3043 };
3044
3045 static struct clk_branch gcc_nss_ppe_cfg_clk = {
3046 .halt_reg = 0x68194,
3047 .clkr = {
3048 .enable_reg = 0x68194,
3049 .enable_mask = BIT(0),
3050 .hw.init = &(struct clk_init_data){
3051 .name = "gcc_nss_ppe_cfg_clk",
3052 .parent_hws = (const struct clk_hw *[]){
3053 &nss_ppe_clk_src.clkr.hw },
3054 .num_parents = 1,
3055 .flags = CLK_SET_RATE_PARENT,
3056 .ops = &clk_branch2_ops,
3057 },
3058 },
3059 };
3060
3061 static struct clk_branch gcc_nss_ppe_clk = {
3062 .halt_reg = 0x68190,
3063 .clkr = {
3064 .enable_reg = 0x68190,
3065 .enable_mask = BIT(0),
3066 .hw.init = &(struct clk_init_data){
3067 .name = "gcc_nss_ppe_clk",
3068 .parent_hws = (const struct clk_hw *[]){
3069 &nss_ppe_clk_src.clkr.hw },
3070 .num_parents = 1,
3071 .flags = CLK_SET_RATE_PARENT,
3072 .ops = &clk_branch2_ops,
3073 },
3074 },
3075 };
3076
3077 static struct clk_branch gcc_nss_ppe_ipe_clk = {
3078 .halt_reg = 0x68338,
3079 .clkr = {
3080 .enable_reg = 0x68338,
3081 .enable_mask = BIT(0),
3082 .hw.init = &(struct clk_init_data){
3083 .name = "gcc_nss_ppe_ipe_clk",
3084 .parent_hws = (const struct clk_hw *[]){
3085 &nss_ppe_clk_src.clkr.hw },
3086 .num_parents = 1,
3087 .flags = CLK_SET_RATE_PARENT,
3088 .ops = &clk_branch2_ops,
3089 },
3090 },
3091 };
3092
3093 static struct clk_branch gcc_nss_ptp_ref_clk = {
3094 .halt_reg = 0x6816C,
3095 .clkr = {
3096 .enable_reg = 0x6816C,
3097 .enable_mask = BIT(0),
3098 .hw.init = &(struct clk_init_data){
3099 .name = "gcc_nss_ptp_ref_clk",
3100 .parent_hws = (const struct clk_hw *[]){
3101 &nss_ppe_cdiv_clk_src.hw },
3102 .num_parents = 1,
3103 .flags = CLK_SET_RATE_PARENT,
3104 .ops = &clk_branch2_ops,
3105 },
3106 },
3107 };
3108
3109 static struct clk_branch gcc_nssnoc_ce_apb_clk = {
3110 .halt_reg = 0x6830C,
3111 .clkr = {
3112 .enable_reg = 0x6830C,
3113 .enable_mask = BIT(0),
3114 .hw.init = &(struct clk_init_data){
3115 .name = "gcc_nssnoc_ce_apb_clk",
3116 .parent_hws = (const struct clk_hw *[]){
3117 &nss_ce_clk_src.clkr.hw },
3118 .num_parents = 1,
3119 .flags = CLK_SET_RATE_PARENT,
3120 .ops = &clk_branch2_ops,
3121 },
3122 },
3123 };
3124
3125 static struct clk_branch gcc_nssnoc_ce_axi_clk = {
3126 .halt_reg = 0x68308,
3127 .clkr = {
3128 .enable_reg = 0x68308,
3129 .enable_mask = BIT(0),
3130 .hw.init = &(struct clk_init_data){
3131 .name = "gcc_nssnoc_ce_axi_clk",
3132 .parent_hws = (const struct clk_hw *[]){
3133 &nss_ce_clk_src.clkr.hw },
3134 .num_parents = 1,
3135 .flags = CLK_SET_RATE_PARENT,
3136 .ops = &clk_branch2_ops,
3137 },
3138 },
3139 };
3140
3141 static struct clk_branch gcc_nssnoc_crypto_clk = {
3142 .halt_reg = 0x68314,
3143 .clkr = {
3144 .enable_reg = 0x68314,
3145 .enable_mask = BIT(0),
3146 .hw.init = &(struct clk_init_data){
3147 .name = "gcc_nssnoc_crypto_clk",
3148 .parent_hws = (const struct clk_hw *[]){
3149 &nss_crypto_clk_src.clkr.hw },
3150 .num_parents = 1,
3151 .flags = CLK_SET_RATE_PARENT,
3152 .ops = &clk_branch2_ops,
3153 },
3154 },
3155 };
3156
3157 static struct clk_branch gcc_nssnoc_ppe_cfg_clk = {
3158 .halt_reg = 0x68304,
3159 .clkr = {
3160 .enable_reg = 0x68304,
3161 .enable_mask = BIT(0),
3162 .hw.init = &(struct clk_init_data){
3163 .name = "gcc_nssnoc_ppe_cfg_clk",
3164 .parent_hws = (const struct clk_hw *[]){
3165 &nss_ppe_clk_src.clkr.hw },
3166 .flags = CLK_SET_RATE_PARENT,
3167 .ops = &clk_branch2_ops,
3168 },
3169 },
3170 };
3171
3172 static struct clk_branch gcc_nssnoc_ppe_clk = {
3173 .halt_reg = 0x68300,
3174 .clkr = {
3175 .enable_reg = 0x68300,
3176 .enable_mask = BIT(0),
3177 .hw.init = &(struct clk_init_data){
3178 .name = "gcc_nssnoc_ppe_clk",
3179 .parent_hws = (const struct clk_hw *[]){
3180 &nss_ppe_clk_src.clkr.hw },
3181 .num_parents = 1,
3182 .flags = CLK_SET_RATE_PARENT,
3183 .ops = &clk_branch2_ops,
3184 },
3185 },
3186 };
3187
3188 static struct clk_branch gcc_nssnoc_qosgen_ref_clk = {
3189 .halt_reg = 0x68180,
3190 .clkr = {
3191 .enable_reg = 0x68180,
3192 .enable_mask = BIT(0),
3193 .hw.init = &(struct clk_init_data){
3194 .name = "gcc_nssnoc_qosgen_ref_clk",
3195 .parent_hws = (const struct clk_hw *[]){
3196 &gcc_xo_clk_src.clkr.hw },
3197 .num_parents = 1,
3198 .flags = CLK_SET_RATE_PARENT,
3199 .ops = &clk_branch2_ops,
3200 },
3201 },
3202 };
3203
3204 static struct clk_branch gcc_nssnoc_snoc_clk = {
3205 .halt_reg = 0x68188,
3206 .clkr = {
3207 .enable_reg = 0x68188,
3208 .enable_mask = BIT(0),
3209 .hw.init = &(struct clk_init_data){
3210 .name = "gcc_nssnoc_snoc_clk",
3211 .parent_hws = (const struct clk_hw *[]){
3212 &system_noc_bfdcd_clk_src.clkr.hw },
3213 .num_parents = 1,
3214 .flags = CLK_SET_RATE_PARENT,
3215 .ops = &clk_branch2_ops,
3216 },
3217 },
3218 };
3219
3220 static struct clk_branch gcc_nssnoc_timeout_ref_clk = {
3221 .halt_reg = 0x68184,
3222 .clkr = {
3223 .enable_reg = 0x68184,
3224 .enable_mask = BIT(0),
3225 .hw.init = &(struct clk_init_data){
3226 .name = "gcc_nssnoc_timeout_ref_clk",
3227 .parent_hws = (const struct clk_hw *[]){
3228 &gcc_xo_div4_clk_src.hw },
3229 .num_parents = 1,
3230 .flags = CLK_SET_RATE_PARENT,
3231 .ops = &clk_branch2_ops,
3232 },
3233 },
3234 };
3235
3236 static struct clk_branch gcc_nssnoc_ubi0_ahb_clk = {
3237 .halt_reg = 0x68270,
3238 .clkr = {
3239 .enable_reg = 0x68270,
3240 .enable_mask = BIT(0),
3241 .hw.init = &(struct clk_init_data){
3242 .name = "gcc_nssnoc_ubi0_ahb_clk",
3243 .parent_hws = (const struct clk_hw *[]){
3244 &nss_ce_clk_src.clkr.hw },
3245 .num_parents = 1,
3246 .flags = CLK_SET_RATE_PARENT,
3247 .ops = &clk_branch2_ops,
3248 },
3249 },
3250 };
3251
3252 static struct clk_branch gcc_port1_mac_clk = {
3253 .halt_reg = 0x68320,
3254 .clkr = {
3255 .enable_reg = 0x68320,
3256 .enable_mask = BIT(0),
3257 .hw.init = &(struct clk_init_data){
3258 .name = "gcc_port1_mac_clk",
3259 .parent_hws = (const struct clk_hw *[]){
3260 &nss_ppe_clk_src.clkr.hw },
3261 .num_parents = 1,
3262 .flags = CLK_SET_RATE_PARENT,
3263 .ops = &clk_branch2_ops,
3264 },
3265 },
3266 };
3267
3268 static struct clk_branch gcc_port2_mac_clk = {
3269 .halt_reg = 0x68324,
3270 .clkr = {
3271 .enable_reg = 0x68324,
3272 .enable_mask = BIT(0),
3273 .hw.init = &(struct clk_init_data){
3274 .name = "gcc_port2_mac_clk",
3275 .parent_hws = (const struct clk_hw *[]){
3276 &nss_ppe_clk_src.clkr.hw },
3277 .num_parents = 1,
3278 .flags = CLK_SET_RATE_PARENT,
3279 .ops = &clk_branch2_ops,
3280 },
3281 },
3282 };
3283
3284 static struct clk_branch gcc_port3_mac_clk = {
3285 .halt_reg = 0x68328,
3286 .clkr = {
3287 .enable_reg = 0x68328,
3288 .enable_mask = BIT(0),
3289 .hw.init = &(struct clk_init_data){
3290 .name = "gcc_port3_mac_clk",
3291 .parent_hws = (const struct clk_hw *[]){
3292 &nss_ppe_clk_src.clkr.hw },
3293 .num_parents = 1,
3294 .flags = CLK_SET_RATE_PARENT,
3295 .ops = &clk_branch2_ops,
3296 },
3297 },
3298 };
3299
3300 static struct clk_branch gcc_port4_mac_clk = {
3301 .halt_reg = 0x6832c,
3302 .clkr = {
3303 .enable_reg = 0x6832c,
3304 .enable_mask = BIT(0),
3305 .hw.init = &(struct clk_init_data){
3306 .name = "gcc_port4_mac_clk",
3307 .parent_hws = (const struct clk_hw *[]){
3308 &nss_ppe_clk_src.clkr.hw },
3309 .num_parents = 1,
3310 .flags = CLK_SET_RATE_PARENT,
3311 .ops = &clk_branch2_ops,
3312 },
3313 },
3314 };
3315
3316 static struct clk_branch gcc_port5_mac_clk = {
3317 .halt_reg = 0x68330,
3318 .clkr = {
3319 .enable_reg = 0x68330,
3320 .enable_mask = BIT(0),
3321 .hw.init = &(struct clk_init_data){
3322 .name = "gcc_port5_mac_clk",
3323 .parent_hws = (const struct clk_hw *[]){
3324 &nss_ppe_clk_src.clkr.hw },
3325 .num_parents = 1,
3326 .flags = CLK_SET_RATE_PARENT,
3327 .ops = &clk_branch2_ops,
3328 },
3329 },
3330 };
3331
3332 static struct clk_branch gcc_ubi0_ahb_clk = {
3333 .halt_reg = 0x6820C,
3334 .halt_check = BRANCH_HALT_DELAY,
3335 .clkr = {
3336 .enable_reg = 0x6820C,
3337 .enable_mask = BIT(0),
3338 .hw.init = &(struct clk_init_data){
3339 .name = "gcc_ubi0_ahb_clk",
3340 .parent_hws = (const struct clk_hw *[]){
3341 &nss_ce_clk_src.clkr.hw },
3342 .num_parents = 1,
3343 .flags = CLK_SET_RATE_PARENT,
3344 .ops = &clk_branch2_ops,
3345 },
3346 },
3347 };
3348
3349 static struct clk_branch gcc_ubi0_axi_clk = {
3350 .halt_reg = 0x68200,
3351 .halt_check = BRANCH_HALT_DELAY,
3352 .clkr = {
3353 .enable_reg = 0x68200,
3354 .enable_mask = BIT(0),
3355 .hw.init = &(struct clk_init_data){
3356 .name = "gcc_ubi0_axi_clk",
3357 .parent_hws = (const struct clk_hw *[]){
3358 &ubi32_mem_noc_bfdcd_clk_src.clkr.hw },
3359 .num_parents = 1,
3360 .flags = CLK_SET_RATE_PARENT,
3361 .ops = &clk_branch2_ops,
3362 },
3363 },
3364 };
3365
3366 static struct clk_branch gcc_ubi0_nc_axi_clk = {
3367 .halt_reg = 0x68204,
3368 .halt_check = BRANCH_HALT_DELAY,
3369 .clkr = {
3370 .enable_reg = 0x68204,
3371 .enable_mask = BIT(0),
3372 .hw.init = &(struct clk_init_data){
3373 .name = "gcc_ubi0_nc_axi_clk",
3374 .parent_hws = (const struct clk_hw *[]){
3375 &snoc_nssnoc_bfdcd_clk_src.clkr.hw },
3376 .num_parents = 1,
3377 .flags = CLK_SET_RATE_PARENT,
3378 .ops = &clk_branch2_ops,
3379 },
3380 },
3381 };
3382
3383 static struct clk_branch gcc_ubi0_core_clk = {
3384 .halt_reg = 0x68210,
3385 .halt_check = BRANCH_HALT_DELAY,
3386 .clkr = {
3387 .enable_reg = 0x68210,
3388 .enable_mask = BIT(0),
3389 .hw.init = &(struct clk_init_data){
3390 .name = "gcc_ubi0_core_clk",
3391 .parent_hws = (const struct clk_hw *[]){
3392 &nss_ubi0_div_clk_src.clkr.hw },
3393 .num_parents = 1,
3394 .flags = CLK_SET_RATE_PARENT,
3395 .ops = &clk_branch2_ops,
3396 },
3397 },
3398 };
3399
3400 static struct clk_branch gcc_pcie0_ahb_clk = {
3401 .halt_reg = 0x75010,
3402 .clkr = {
3403 .enable_reg = 0x75010,
3404 .enable_mask = BIT(0),
3405 .hw.init = &(struct clk_init_data){
3406 .name = "gcc_pcie0_ahb_clk",
3407 .parent_hws = (const struct clk_hw *[]){
3408 &pcnoc_bfdcd_clk_src.clkr.hw },
3409 .num_parents = 1,
3410 .flags = CLK_SET_RATE_PARENT,
3411 .ops = &clk_branch2_ops,
3412 },
3413 },
3414 };
3415
3416 static struct clk_branch gcc_pcie0_aux_clk = {
3417 .halt_reg = 0x75014,
3418 .clkr = {
3419 .enable_reg = 0x75014,
3420 .enable_mask = BIT(0),
3421 .hw.init = &(struct clk_init_data){
3422 .name = "gcc_pcie0_aux_clk",
3423 .parent_hws = (const struct clk_hw *[]){
3424 &pcie0_aux_clk_src.clkr.hw },
3425 .num_parents = 1,
3426 .flags = CLK_SET_RATE_PARENT,
3427 .ops = &clk_branch2_ops,
3428 },
3429 },
3430 };
3431
3432 static struct clk_branch gcc_pcie0_axi_m_clk = {
3433 .halt_reg = 0x75008,
3434 .clkr = {
3435 .enable_reg = 0x75008,
3436 .enable_mask = BIT(0),
3437 .hw.init = &(struct clk_init_data){
3438 .name = "gcc_pcie0_axi_m_clk",
3439 .parent_hws = (const struct clk_hw *[]){
3440 &pcie0_axi_clk_src.clkr.hw },
3441 .num_parents = 1,
3442 .flags = CLK_SET_RATE_PARENT,
3443 .ops = &clk_branch2_ops,
3444 },
3445 },
3446 };
3447
3448 static struct clk_branch gcc_pcie0_axi_s_clk = {
3449 .halt_reg = 0x7500c,
3450 .clkr = {
3451 .enable_reg = 0x7500c,
3452 .enable_mask = BIT(0),
3453 .hw.init = &(struct clk_init_data){
3454 .name = "gcc_pcie0_axi_s_clk",
3455 .parent_hws = (const struct clk_hw *[]){
3456 &pcie0_axi_clk_src.clkr.hw },
3457 .num_parents = 1,
3458 .flags = CLK_SET_RATE_PARENT,
3459 .ops = &clk_branch2_ops,
3460 },
3461 },
3462 };
3463
3464 static struct clk_branch gcc_sys_noc_pcie0_axi_clk = {
3465 .halt_reg = 0x26048,
3466 .clkr = {
3467 .enable_reg = 0x26048,
3468 .enable_mask = BIT(0),
3469 .hw.init = &(struct clk_init_data){
3470 .name = "gcc_sys_noc_pcie0_axi_clk",
3471 .parent_hws = (const struct clk_hw *[]){
3472 &pcie0_axi_clk_src.clkr.hw },
3473 .num_parents = 1,
3474 .flags = CLK_SET_RATE_PARENT,
3475 .ops = &clk_branch2_ops,
3476 },
3477 },
3478 };
3479
3480 static struct clk_branch gcc_pcie0_pipe_clk = {
3481 .halt_reg = 0x75018,
3482 .halt_check = BRANCH_HALT_DELAY,
3483 .clkr = {
3484 .enable_reg = 0x75018,
3485 .enable_mask = BIT(0),
3486 .hw.init = &(struct clk_init_data){
3487 .name = "gcc_pcie0_pipe_clk",
3488 .parent_hws = (const struct clk_hw *[]){
3489 &pcie0_pipe_clk_src.clkr.hw },
3490 .num_parents = 1,
3491 .flags = CLK_SET_RATE_PARENT,
3492 .ops = &clk_branch2_ops,
3493 },
3494 },
3495 };
3496
3497 static struct clk_branch gcc_prng_ahb_clk = {
3498 .halt_reg = 0x13004,
3499 .halt_check = BRANCH_HALT_VOTED,
3500 .clkr = {
3501 .enable_reg = 0x0b004,
3502 .enable_mask = BIT(8),
3503 .hw.init = &(struct clk_init_data){
3504 .name = "gcc_prng_ahb_clk",
3505 .parent_hws = (const struct clk_hw *[]){
3506 &pcnoc_bfdcd_clk_src.clkr.hw },
3507 .num_parents = 1,
3508 .flags = CLK_SET_RATE_PARENT,
3509 .ops = &clk_branch2_ops,
3510 },
3511 },
3512 };
3513
3514 static struct clk_branch gcc_qdss_dap_clk = {
3515 .halt_reg = 0x29084,
3516 .clkr = {
3517 .enable_reg = 0x29084,
3518 .enable_mask = BIT(0),
3519 .hw.init = &(struct clk_init_data){
3520 .name = "gcc_qdss_dap_clk",
3521 .parent_hws = (const struct clk_hw *[]){
3522 &qdss_dap_sync_clk_src.hw },
3523 .num_parents = 1,
3524 .flags = CLK_SET_RATE_PARENT,
3525 .ops = &clk_branch2_ops,
3526 },
3527 },
3528 };
3529
3530 static struct clk_branch gcc_qpic_ahb_clk = {
3531 .halt_reg = 0x57024,
3532 .clkr = {
3533 .enable_reg = 0x57024,
3534 .enable_mask = BIT(0),
3535 .hw.init = &(struct clk_init_data){
3536 .name = "gcc_qpic_ahb_clk",
3537 .parent_hws = (const struct clk_hw *[]){
3538 &pcnoc_bfdcd_clk_src.clkr.hw },
3539 .num_parents = 1,
3540 .flags = CLK_SET_RATE_PARENT,
3541 .ops = &clk_branch2_ops,
3542 },
3543 },
3544 };
3545
3546 static struct clk_branch gcc_qpic_clk = {
3547 .halt_reg = 0x57020,
3548 .clkr = {
3549 .enable_reg = 0x57020,
3550 .enable_mask = BIT(0),
3551 .hw.init = &(struct clk_init_data){
3552 .name = "gcc_qpic_clk",
3553 .parent_hws = (const struct clk_hw *[]){
3554 &pcnoc_bfdcd_clk_src.clkr.hw },
3555 .num_parents = 1,
3556 .flags = CLK_SET_RATE_PARENT,
3557 .ops = &clk_branch2_ops,
3558 },
3559 },
3560 };
3561
3562 static struct clk_branch gcc_sdcc1_ahb_clk = {
3563 .halt_reg = 0x4201c,
3564 .clkr = {
3565 .enable_reg = 0x4201c,
3566 .enable_mask = BIT(0),
3567 .hw.init = &(struct clk_init_data){
3568 .name = "gcc_sdcc1_ahb_clk",
3569 .parent_hws = (const struct clk_hw *[]){
3570 &pcnoc_bfdcd_clk_src.clkr.hw },
3571 .num_parents = 1,
3572 .flags = CLK_SET_RATE_PARENT,
3573 .ops = &clk_branch2_ops,
3574 },
3575 },
3576 };
3577
3578 static struct clk_branch gcc_sdcc1_apps_clk = {
3579 .halt_reg = 0x42018,
3580 .clkr = {
3581 .enable_reg = 0x42018,
3582 .enable_mask = BIT(0),
3583 .hw.init = &(struct clk_init_data){
3584 .name = "gcc_sdcc1_apps_clk",
3585 .parent_hws = (const struct clk_hw *[]){
3586 &sdcc1_apps_clk_src.clkr.hw },
3587 .num_parents = 1,
3588 .flags = CLK_SET_RATE_PARENT,
3589 .ops = &clk_branch2_ops,
3590 },
3591 },
3592 };
3593
3594 static struct clk_branch gcc_uniphy0_ahb_clk = {
3595 .halt_reg = 0x56008,
3596 .clkr = {
3597 .enable_reg = 0x56008,
3598 .enable_mask = BIT(0),
3599 .hw.init = &(struct clk_init_data){
3600 .name = "gcc_uniphy0_ahb_clk",
3601 .parent_hws = (const struct clk_hw *[]){
3602 &pcnoc_bfdcd_clk_src.clkr.hw },
3603 .num_parents = 1,
3604 .flags = CLK_SET_RATE_PARENT,
3605 .ops = &clk_branch2_ops,
3606 },
3607 },
3608 };
3609
3610 static struct clk_branch gcc_uniphy0_port1_rx_clk = {
3611 .halt_reg = 0x56010,
3612 .clkr = {
3613 .enable_reg = 0x56010,
3614 .enable_mask = BIT(0),
3615 .hw.init = &(struct clk_init_data){
3616 .name = "gcc_uniphy0_port1_rx_clk",
3617 .parent_hws = (const struct clk_hw *[]){
3618 &nss_port1_rx_div_clk_src.clkr.hw },
3619 .num_parents = 1,
3620 .flags = CLK_SET_RATE_PARENT,
3621 .ops = &clk_branch2_ops,
3622 },
3623 },
3624 };
3625
3626 static struct clk_branch gcc_uniphy0_port1_tx_clk = {
3627 .halt_reg = 0x56014,
3628 .clkr = {
3629 .enable_reg = 0x56014,
3630 .enable_mask = BIT(0),
3631 .hw.init = &(struct clk_init_data){
3632 .name = "gcc_uniphy0_port1_tx_clk",
3633 .parent_hws = (const struct clk_hw *[]){
3634 &nss_port1_tx_div_clk_src.clkr.hw },
3635 .num_parents = 1,
3636 .flags = CLK_SET_RATE_PARENT,
3637 .ops = &clk_branch2_ops,
3638 },
3639 },
3640 };
3641
3642 static struct clk_branch gcc_uniphy0_port2_rx_clk = {
3643 .halt_reg = 0x56018,
3644 .clkr = {
3645 .enable_reg = 0x56018,
3646 .enable_mask = BIT(0),
3647 .hw.init = &(struct clk_init_data){
3648 .name = "gcc_uniphy0_port2_rx_clk",
3649 .parent_hws = (const struct clk_hw *[]){
3650 &nss_port2_rx_div_clk_src.clkr.hw },
3651 .num_parents = 1,
3652 .flags = CLK_SET_RATE_PARENT,
3653 .ops = &clk_branch2_ops,
3654 },
3655 },
3656 };
3657
3658 static struct clk_branch gcc_uniphy0_port2_tx_clk = {
3659 .halt_reg = 0x5601c,
3660 .clkr = {
3661 .enable_reg = 0x5601c,
3662 .enable_mask = BIT(0),
3663 .hw.init = &(struct clk_init_data){
3664 .name = "gcc_uniphy0_port2_tx_clk",
3665 .parent_hws = (const struct clk_hw *[]){
3666 &nss_port2_tx_div_clk_src.clkr.hw },
3667 .num_parents = 1,
3668 .flags = CLK_SET_RATE_PARENT,
3669 .ops = &clk_branch2_ops,
3670 },
3671 },
3672 };
3673
3674 static struct clk_branch gcc_uniphy0_port3_rx_clk = {
3675 .halt_reg = 0x56020,
3676 .clkr = {
3677 .enable_reg = 0x56020,
3678 .enable_mask = BIT(0),
3679 .hw.init = &(struct clk_init_data){
3680 .name = "gcc_uniphy0_port3_rx_clk",
3681 .parent_hws = (const struct clk_hw *[]){
3682 &nss_port3_rx_div_clk_src.clkr.hw },
3683 .num_parents = 1,
3684 .flags = CLK_SET_RATE_PARENT,
3685 .ops = &clk_branch2_ops,
3686 },
3687 },
3688 };
3689
3690 static struct clk_branch gcc_uniphy0_port3_tx_clk = {
3691 .halt_reg = 0x56024,
3692 .clkr = {
3693 .enable_reg = 0x56024,
3694 .enable_mask = BIT(0),
3695 .hw.init = &(struct clk_init_data){
3696 .name = "gcc_uniphy0_port3_tx_clk",
3697 .parent_hws = (const struct clk_hw *[]){
3698 &nss_port3_tx_div_clk_src.clkr.hw },
3699 .num_parents = 1,
3700 .flags = CLK_SET_RATE_PARENT,
3701 .ops = &clk_branch2_ops,
3702 },
3703 },
3704 };
3705
3706 static struct clk_branch gcc_uniphy0_port4_rx_clk = {
3707 .halt_reg = 0x56028,
3708 .clkr = {
3709 .enable_reg = 0x56028,
3710 .enable_mask = BIT(0),
3711 .hw.init = &(struct clk_init_data){
3712 .name = "gcc_uniphy0_port4_rx_clk",
3713 .parent_hws = (const struct clk_hw *[]){
3714 &nss_port4_rx_div_clk_src.clkr.hw },
3715 .num_parents = 1,
3716 .flags = CLK_SET_RATE_PARENT,
3717 .ops = &clk_branch2_ops,
3718 },
3719 },
3720 };
3721
3722 static struct clk_branch gcc_uniphy0_port4_tx_clk = {
3723 .halt_reg = 0x5602c,
3724 .clkr = {
3725 .enable_reg = 0x5602c,
3726 .enable_mask = BIT(0),
3727 .hw.init = &(struct clk_init_data){
3728 .name = "gcc_uniphy0_port4_tx_clk",
3729 .parent_hws = (const struct clk_hw *[]){
3730 &nss_port4_tx_div_clk_src.clkr.hw },
3731 .num_parents = 1,
3732 .flags = CLK_SET_RATE_PARENT,
3733 .ops = &clk_branch2_ops,
3734 },
3735 },
3736 };
3737
3738 static struct clk_branch gcc_uniphy0_port5_rx_clk = {
3739 .halt_reg = 0x56030,
3740 .clkr = {
3741 .enable_reg = 0x56030,
3742 .enable_mask = BIT(0),
3743 .hw.init = &(struct clk_init_data){
3744 .name = "gcc_uniphy0_port5_rx_clk",
3745 .parent_hws = (const struct clk_hw *[]){
3746 &nss_port5_rx_div_clk_src.clkr.hw },
3747 .num_parents = 1,
3748 .flags = CLK_SET_RATE_PARENT,
3749 .ops = &clk_branch2_ops,
3750 },
3751 },
3752 };
3753
3754 static struct clk_branch gcc_uniphy0_port5_tx_clk = {
3755 .halt_reg = 0x56034,
3756 .clkr = {
3757 .enable_reg = 0x56034,
3758 .enable_mask = BIT(0),
3759 .hw.init = &(struct clk_init_data){
3760 .name = "gcc_uniphy0_port5_tx_clk",
3761 .parent_hws = (const struct clk_hw *[]){
3762 &nss_port5_tx_div_clk_src.clkr.hw },
3763 .num_parents = 1,
3764 .flags = CLK_SET_RATE_PARENT,
3765 .ops = &clk_branch2_ops,
3766 },
3767 },
3768 };
3769
3770 static struct clk_branch gcc_uniphy0_sys_clk = {
3771 .halt_reg = 0x5600C,
3772 .clkr = {
3773 .enable_reg = 0x5600C,
3774 .enable_mask = BIT(0),
3775 .hw.init = &(struct clk_init_data){
3776 .name = "gcc_uniphy0_sys_clk",
3777 .parent_hws = (const struct clk_hw *[]){
3778 &gcc_xo_clk_src.clkr.hw },
3779 .num_parents = 1,
3780 .flags = CLK_SET_RATE_PARENT,
3781 .ops = &clk_branch2_ops,
3782 },
3783 },
3784 };
3785
3786 static struct clk_branch gcc_uniphy1_ahb_clk = {
3787 .halt_reg = 0x56108,
3788 .clkr = {
3789 .enable_reg = 0x56108,
3790 .enable_mask = BIT(0),
3791 .hw.init = &(struct clk_init_data){
3792 .name = "gcc_uniphy1_ahb_clk",
3793 .parent_hws = (const struct clk_hw *[]){
3794 &pcnoc_bfdcd_clk_src.clkr.hw },
3795 .num_parents = 1,
3796 .flags = CLK_SET_RATE_PARENT,
3797 .ops = &clk_branch2_ops,
3798 },
3799 },
3800 };
3801
3802 static struct clk_branch gcc_uniphy1_port5_rx_clk = {
3803 .halt_reg = 0x56110,
3804 .clkr = {
3805 .enable_reg = 0x56110,
3806 .enable_mask = BIT(0),
3807 .hw.init = &(struct clk_init_data){
3808 .name = "gcc_uniphy1_port5_rx_clk",
3809 .parent_hws = (const struct clk_hw *[]){
3810 &nss_port5_rx_div_clk_src.clkr.hw },
3811 .num_parents = 1,
3812 .flags = CLK_SET_RATE_PARENT,
3813 .ops = &clk_branch2_ops,
3814 },
3815 },
3816 };
3817
3818 static struct clk_branch gcc_uniphy1_port5_tx_clk = {
3819 .halt_reg = 0x56114,
3820 .clkr = {
3821 .enable_reg = 0x56114,
3822 .enable_mask = BIT(0),
3823 .hw.init = &(struct clk_init_data){
3824 .name = "gcc_uniphy1_port5_tx_clk",
3825 .parent_hws = (const struct clk_hw *[]){
3826 &nss_port5_tx_div_clk_src.clkr.hw },
3827 .num_parents = 1,
3828 .flags = CLK_SET_RATE_PARENT,
3829 .ops = &clk_branch2_ops,
3830 },
3831 },
3832 };
3833
3834 static struct clk_branch gcc_uniphy1_sys_clk = {
3835 .halt_reg = 0x5610C,
3836 .clkr = {
3837 .enable_reg = 0x5610C,
3838 .enable_mask = BIT(0),
3839 .hw.init = &(struct clk_init_data){
3840 .name = "gcc_uniphy1_sys_clk",
3841 .parent_hws = (const struct clk_hw *[]){
3842 &gcc_xo_clk_src.clkr.hw },
3843 .num_parents = 1,
3844 .flags = CLK_SET_RATE_PARENT,
3845 .ops = &clk_branch2_ops,
3846 },
3847 },
3848 };
3849
3850 static struct clk_branch gcc_usb0_aux_clk = {
3851 .halt_reg = 0x3e044,
3852 .clkr = {
3853 .enable_reg = 0x3e044,
3854 .enable_mask = BIT(0),
3855 .hw.init = &(struct clk_init_data){
3856 .name = "gcc_usb0_aux_clk",
3857 .parent_hws = (const struct clk_hw *[]){
3858 &usb0_aux_clk_src.clkr.hw },
3859 .num_parents = 1,
3860 .flags = CLK_SET_RATE_PARENT,
3861 .ops = &clk_branch2_ops,
3862 },
3863 },
3864 };
3865
3866 static struct clk_branch gcc_usb0_master_clk = {
3867 .halt_reg = 0x3e000,
3868 .clkr = {
3869 .enable_reg = 0x3e000,
3870 .enable_mask = BIT(0),
3871 .hw.init = &(struct clk_init_data){
3872 .name = "gcc_usb0_master_clk",
3873 .parent_hws = (const struct clk_hw *[]){
3874 &usb0_master_clk_src.clkr.hw },
3875 .num_parents = 1,
3876 .flags = CLK_SET_RATE_PARENT,
3877 .ops = &clk_branch2_ops,
3878 },
3879 },
3880 };
3881
3882 static struct clk_branch gcc_snoc_bus_timeout2_ahb_clk = {
3883 .halt_reg = 0x47014,
3884 .clkr = {
3885 .enable_reg = 0x47014,
3886 .enable_mask = BIT(0),
3887 .hw.init = &(struct clk_init_data){
3888 .name = "gcc_snoc_bus_timeout2_ahb_clk",
3889 .parent_hws = (const struct clk_hw *[]){
3890 &usb0_master_clk_src.clkr.hw },
3891 .num_parents = 1,
3892 .flags = CLK_SET_RATE_PARENT,
3893 .ops = &clk_branch2_ops,
3894 },
3895 },
3896 };
3897
3898 static struct clk_rcg2 pcie0_rchng_clk_src = {
3899 .cmd_rcgr = 0x75070,
3900 .freq_tbl = ftbl_pcie_rchng_clk_src,
3901 .hid_width = 5,
3902 .parent_map = gcc_xo_gpll0_map,
3903 .clkr.hw.init = &(struct clk_init_data){
3904 .name = "pcie0_rchng_clk_src",
3905 .parent_data = gcc_xo_gpll0,
3906 .num_parents = 2,
3907 .ops = &clk_rcg2_ops,
3908 },
3909 };
3910
3911 static struct clk_branch gcc_pcie0_rchng_clk = {
3912 .halt_reg = 0x75070,
3913 .clkr = {
3914 .enable_reg = 0x75070,
3915 .enable_mask = BIT(1),
3916 .hw.init = &(struct clk_init_data){
3917 .name = "gcc_pcie0_rchng_clk",
3918 .parent_hws = (const struct clk_hw *[]){
3919 &pcie0_rchng_clk_src.clkr.hw },
3920 .num_parents = 1,
3921 .flags = CLK_SET_RATE_PARENT,
3922 .ops = &clk_branch2_ops,
3923 },
3924 },
3925 };
3926
3927 static struct clk_branch gcc_pcie0_axi_s_bridge_clk = {
3928 .halt_reg = 0x75048,
3929 .clkr = {
3930 .enable_reg = 0x75048,
3931 .enable_mask = BIT(0),
3932 .hw.init = &(struct clk_init_data){
3933 .name = "gcc_pcie0_axi_s_bridge_clk",
3934 .parent_hws = (const struct clk_hw *[]){
3935 &pcie0_axi_clk_src.clkr.hw },
3936 .num_parents = 1,
3937 .flags = CLK_SET_RATE_PARENT,
3938 .ops = &clk_branch2_ops,
3939 },
3940 },
3941 };
3942
3943 static struct clk_branch gcc_sys_noc_usb0_axi_clk = {
3944 .halt_reg = 0x26040,
3945 .clkr = {
3946 .enable_reg = 0x26040,
3947 .enable_mask = BIT(0),
3948 .hw.init = &(struct clk_init_data){
3949 .name = "gcc_sys_noc_usb0_axi_clk",
3950 .parent_hws = (const struct clk_hw *[]){
3951 &usb0_master_clk_src.clkr.hw },
3952 .num_parents = 1,
3953 .flags = CLK_SET_RATE_PARENT,
3954 .ops = &clk_branch2_ops,
3955 },
3956 },
3957 };
3958
3959 static struct clk_branch gcc_usb0_mock_utmi_clk = {
3960 .halt_reg = 0x3e008,
3961 .clkr = {
3962 .enable_reg = 0x3e008,
3963 .enable_mask = BIT(0),
3964 .hw.init = &(struct clk_init_data){
3965 .name = "gcc_usb0_mock_utmi_clk",
3966 .parent_hws = (const struct clk_hw *[]){
3967 &usb0_mock_utmi_clk_src.clkr.hw },
3968 .num_parents = 1,
3969 .flags = CLK_SET_RATE_PARENT,
3970 .ops = &clk_branch2_ops,
3971 },
3972 },
3973 };
3974
3975 static struct clk_branch gcc_usb0_phy_cfg_ahb_clk = {
3976 .halt_reg = 0x3e080,
3977 .clkr = {
3978 .enable_reg = 0x3e080,
3979 .enable_mask = BIT(0),
3980 .hw.init = &(struct clk_init_data){
3981 .name = "gcc_usb0_phy_cfg_ahb_clk",
3982 .parent_hws = (const struct clk_hw *[]){
3983 &pcnoc_bfdcd_clk_src.clkr.hw },
3984 .num_parents = 1,
3985 .flags = CLK_SET_RATE_PARENT,
3986 .ops = &clk_branch2_ops,
3987 },
3988 },
3989 };
3990
3991 static struct clk_branch gcc_usb0_pipe_clk = {
3992 .halt_reg = 0x3e040,
3993 .halt_check = BRANCH_HALT_DELAY,
3994 .clkr = {
3995 .enable_reg = 0x3e040,
3996 .enable_mask = BIT(0),
3997 .hw.init = &(struct clk_init_data){
3998 .name = "gcc_usb0_pipe_clk",
3999 .parent_hws = (const struct clk_hw *[]){
4000 &usb0_pipe_clk_src.clkr.hw },
4001 .num_parents = 1,
4002 .flags = CLK_SET_RATE_PARENT,
4003 .ops = &clk_branch2_ops,
4004 },
4005 },
4006 };
4007
4008 static struct clk_branch gcc_usb0_sleep_clk = {
4009 .halt_reg = 0x3e004,
4010 .clkr = {
4011 .enable_reg = 0x3e004,
4012 .enable_mask = BIT(0),
4013 .hw.init = &(struct clk_init_data){
4014 .name = "gcc_usb0_sleep_clk",
4015 .parent_hws = (const struct clk_hw *[]){
4016 &gcc_sleep_clk_src.clkr.hw },
4017 .num_parents = 1,
4018 .flags = CLK_SET_RATE_PARENT,
4019 .ops = &clk_branch2_ops,
4020 },
4021 },
4022 };
4023
4024 static struct clk_branch gcc_usb1_master_clk = {
4025 .halt_reg = 0x3f000,
4026 .clkr = {
4027 .enable_reg = 0x3f000,
4028 .enable_mask = BIT(0),
4029 .hw.init = &(struct clk_init_data){
4030 .name = "gcc_usb1_master_clk",
4031 .parent_hws = (const struct clk_hw *[]){
4032 &pcnoc_bfdcd_clk_src.clkr.hw },
4033 .num_parents = 1,
4034 .flags = CLK_SET_RATE_PARENT,
4035 .ops = &clk_branch2_ops,
4036 },
4037 },
4038 };
4039
4040 static struct clk_branch gcc_usb1_mock_utmi_clk = {
4041 .halt_reg = 0x3f008,
4042 .clkr = {
4043 .enable_reg = 0x3f008,
4044 .enable_mask = BIT(0),
4045 .hw.init = &(struct clk_init_data){
4046 .name = "gcc_usb1_mock_utmi_clk",
4047 .parent_hws = (const struct clk_hw *[]){
4048 &usb1_mock_utmi_clk_src.clkr.hw },
4049 .num_parents = 1,
4050 .flags = CLK_SET_RATE_PARENT,
4051 .ops = &clk_branch2_ops,
4052 },
4053 },
4054 };
4055
4056 static struct clk_branch gcc_usb1_phy_cfg_ahb_clk = {
4057 .halt_reg = 0x3f080,
4058 .clkr = {
4059 .enable_reg = 0x3f080,
4060 .enable_mask = BIT(0),
4061 .hw.init = &(struct clk_init_data){
4062 .name = "gcc_usb1_phy_cfg_ahb_clk",
4063 .parent_hws = (const struct clk_hw *[]){
4064 &pcnoc_bfdcd_clk_src.clkr.hw },
4065 .num_parents = 1,
4066 .flags = CLK_SET_RATE_PARENT,
4067 .ops = &clk_branch2_ops,
4068 },
4069 },
4070 };
4071
4072 static struct clk_branch gcc_usb1_sleep_clk = {
4073 .halt_reg = 0x3f004,
4074 .clkr = {
4075 .enable_reg = 0x3f004,
4076 .enable_mask = BIT(0),
4077 .hw.init = &(struct clk_init_data){
4078 .name = "gcc_usb1_sleep_clk",
4079 .parent_hws = (const struct clk_hw *[]){
4080 &gcc_sleep_clk_src.clkr.hw },
4081 .num_parents = 1,
4082 .flags = CLK_SET_RATE_PARENT,
4083 .ops = &clk_branch2_ops,
4084 },
4085 },
4086 };
4087
4088 static struct clk_branch gcc_cmn_12gpll_ahb_clk = {
4089 .halt_reg = 0x56308,
4090 .clkr = {
4091 .enable_reg = 0x56308,
4092 .enable_mask = BIT(0),
4093 .hw.init = &(struct clk_init_data){
4094 .name = "gcc_cmn_12gpll_ahb_clk",
4095 .parent_hws = (const struct clk_hw *[]){
4096 &pcnoc_bfdcd_clk_src.clkr.hw },
4097 .num_parents = 1,
4098 .flags = CLK_SET_RATE_PARENT,
4099 .ops = &clk_branch2_ops,
4100 },
4101 },
4102 };
4103
4104 static struct clk_branch gcc_cmn_12gpll_sys_clk = {
4105 .halt_reg = 0x5630c,
4106 .clkr = {
4107 .enable_reg = 0x5630c,
4108 .enable_mask = BIT(0),
4109 .hw.init = &(struct clk_init_data){
4110 .name = "gcc_cmn_12gpll_sys_clk",
4111 .parent_hws = (const struct clk_hw *[]){
4112 &gcc_xo_clk_src.clkr.hw },
4113 .num_parents = 1,
4114 .flags = CLK_SET_RATE_PARENT,
4115 .ops = &clk_branch2_ops,
4116 },
4117 },
4118 };
4119
4120 static struct clk_branch gcc_sdcc1_ice_core_clk = {
4121 .halt_reg = 0x5d014,
4122 .clkr = {
4123 .enable_reg = 0x5d014,
4124 .enable_mask = BIT(0),
4125 .hw.init = &(struct clk_init_data){
4126 .name = "gcc_sdcc1_ice_core_clk",
4127 .parent_hws = (const struct clk_hw *[]){
4128 &sdcc1_ice_core_clk_src.clkr.hw },
4129 .num_parents = 1,
4130 .flags = CLK_SET_RATE_PARENT,
4131 .ops = &clk_branch2_ops,
4132 },
4133 },
4134 };
4135
4136 static struct clk_branch gcc_dcc_clk = {
4137 .halt_reg = 0x77004,
4138 .clkr = {
4139 .enable_reg = 0x77004,
4140 .enable_mask = BIT(0),
4141 .hw.init = &(struct clk_init_data){
4142 .name = "gcc_dcc_clk",
4143 .parent_hws = (const struct clk_hw *[]){
4144 &pcnoc_bfdcd_clk_src.clkr.hw },
4145 .num_parents = 1,
4146 .flags = CLK_SET_RATE_PARENT,
4147 .ops = &clk_branch2_ops,
4148 },
4149 },
4150 };
4151
4152 static const struct alpha_pll_config ubi32_pll_config = {
4153 .l = 0x3e,
4154 .alpha = 0x57,
4155 .config_ctl_val = 0x240d6aa8,
4156 .config_ctl_hi_val = 0x3c2,
4157 .main_output_mask = BIT(0),
4158 .aux_output_mask = BIT(1),
4159 .pre_div_val = 0x0,
4160 .pre_div_mask = BIT(12),
4161 .post_div_val = 0x0,
4162 .post_div_mask = GENMASK(9, 8),
4163 };
4164
4165 static const struct alpha_pll_config nss_crypto_pll_config = {
4166 .l = 0x32,
4167 .alpha = 0x0,
4168 .alpha_hi = 0x0,
4169 .config_ctl_val = 0x4001055b,
4170 .main_output_mask = BIT(0),
4171 .pre_div_val = 0x0,
4172 .pre_div_mask = GENMASK(14, 12),
4173 .post_div_val = 0x1 << 8,
4174 .post_div_mask = GENMASK(11, 8),
4175 .vco_mask = GENMASK(21, 20),
4176 .vco_val = 0x0,
4177 .alpha_en_mask = BIT(24),
4178 };
4179
4180 static struct clk_hw *gcc_ipq6018_hws[] = {
4181 &gpll0_out_main_div2.hw,
4182 &gcc_xo_div4_clk_src.hw,
4183 &nss_ppe_cdiv_clk_src.hw,
4184 &gpll6_out_main_div2.hw,
4185 &qdss_dap_sync_clk_src.hw,
4186 &qdss_tsctr_div2_clk_src.hw,
4187 };
4188
4189 static struct clk_regmap *gcc_ipq6018_clks[] = {
4190 [GPLL0_MAIN] = &gpll0_main.clkr,
4191 [GPLL0] = &gpll0.clkr,
4192 [UBI32_PLL_MAIN] = &ubi32_pll_main.clkr,
4193 [UBI32_PLL] = &ubi32_pll.clkr,
4194 [GPLL6_MAIN] = &gpll6_main.clkr,
4195 [GPLL6] = &gpll6.clkr,
4196 [GPLL4_MAIN] = &gpll4_main.clkr,
4197 [GPLL4] = &gpll4.clkr,
4198 [PCNOC_BFDCD_CLK_SRC] = &pcnoc_bfdcd_clk_src.clkr,
4199 [GPLL2_MAIN] = &gpll2_main.clkr,
4200 [GPLL2] = &gpll2.clkr,
4201 [NSS_CRYPTO_PLL_MAIN] = &nss_crypto_pll_main.clkr,
4202 [NSS_CRYPTO_PLL] = &nss_crypto_pll.clkr,
4203 [QDSS_TSCTR_CLK_SRC] = &qdss_tsctr_clk_src.clkr,
4204 [QDSS_AT_CLK_SRC] = &qdss_at_clk_src.clkr,
4205 [NSS_PPE_CLK_SRC] = &nss_ppe_clk_src.clkr,
4206 [GCC_XO_CLK_SRC] = &gcc_xo_clk_src.clkr,
4207 [SYSTEM_NOC_BFDCD_CLK_SRC] = &system_noc_bfdcd_clk_src.clkr,
4208 [SNOC_NSSNOC_BFDCD_CLK_SRC] = &snoc_nssnoc_bfdcd_clk_src.clkr,
4209 [NSS_CE_CLK_SRC] = &nss_ce_clk_src.clkr,
4210 [GCC_SLEEP_CLK_SRC] = &gcc_sleep_clk_src.clkr,
4211 [APSS_AHB_CLK_SRC] = &apss_ahb_clk_src.clkr,
4212 [NSS_PORT5_RX_CLK_SRC] = &nss_port5_rx_clk_src.clkr,
4213 [NSS_PORT5_TX_CLK_SRC] = &nss_port5_tx_clk_src.clkr,
4214 [UBI32_MEM_NOC_BFDCD_CLK_SRC] = &ubi32_mem_noc_bfdcd_clk_src.clkr,
4215 [PCIE0_AXI_CLK_SRC] = &pcie0_axi_clk_src.clkr,
4216 [USB0_MASTER_CLK_SRC] = &usb0_master_clk_src.clkr,
4217 [APSS_AHB_POSTDIV_CLK_SRC] = &apss_ahb_postdiv_clk_src.clkr,
4218 [NSS_PORT1_RX_CLK_SRC] = &nss_port1_rx_clk_src.clkr,
4219 [NSS_PORT1_TX_CLK_SRC] = &nss_port1_tx_clk_src.clkr,
4220 [NSS_PORT2_RX_CLK_SRC] = &nss_port2_rx_clk_src.clkr,
4221 [NSS_PORT2_TX_CLK_SRC] = &nss_port2_tx_clk_src.clkr,
4222 [NSS_PORT3_RX_CLK_SRC] = &nss_port3_rx_clk_src.clkr,
4223 [NSS_PORT3_TX_CLK_SRC] = &nss_port3_tx_clk_src.clkr,
4224 [NSS_PORT4_RX_CLK_SRC] = &nss_port4_rx_clk_src.clkr,
4225 [NSS_PORT4_TX_CLK_SRC] = &nss_port4_tx_clk_src.clkr,
4226 [NSS_PORT5_RX_DIV_CLK_SRC] = &nss_port5_rx_div_clk_src.clkr,
4227 [NSS_PORT5_TX_DIV_CLK_SRC] = &nss_port5_tx_div_clk_src.clkr,
4228 [APSS_AXI_CLK_SRC] = &apss_axi_clk_src.clkr,
4229 [NSS_CRYPTO_CLK_SRC] = &nss_crypto_clk_src.clkr,
4230 [NSS_PORT1_RX_DIV_CLK_SRC] = &nss_port1_rx_div_clk_src.clkr,
4231 [NSS_PORT1_TX_DIV_CLK_SRC] = &nss_port1_tx_div_clk_src.clkr,
4232 [NSS_PORT2_RX_DIV_CLK_SRC] = &nss_port2_rx_div_clk_src.clkr,
4233 [NSS_PORT2_TX_DIV_CLK_SRC] = &nss_port2_tx_div_clk_src.clkr,
4234 [NSS_PORT3_RX_DIV_CLK_SRC] = &nss_port3_rx_div_clk_src.clkr,
4235 [NSS_PORT3_TX_DIV_CLK_SRC] = &nss_port3_tx_div_clk_src.clkr,
4236 [NSS_PORT4_RX_DIV_CLK_SRC] = &nss_port4_rx_div_clk_src.clkr,
4237 [NSS_PORT4_TX_DIV_CLK_SRC] = &nss_port4_tx_div_clk_src.clkr,
4238 [NSS_UBI0_CLK_SRC] = &nss_ubi0_clk_src.clkr,
4239 [ADSS_PWM_CLK_SRC] = &adss_pwm_clk_src.clkr,
4240 [BLSP1_QUP1_I2C_APPS_CLK_SRC] = &blsp1_qup1_i2c_apps_clk_src.clkr,
4241 [BLSP1_QUP1_SPI_APPS_CLK_SRC] = &blsp1_qup1_spi_apps_clk_src.clkr,
4242 [BLSP1_QUP2_I2C_APPS_CLK_SRC] = &blsp1_qup2_i2c_apps_clk_src.clkr,
4243 [BLSP1_QUP2_SPI_APPS_CLK_SRC] = &blsp1_qup2_spi_apps_clk_src.clkr,
4244 [BLSP1_QUP3_I2C_APPS_CLK_SRC] = &blsp1_qup3_i2c_apps_clk_src.clkr,
4245 [BLSP1_QUP3_SPI_APPS_CLK_SRC] = &blsp1_qup3_spi_apps_clk_src.clkr,
4246 [BLSP1_QUP4_I2C_APPS_CLK_SRC] = &blsp1_qup4_i2c_apps_clk_src.clkr,
4247 [BLSP1_QUP4_SPI_APPS_CLK_SRC] = &blsp1_qup4_spi_apps_clk_src.clkr,
4248 [BLSP1_QUP5_I2C_APPS_CLK_SRC] = &blsp1_qup5_i2c_apps_clk_src.clkr,
4249 [BLSP1_QUP5_SPI_APPS_CLK_SRC] = &blsp1_qup5_spi_apps_clk_src.clkr,
4250 [BLSP1_QUP6_I2C_APPS_CLK_SRC] = &blsp1_qup6_i2c_apps_clk_src.clkr,
4251 [BLSP1_QUP6_SPI_APPS_CLK_SRC] = &blsp1_qup6_spi_apps_clk_src.clkr,
4252 [BLSP1_UART1_APPS_CLK_SRC] = &blsp1_uart1_apps_clk_src.clkr,
4253 [BLSP1_UART2_APPS_CLK_SRC] = &blsp1_uart2_apps_clk_src.clkr,
4254 [BLSP1_UART3_APPS_CLK_SRC] = &blsp1_uart3_apps_clk_src.clkr,
4255 [BLSP1_UART4_APPS_CLK_SRC] = &blsp1_uart4_apps_clk_src.clkr,
4256 [BLSP1_UART5_APPS_CLK_SRC] = &blsp1_uart5_apps_clk_src.clkr,
4257 [BLSP1_UART6_APPS_CLK_SRC] = &blsp1_uart6_apps_clk_src.clkr,
4258 [CRYPTO_CLK_SRC] = &crypto_clk_src.clkr,
4259 [GP1_CLK_SRC] = &gp1_clk_src.clkr,
4260 [GP2_CLK_SRC] = &gp2_clk_src.clkr,
4261 [GP3_CLK_SRC] = &gp3_clk_src.clkr,
4262 [NSS_UBI0_DIV_CLK_SRC] = &nss_ubi0_div_clk_src.clkr,
4263 [PCIE0_AUX_CLK_SRC] = &pcie0_aux_clk_src.clkr,
4264 [PCIE0_PIPE_CLK_SRC] = &pcie0_pipe_clk_src.clkr,
4265 [SDCC1_APPS_CLK_SRC] = &sdcc1_apps_clk_src.clkr,
4266 [USB0_AUX_CLK_SRC] = &usb0_aux_clk_src.clkr,
4267 [USB0_MOCK_UTMI_CLK_SRC] = &usb0_mock_utmi_clk_src.clkr,
4268 [USB0_PIPE_CLK_SRC] = &usb0_pipe_clk_src.clkr,
4269 [USB1_MOCK_UTMI_CLK_SRC] = &usb1_mock_utmi_clk_src.clkr,
4270 [GCC_ADSS_PWM_CLK] = &gcc_adss_pwm_clk.clkr,
4271 [GCC_APSS_AHB_CLK] = &gcc_apss_ahb_clk.clkr,
4272 [GCC_APSS_AXI_CLK] = &gcc_apss_axi_clk.clkr,
4273 [GCC_BLSP1_AHB_CLK] = &gcc_blsp1_ahb_clk.clkr,
4274 [GCC_BLSP1_QUP1_I2C_APPS_CLK] = &gcc_blsp1_qup1_i2c_apps_clk.clkr,
4275 [GCC_BLSP1_QUP1_SPI_APPS_CLK] = &gcc_blsp1_qup1_spi_apps_clk.clkr,
4276 [GCC_BLSP1_QUP2_I2C_APPS_CLK] = &gcc_blsp1_qup2_i2c_apps_clk.clkr,
4277 [GCC_BLSP1_QUP2_SPI_APPS_CLK] = &gcc_blsp1_qup2_spi_apps_clk.clkr,
4278 [GCC_BLSP1_QUP3_I2C_APPS_CLK] = &gcc_blsp1_qup3_i2c_apps_clk.clkr,
4279 [GCC_BLSP1_QUP3_SPI_APPS_CLK] = &gcc_blsp1_qup3_spi_apps_clk.clkr,
4280 [GCC_BLSP1_QUP4_I2C_APPS_CLK] = &gcc_blsp1_qup4_i2c_apps_clk.clkr,
4281 [GCC_BLSP1_QUP4_SPI_APPS_CLK] = &gcc_blsp1_qup4_spi_apps_clk.clkr,
4282 [GCC_BLSP1_QUP5_I2C_APPS_CLK] = &gcc_blsp1_qup5_i2c_apps_clk.clkr,
4283 [GCC_BLSP1_QUP5_SPI_APPS_CLK] = &gcc_blsp1_qup5_spi_apps_clk.clkr,
4284 [GCC_BLSP1_QUP6_SPI_APPS_CLK] = &gcc_blsp1_qup6_spi_apps_clk.clkr,
4285 [GCC_BLSP1_UART1_APPS_CLK] = &gcc_blsp1_uart1_apps_clk.clkr,
4286 [GCC_BLSP1_UART2_APPS_CLK] = &gcc_blsp1_uart2_apps_clk.clkr,
4287 [GCC_BLSP1_UART3_APPS_CLK] = &gcc_blsp1_uart3_apps_clk.clkr,
4288 [GCC_BLSP1_UART4_APPS_CLK] = &gcc_blsp1_uart4_apps_clk.clkr,
4289 [GCC_BLSP1_UART5_APPS_CLK] = &gcc_blsp1_uart5_apps_clk.clkr,
4290 [GCC_BLSP1_UART6_APPS_CLK] = &gcc_blsp1_uart6_apps_clk.clkr,
4291 [GCC_CRYPTO_AHB_CLK] = &gcc_crypto_ahb_clk.clkr,
4292 [GCC_CRYPTO_AXI_CLK] = &gcc_crypto_axi_clk.clkr,
4293 [GCC_CRYPTO_CLK] = &gcc_crypto_clk.clkr,
4294 [GCC_XO_CLK] = &gcc_xo_clk.clkr,
4295 [GCC_GP1_CLK] = &gcc_gp1_clk.clkr,
4296 [GCC_GP2_CLK] = &gcc_gp2_clk.clkr,
4297 [GCC_GP3_CLK] = &gcc_gp3_clk.clkr,
4298 [GCC_MDIO_AHB_CLK] = &gcc_mdio_ahb_clk.clkr,
4299 [GCC_CRYPTO_PPE_CLK] = &gcc_crypto_ppe_clk.clkr,
4300 [GCC_NSS_CE_APB_CLK] = &gcc_nss_ce_apb_clk.clkr,
4301 [GCC_NSS_CE_AXI_CLK] = &gcc_nss_ce_axi_clk.clkr,
4302 [GCC_NSS_CFG_CLK] = &gcc_nss_cfg_clk.clkr,
4303 [GCC_NSS_CRYPTO_CLK] = &gcc_nss_crypto_clk.clkr,
4304 [GCC_NSS_CSR_CLK] = &gcc_nss_csr_clk.clkr,
4305 [GCC_NSS_EDMA_CFG_CLK] = &gcc_nss_edma_cfg_clk.clkr,
4306 [GCC_NSS_EDMA_CLK] = &gcc_nss_edma_clk.clkr,
4307 [GCC_NSS_NOC_CLK] = &gcc_nss_noc_clk.clkr,
4308 [GCC_UBI0_UTCM_CLK] = &gcc_ubi0_utcm_clk.clkr,
4309 [GCC_SNOC_NSSNOC_CLK] = &gcc_snoc_nssnoc_clk.clkr,
4310 [GCC_NSS_PORT1_RX_CLK] = &gcc_nss_port1_rx_clk.clkr,
4311 [GCC_NSS_PORT1_TX_CLK] = &gcc_nss_port1_tx_clk.clkr,
4312 [GCC_NSS_PORT2_RX_CLK] = &gcc_nss_port2_rx_clk.clkr,
4313 [GCC_NSS_PORT2_TX_CLK] = &gcc_nss_port2_tx_clk.clkr,
4314 [GCC_NSS_PORT3_RX_CLK] = &gcc_nss_port3_rx_clk.clkr,
4315 [GCC_NSS_PORT3_TX_CLK] = &gcc_nss_port3_tx_clk.clkr,
4316 [GCC_NSS_PORT4_RX_CLK] = &gcc_nss_port4_rx_clk.clkr,
4317 [GCC_NSS_PORT4_TX_CLK] = &gcc_nss_port4_tx_clk.clkr,
4318 [GCC_NSS_PORT5_RX_CLK] = &gcc_nss_port5_rx_clk.clkr,
4319 [GCC_NSS_PORT5_TX_CLK] = &gcc_nss_port5_tx_clk.clkr,
4320 [GCC_NSS_PPE_CFG_CLK] = &gcc_nss_ppe_cfg_clk.clkr,
4321 [GCC_NSS_PPE_CLK] = &gcc_nss_ppe_clk.clkr,
4322 [GCC_NSS_PPE_IPE_CLK] = &gcc_nss_ppe_ipe_clk.clkr,
4323 [GCC_NSS_PTP_REF_CLK] = &gcc_nss_ptp_ref_clk.clkr,
4324 [GCC_NSSNOC_CE_APB_CLK] = &gcc_nssnoc_ce_apb_clk.clkr,
4325 [GCC_NSSNOC_CE_AXI_CLK] = &gcc_nssnoc_ce_axi_clk.clkr,
4326 [GCC_NSSNOC_CRYPTO_CLK] = &gcc_nssnoc_crypto_clk.clkr,
4327 [GCC_NSSNOC_PPE_CFG_CLK] = &gcc_nssnoc_ppe_cfg_clk.clkr,
4328 [GCC_NSSNOC_PPE_CLK] = &gcc_nssnoc_ppe_clk.clkr,
4329 [GCC_NSSNOC_QOSGEN_REF_CLK] = &gcc_nssnoc_qosgen_ref_clk.clkr,
4330 [GCC_NSSNOC_SNOC_CLK] = &gcc_nssnoc_snoc_clk.clkr,
4331 [GCC_NSSNOC_TIMEOUT_REF_CLK] = &gcc_nssnoc_timeout_ref_clk.clkr,
4332 [GCC_NSSNOC_UBI0_AHB_CLK] = &gcc_nssnoc_ubi0_ahb_clk.clkr,
4333 [GCC_PORT1_MAC_CLK] = &gcc_port1_mac_clk.clkr,
4334 [GCC_PORT2_MAC_CLK] = &gcc_port2_mac_clk.clkr,
4335 [GCC_PORT3_MAC_CLK] = &gcc_port3_mac_clk.clkr,
4336 [GCC_PORT4_MAC_CLK] = &gcc_port4_mac_clk.clkr,
4337 [GCC_PORT5_MAC_CLK] = &gcc_port5_mac_clk.clkr,
4338 [GCC_UBI0_AHB_CLK] = &gcc_ubi0_ahb_clk.clkr,
4339 [GCC_UBI0_AXI_CLK] = &gcc_ubi0_axi_clk.clkr,
4340 [GCC_UBI0_NC_AXI_CLK] = &gcc_ubi0_nc_axi_clk.clkr,
4341 [GCC_UBI0_CORE_CLK] = &gcc_ubi0_core_clk.clkr,
4342 [GCC_PCIE0_AHB_CLK] = &gcc_pcie0_ahb_clk.clkr,
4343 [GCC_PCIE0_AUX_CLK] = &gcc_pcie0_aux_clk.clkr,
4344 [GCC_PCIE0_AXI_M_CLK] = &gcc_pcie0_axi_m_clk.clkr,
4345 [GCC_PCIE0_AXI_S_CLK] = &gcc_pcie0_axi_s_clk.clkr,
4346 [GCC_SYS_NOC_PCIE0_AXI_CLK] = &gcc_sys_noc_pcie0_axi_clk.clkr,
4347 [GCC_PCIE0_PIPE_CLK] = &gcc_pcie0_pipe_clk.clkr,
4348 [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr,
4349 [GCC_QDSS_DAP_CLK] = &gcc_qdss_dap_clk.clkr,
4350 [GCC_QPIC_AHB_CLK] = &gcc_qpic_ahb_clk.clkr,
4351 [GCC_QPIC_CLK] = &gcc_qpic_clk.clkr,
4352 [GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr,
4353 [GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr,
4354 [GCC_UNIPHY0_AHB_CLK] = &gcc_uniphy0_ahb_clk.clkr,
4355 [GCC_UNIPHY0_PORT1_RX_CLK] = &gcc_uniphy0_port1_rx_clk.clkr,
4356 [GCC_UNIPHY0_PORT1_TX_CLK] = &gcc_uniphy0_port1_tx_clk.clkr,
4357 [GCC_UNIPHY0_PORT2_RX_CLK] = &gcc_uniphy0_port2_rx_clk.clkr,
4358 [GCC_UNIPHY0_PORT2_TX_CLK] = &gcc_uniphy0_port2_tx_clk.clkr,
4359 [GCC_UNIPHY0_PORT3_RX_CLK] = &gcc_uniphy0_port3_rx_clk.clkr,
4360 [GCC_UNIPHY0_PORT3_TX_CLK] = &gcc_uniphy0_port3_tx_clk.clkr,
4361 [GCC_UNIPHY0_PORT4_RX_CLK] = &gcc_uniphy0_port4_rx_clk.clkr,
4362 [GCC_UNIPHY0_PORT4_TX_CLK] = &gcc_uniphy0_port4_tx_clk.clkr,
4363 [GCC_UNIPHY0_PORT5_RX_CLK] = &gcc_uniphy0_port5_rx_clk.clkr,
4364 [GCC_UNIPHY0_PORT5_TX_CLK] = &gcc_uniphy0_port5_tx_clk.clkr,
4365 [GCC_UNIPHY0_SYS_CLK] = &gcc_uniphy0_sys_clk.clkr,
4366 [GCC_UNIPHY1_AHB_CLK] = &gcc_uniphy1_ahb_clk.clkr,
4367 [GCC_UNIPHY1_PORT5_RX_CLK] = &gcc_uniphy1_port5_rx_clk.clkr,
4368 [GCC_UNIPHY1_PORT5_TX_CLK] = &gcc_uniphy1_port5_tx_clk.clkr,
4369 [GCC_UNIPHY1_SYS_CLK] = &gcc_uniphy1_sys_clk.clkr,
4370 [GCC_USB0_AUX_CLK] = &gcc_usb0_aux_clk.clkr,
4371 [GCC_SYS_NOC_USB0_AXI_CLK] = &gcc_sys_noc_usb0_axi_clk.clkr,
4372 [GCC_SNOC_BUS_TIMEOUT2_AHB_CLK] = &gcc_snoc_bus_timeout2_ahb_clk.clkr,
4373 [GCC_USB0_MASTER_CLK] = &gcc_usb0_master_clk.clkr,
4374 [GCC_USB0_MOCK_UTMI_CLK] = &gcc_usb0_mock_utmi_clk.clkr,
4375 [GCC_USB0_PHY_CFG_AHB_CLK] = &gcc_usb0_phy_cfg_ahb_clk.clkr,
4376 [GCC_USB0_PIPE_CLK] = &gcc_usb0_pipe_clk.clkr,
4377 [GCC_USB0_SLEEP_CLK] = &gcc_usb0_sleep_clk.clkr,
4378 [GCC_USB1_MASTER_CLK] = &gcc_usb1_master_clk.clkr,
4379 [GCC_USB1_MOCK_UTMI_CLK] = &gcc_usb1_mock_utmi_clk.clkr,
4380 [GCC_USB1_PHY_CFG_AHB_CLK] = &gcc_usb1_phy_cfg_ahb_clk.clkr,
4381 [GCC_USB1_SLEEP_CLK] = &gcc_usb1_sleep_clk.clkr,
4382 [GCC_CMN_12GPLL_AHB_CLK] = &gcc_cmn_12gpll_ahb_clk.clkr,
4383 [GCC_CMN_12GPLL_SYS_CLK] = &gcc_cmn_12gpll_sys_clk.clkr,
4384 [GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr,
4385 [SDCC1_ICE_CORE_CLK_SRC] = &sdcc1_ice_core_clk_src.clkr,
4386 [GCC_DCC_CLK] = &gcc_dcc_clk.clkr,
4387 [PCIE0_RCHNG_CLK_SRC] = &pcie0_rchng_clk_src.clkr,
4388 [GCC_PCIE0_AXI_S_BRIDGE_CLK] = &gcc_pcie0_axi_s_bridge_clk.clkr,
4389 [PCIE0_RCHNG_CLK] = &gcc_pcie0_rchng_clk.clkr,
4390 [WCSS_AHB_CLK_SRC] = &wcss_ahb_clk_src.clkr,
4391 [Q6_AXI_CLK_SRC] = &q6_axi_clk_src.clkr,
4392 [RBCPR_WCSS_CLK_SRC] = &rbcpr_wcss_clk_src.clkr,
4393 [GCC_LPASS_CORE_AXIM_CLK] = &gcc_lpass_core_axim_clk.clkr,
4394 [LPASS_CORE_AXIM_CLK_SRC] = &lpass_core_axim_clk_src.clkr,
4395 [GCC_LPASS_SNOC_CFG_CLK] = &gcc_lpass_snoc_cfg_clk.clkr,
4396 [LPASS_SNOC_CFG_CLK_SRC] = &lpass_snoc_cfg_clk_src.clkr,
4397 [GCC_LPASS_Q6_AXIM_CLK] = &gcc_lpass_q6_axim_clk.clkr,
4398 [LPASS_Q6_AXIM_CLK_SRC] = &lpass_q6_axim_clk_src.clkr,
4399 [GCC_LPASS_Q6_ATBM_AT_CLK] = &gcc_lpass_q6_atbm_at_clk.clkr,
4400 [GCC_LPASS_Q6_PCLKDBG_CLK] = &gcc_lpass_q6_pclkdbg_clk.clkr,
4401 [GCC_LPASS_Q6SS_TSCTR_1TO2_CLK] = &gcc_lpass_q6ss_tsctr_1to2_clk.clkr,
4402 [GCC_LPASS_Q6SS_TRIG_CLK] = &gcc_lpass_q6ss_trig_clk.clkr,
4403 [GCC_LPASS_TBU_CLK] = &gcc_lpass_tbu_clk.clkr,
4404 [GCC_PCNOC_LPASS_CLK] = &gcc_pcnoc_lpass_clk.clkr,
4405 [GCC_MEM_NOC_UBI32_CLK] = &gcc_mem_noc_ubi32_clk.clkr,
4406 [GCC_MEM_NOC_LPASS_CLK] = &gcc_mem_noc_lpass_clk.clkr,
4407 [GCC_SNOC_LPASS_CFG_CLK] = &gcc_snoc_lpass_cfg_clk.clkr,
4408 [QDSS_STM_CLK_SRC] = &qdss_stm_clk_src.clkr,
4409 [QDSS_TRACECLKIN_CLK_SRC] = &qdss_traceclkin_clk_src.clkr,
4410 };
4411
4412 static const struct qcom_reset_map gcc_ipq6018_resets[] = {
4413 [GCC_BLSP1_BCR] = { 0x01000, 0 },
4414 [GCC_BLSP1_QUP1_BCR] = { 0x02000, 0 },
4415 [GCC_BLSP1_UART1_BCR] = { 0x02038, 0 },
4416 [GCC_BLSP1_QUP2_BCR] = { 0x03008, 0 },
4417 [GCC_BLSP1_UART2_BCR] = { 0x03028, 0 },
4418 [GCC_BLSP1_QUP3_BCR] = { 0x04008, 0 },
4419 [GCC_BLSP1_UART3_BCR] = { 0x04028, 0 },
4420 [GCC_BLSP1_QUP4_BCR] = { 0x05008, 0 },
4421 [GCC_BLSP1_UART4_BCR] = { 0x05028, 0 },
4422 [GCC_BLSP1_QUP5_BCR] = { 0x06008, 0 },
4423 [GCC_BLSP1_UART5_BCR] = { 0x06028, 0 },
4424 [GCC_BLSP1_QUP6_BCR] = { 0x07008, 0 },
4425 [GCC_BLSP1_UART6_BCR] = { 0x07028, 0 },
4426 [GCC_IMEM_BCR] = { 0x0e000, 0 },
4427 [GCC_SMMU_BCR] = { 0x12000, 0 },
4428 [GCC_APSS_TCU_BCR] = { 0x12050, 0 },
4429 [GCC_SMMU_XPU_BCR] = { 0x12054, 0 },
4430 [GCC_PCNOC_TBU_BCR] = { 0x12058, 0 },
4431 [GCC_SMMU_CFG_BCR] = { 0x1208c, 0 },
4432 [GCC_PRNG_BCR] = { 0x13000, 0 },
4433 [GCC_BOOT_ROM_BCR] = { 0x13008, 0 },
4434 [GCC_CRYPTO_BCR] = { 0x16000, 0 },
4435 [GCC_WCSS_BCR] = { 0x18000, 0 },
4436 [GCC_WCSS_Q6_BCR] = { 0x18100, 0 },
4437 [GCC_NSS_BCR] = { 0x19000, 0 },
4438 [GCC_SEC_CTRL_BCR] = { 0x1a000, 0 },
4439 [GCC_ADSS_BCR] = { 0x1c000, 0 },
4440 [GCC_DDRSS_BCR] = { 0x1e000, 0 },
4441 [GCC_SYSTEM_NOC_BCR] = { 0x26000, 0 },
4442 [GCC_PCNOC_BCR] = { 0x27018, 0 },
4443 [GCC_TCSR_BCR] = { 0x28000, 0 },
4444 [GCC_QDSS_BCR] = { 0x29000, 0 },
4445 [GCC_DCD_BCR] = { 0x2a000, 0 },
4446 [GCC_MSG_RAM_BCR] = { 0x2b000, 0 },
4447 [GCC_MPM_BCR] = { 0x2c000, 0 },
4448 [GCC_SPDM_BCR] = { 0x2f000, 0 },
4449 [GCC_RBCPR_BCR] = { 0x33000, 0 },
4450 [GCC_RBCPR_MX_BCR] = { 0x33014, 0 },
4451 [GCC_TLMM_BCR] = { 0x34000, 0 },
4452 [GCC_RBCPR_WCSS_BCR] = { 0x3a000, 0 },
4453 [GCC_USB0_PHY_BCR] = { 0x3e034, 0 },
4454 [GCC_USB3PHY_0_PHY_BCR] = { 0x3e03c, 0 },
4455 [GCC_USB0_BCR] = { 0x3e070, 0 },
4456 [GCC_USB1_BCR] = { 0x3f070, 0 },
4457 [GCC_QUSB2_0_PHY_BCR] = { 0x4103c, 0 },
4458 [GCC_QUSB2_1_PHY_BCR] = { 0x41040, 0 },
4459 [GCC_SDCC1_BCR] = { 0x42000, 0 },
4460 [GCC_SNOC_BUS_TIMEOUT0_BCR] = { 0x47000, 0 },
4461 [GCC_SNOC_BUS_TIMEOUT1_BCR] = { 0x47008, 0 },
4462 [GCC_SNOC_BUS_TIMEOUT2_BCR] = { 0x47010, 0 },
4463 [GCC_PCNOC_BUS_TIMEOUT0_BCR] = { 0x48000, 0 },
4464 [GCC_PCNOC_BUS_TIMEOUT1_BCR] = { 0x48008, 0 },
4465 [GCC_PCNOC_BUS_TIMEOUT2_BCR] = { 0x48010, 0 },
4466 [GCC_PCNOC_BUS_TIMEOUT3_BCR] = { 0x48018, 0 },
4467 [GCC_PCNOC_BUS_TIMEOUT4_BCR] = { 0x48020, 0 },
4468 [GCC_PCNOC_BUS_TIMEOUT5_BCR] = { 0x48028, 0 },
4469 [GCC_PCNOC_BUS_TIMEOUT6_BCR] = { 0x48030, 0 },
4470 [GCC_PCNOC_BUS_TIMEOUT7_BCR] = { 0x48038, 0 },
4471 [GCC_PCNOC_BUS_TIMEOUT8_BCR] = { 0x48040, 0 },
4472 [GCC_PCNOC_BUS_TIMEOUT9_BCR] = { 0x48048, 0 },
4473 [GCC_UNIPHY0_BCR] = { 0x56000, 0 },
4474 [GCC_UNIPHY1_BCR] = { 0x56100, 0 },
4475 [GCC_CMN_12GPLL_BCR] = { 0x56300, 0 },
4476 [GCC_QPIC_BCR] = { 0x57018, 0 },
4477 [GCC_MDIO_BCR] = { 0x58000, 0 },
4478 [GCC_WCSS_CORE_TBU_BCR] = { 0x66000, 0 },
4479 [GCC_WCSS_Q6_TBU_BCR] = { 0x67000, 0 },
4480 [GCC_USB0_TBU_BCR] = { 0x6a000, 0 },
4481 [GCC_PCIE0_TBU_BCR] = { 0x6b000, 0 },
4482 [GCC_NSS_NOC_TBU_BCR] = { 0x6e000, 0 },
4483 [GCC_PCIE0_BCR] = { 0x75004, 0 },
4484 [GCC_PCIE0_PHY_BCR] = { 0x75038, 0 },
4485 [GCC_PCIE0PHY_PHY_BCR] = { 0x7503c, 0 },
4486 [GCC_PCIE0_LINK_DOWN_BCR] = { 0x75044, 0 },
4487 [GCC_DCC_BCR] = { 0x77000, 0 },
4488 [GCC_APC0_VOLTAGE_DROOP_DETECTOR_BCR] = { 0x78000, 0 },
4489 [GCC_SMMU_CATS_BCR] = { 0x7c000, 0 },
4490 [GCC_UBI0_AXI_ARES] = { 0x68010, 0 },
4491 [GCC_UBI0_AHB_ARES] = { 0x68010, 1 },
4492 [GCC_UBI0_NC_AXI_ARES] = { 0x68010, 2 },
4493 [GCC_UBI0_DBG_ARES] = { 0x68010, 3 },
4494 [GCC_UBI0_CORE_CLAMP_ENABLE] = { 0x68010, 4 },
4495 [GCC_UBI0_CLKRST_CLAMP_ENABLE] = { 0x68010, 5 },
4496 [GCC_UBI0_UTCM_ARES] = { 0x68010, 6 },
4497 [GCC_UBI0_CORE_ARES] = { 0x68010, 7 },
4498 [GCC_NSS_CFG_ARES] = { 0x68010, 16 },
4499 [GCC_NSS_NOC_ARES] = { 0x68010, 18 },
4500 [GCC_NSS_CRYPTO_ARES] = { 0x68010, 19 },
4501 [GCC_NSS_CSR_ARES] = { 0x68010, 20 },
4502 [GCC_NSS_CE_APB_ARES] = { 0x68010, 21 },
4503 [GCC_NSS_CE_AXI_ARES] = { 0x68010, 22 },
4504 [GCC_NSSNOC_CE_APB_ARES] = { 0x68010, 23 },
4505 [GCC_NSSNOC_CE_AXI_ARES] = { 0x68010, 24 },
4506 [GCC_NSSNOC_UBI0_AHB_ARES] = { 0x68010, 25 },
4507 [GCC_NSSNOC_SNOC_ARES] = { 0x68010, 27 },
4508 [GCC_NSSNOC_CRYPTO_ARES] = { 0x68010, 28 },
4509 [GCC_NSSNOC_ATB_ARES] = { 0x68010, 29 },
4510 [GCC_NSSNOC_QOSGEN_REF_ARES] = { 0x68010, 30 },
4511 [GCC_NSSNOC_TIMEOUT_REF_ARES] = { 0x68010, 31 },
4512 [GCC_PCIE0_PIPE_ARES] = { 0x75040, 0 },
4513 [GCC_PCIE0_SLEEP_ARES] = { 0x75040, 1 },
4514 [GCC_PCIE0_CORE_STICKY_ARES] = { 0x75040, 2 },
4515 [GCC_PCIE0_AXI_MASTER_ARES] = { 0x75040, 3 },
4516 [GCC_PCIE0_AXI_SLAVE_ARES] = { 0x75040, 4 },
4517 [GCC_PCIE0_AHB_ARES] = { 0x75040, 5 },
4518 [GCC_PCIE0_AXI_MASTER_STICKY_ARES] = { 0x75040, 6 },
4519 [GCC_PCIE0_AXI_SLAVE_STICKY_ARES] = { 0x75040, 7 },
4520 [GCC_PPE_FULL_RESET] = { 0x68014, 0 },
4521 [GCC_UNIPHY0_SOFT_RESET] = { 0x56004, 0 },
4522 [GCC_UNIPHY0_XPCS_RESET] = { 0x56004, 2 },
4523 [GCC_UNIPHY1_SOFT_RESET] = { 0x56104, 0 },
4524 [GCC_UNIPHY1_XPCS_RESET] = { 0x56104, 2 },
4525 [GCC_EDMA_HW_RESET] = { 0x68014, 0 },
4526 [GCC_NSSPORT1_RESET] = { 0x68014, 0 },
4527 [GCC_NSSPORT2_RESET] = { 0x68014, 0 },
4528 [GCC_NSSPORT3_RESET] = { 0x68014, 0 },
4529 [GCC_NSSPORT4_RESET] = { 0x68014, 0 },
4530 [GCC_NSSPORT5_RESET] = { 0x68014, 0 },
4531 [GCC_UNIPHY0_PORT1_ARES] = { 0x56004, 0 },
4532 [GCC_UNIPHY0_PORT2_ARES] = { 0x56004, 0 },
4533 [GCC_UNIPHY0_PORT3_ARES] = { 0x56004, 0 },
4534 [GCC_UNIPHY0_PORT4_ARES] = { 0x56004, 0 },
4535 [GCC_UNIPHY0_PORT5_ARES] = { 0x56004, 0 },
4536 [GCC_UNIPHY0_PORT_4_5_RESET] = { 0x56004, 0 },
4537 [GCC_UNIPHY0_PORT_4_RESET] = { 0x56004, 0 },
4538 [GCC_LPASS_BCR] = {0x1F000, 0},
4539 [GCC_UBI32_TBU_BCR] = {0x65000, 0},
4540 [GCC_LPASS_TBU_BCR] = {0x6C000, 0},
4541 [GCC_WCSSAON_RESET] = {0x59010, 0},
4542 [GCC_LPASS_Q6_AXIM_ARES] = {0x1F004, 0},
4543 [GCC_LPASS_Q6SS_TSCTR_1TO2_ARES] = {0x1F004, 1},
4544 [GCC_LPASS_Q6SS_TRIG_ARES] = {0x1F004, 2},
4545 [GCC_LPASS_Q6_ATBM_AT_ARES] = {0x1F004, 3},
4546 [GCC_LPASS_Q6_PCLKDBG_ARES] = {0x1F004, 4},
4547 [GCC_LPASS_CORE_AXIM_ARES] = {0x1F004, 5},
4548 [GCC_LPASS_SNOC_CFG_ARES] = {0x1F004, 6},
4549 [GCC_WCSS_DBG_ARES] = {0x59008, 0},
4550 [GCC_WCSS_ECAHB_ARES] = {0x59008, 1},
4551 [GCC_WCSS_ACMT_ARES] = {0x59008, 2},
4552 [GCC_WCSS_DBG_BDG_ARES] = {0x59008, 3},
4553 [GCC_WCSS_AHB_S_ARES] = {0x59008, 4},
4554 [GCC_WCSS_AXI_M_ARES] = {0x59008, 5},
4555 [GCC_Q6SS_DBG_ARES] = {0x59110, 0},
4556 [GCC_Q6_AHB_S_ARES] = {0x59110, 1},
4557 [GCC_Q6_AHB_ARES] = {0x59110, 2},
4558 [GCC_Q6_AXIM2_ARES] = {0x59110, 3},
4559 [GCC_Q6_AXIM_ARES] = {0x59110, 4},
4560 };
4561
4562 static const struct of_device_id gcc_ipq6018_match_table[] = {
4563 { .compatible = "qcom,gcc-ipq6018" },
4564 { }
4565 };
4566 MODULE_DEVICE_TABLE(of, gcc_ipq6018_match_table);
4567
4568 static const struct regmap_config gcc_ipq6018_regmap_config = {
4569 .reg_bits = 32,
4570 .reg_stride = 4,
4571 .val_bits = 32,
4572 .max_register = 0x7fffc,
4573 .fast_io = true,
4574 };
4575
4576 static const struct qcom_cc_desc gcc_ipq6018_desc = {
4577 .config = &gcc_ipq6018_regmap_config,
4578 .clks = gcc_ipq6018_clks,
4579 .num_clks = ARRAY_SIZE(gcc_ipq6018_clks),
4580 .resets = gcc_ipq6018_resets,
4581 .num_resets = ARRAY_SIZE(gcc_ipq6018_resets),
4582 .clk_hws = gcc_ipq6018_hws,
4583 .num_clk_hws = ARRAY_SIZE(gcc_ipq6018_hws),
4584 };
4585
gcc_ipq6018_probe(struct platform_device * pdev)4586 static int gcc_ipq6018_probe(struct platform_device *pdev)
4587 {
4588 struct regmap *regmap;
4589
4590 regmap = qcom_cc_map(pdev, &gcc_ipq6018_desc);
4591 if (IS_ERR(regmap))
4592 return PTR_ERR(regmap);
4593
4594 /* Disable SW_COLLAPSE for USB0 GDSCR */
4595 regmap_update_bits(regmap, 0x3e078, BIT(0), 0x0);
4596 /* Enable SW_OVERRIDE for USB0 GDSCR */
4597 regmap_update_bits(regmap, 0x3e078, BIT(2), BIT(2));
4598 /* Disable SW_COLLAPSE for USB1 GDSCR */
4599 regmap_update_bits(regmap, 0x3f078, BIT(0), 0x0);
4600 /* Enable SW_OVERRIDE for USB1 GDSCR */
4601 regmap_update_bits(regmap, 0x3f078, BIT(2), BIT(2));
4602
4603 /* SW Workaround for UBI Huyara PLL */
4604 regmap_update_bits(regmap, 0x2501c, BIT(26), BIT(26));
4605
4606 clk_alpha_pll_configure(&ubi32_pll_main, regmap, &ubi32_pll_config);
4607
4608 clk_alpha_pll_configure(&nss_crypto_pll_main, regmap,
4609 &nss_crypto_pll_config);
4610
4611 return qcom_cc_really_probe(pdev, &gcc_ipq6018_desc, regmap);
4612 }
4613
4614 static struct platform_driver gcc_ipq6018_driver = {
4615 .probe = gcc_ipq6018_probe,
4616 .driver = {
4617 .name = "qcom,gcc-ipq6018",
4618 .of_match_table = gcc_ipq6018_match_table,
4619 },
4620 };
4621
gcc_ipq6018_init(void)4622 static int __init gcc_ipq6018_init(void)
4623 {
4624 return platform_driver_register(&gcc_ipq6018_driver);
4625 }
4626 core_initcall(gcc_ipq6018_init);
4627
gcc_ipq6018_exit(void)4628 static void __exit gcc_ipq6018_exit(void)
4629 {
4630 platform_driver_unregister(&gcc_ipq6018_driver);
4631 }
4632 module_exit(gcc_ipq6018_exit);
4633
4634 MODULE_DESCRIPTION("Qualcomm Technologies, Inc. GCC IPQ6018 Driver");
4635 MODULE_LICENSE("GPL v2");
4636