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