2 * Copyright (c) 2013, The Linux Foundation. All rights reserved.
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.
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.
14 #include <linux/kernel.h>
15 #include <linux/bitops.h>
16 #include <linux/err.h>
17 #include <linux/platform_device.h>
18 #include <linux/module.h>
20 #include <linux/of_device.h>
21 #include <linux/clk-provider.h>
22 #include <linux/regmap.h>
23 #include <linux/reset-controller.h>
25 #include <dt-bindings/clock/qcom,gcc-msm8974.h>
26 #include <dt-bindings/reset/qcom,gcc-msm8974.h>
29 #include "clk-regmap.h"
32 #include "clk-branch.h"
43 static const struct parent_map gcc_xo_gpll0_map
[] = {
48 static const char * const gcc_xo_gpll0
[] = {
53 static const struct parent_map gcc_xo_gpll0_gpll4_map
[] = {
59 static const char * const gcc_xo_gpll0_gpll4
[] = {
65 #define F(f, s, h, m, n) { (f), (s), (2 * (h) - 1), (m), (n) }
67 static struct clk_pll gpll0
= {
75 .clkr
.hw
.init
= &(struct clk_init_data
){
77 .parent_names
= (const char *[]){ "xo" },
83 static struct clk_regmap gpll0_vote
= {
85 .enable_mask
= BIT(0),
86 .hw
.init
= &(struct clk_init_data
){
88 .parent_names
= (const char *[]){ "gpll0" },
90 .ops
= &clk_pll_vote_ops
,
94 static struct clk_rcg2 config_noc_clk_src
= {
97 .parent_map
= gcc_xo_gpll0_map
,
98 .clkr
.hw
.init
= &(struct clk_init_data
){
99 .name
= "config_noc_clk_src",
100 .parent_names
= gcc_xo_gpll0
,
102 .ops
= &clk_rcg2_ops
,
106 static struct clk_rcg2 periph_noc_clk_src
= {
109 .parent_map
= gcc_xo_gpll0_map
,
110 .clkr
.hw
.init
= &(struct clk_init_data
){
111 .name
= "periph_noc_clk_src",
112 .parent_names
= gcc_xo_gpll0
,
114 .ops
= &clk_rcg2_ops
,
118 static struct clk_rcg2 system_noc_clk_src
= {
121 .parent_map
= gcc_xo_gpll0_map
,
122 .clkr
.hw
.init
= &(struct clk_init_data
){
123 .name
= "system_noc_clk_src",
124 .parent_names
= gcc_xo_gpll0
,
126 .ops
= &clk_rcg2_ops
,
130 static struct clk_pll gpll1
= {
134 .config_reg
= 0x0054,
136 .status_reg
= 0x005c,
138 .clkr
.hw
.init
= &(struct clk_init_data
){
140 .parent_names
= (const char *[]){ "xo" },
146 static struct clk_regmap gpll1_vote
= {
147 .enable_reg
= 0x1480,
148 .enable_mask
= BIT(1),
149 .hw
.init
= &(struct clk_init_data
){
150 .name
= "gpll1_vote",
151 .parent_names
= (const char *[]){ "gpll1" },
153 .ops
= &clk_pll_vote_ops
,
157 static struct clk_pll gpll4
= {
161 .config_reg
= 0x1dd4,
163 .status_reg
= 0x1ddc,
165 .clkr
.hw
.init
= &(struct clk_init_data
){
167 .parent_names
= (const char *[]){ "xo" },
173 static struct clk_regmap gpll4_vote
= {
174 .enable_reg
= 0x1480,
175 .enable_mask
= BIT(4),
176 .hw
.init
= &(struct clk_init_data
){
177 .name
= "gpll4_vote",
178 .parent_names
= (const char *[]){ "gpll4" },
180 .ops
= &clk_pll_vote_ops
,
184 static const struct freq_tbl ftbl_gcc_usb30_master_clk
[] = {
185 F(125000000, P_GPLL0
, 1, 5, 24),
189 static struct clk_rcg2 usb30_master_clk_src
= {
193 .parent_map
= gcc_xo_gpll0_map
,
194 .freq_tbl
= ftbl_gcc_usb30_master_clk
,
195 .clkr
.hw
.init
= &(struct clk_init_data
){
196 .name
= "usb30_master_clk_src",
197 .parent_names
= gcc_xo_gpll0
,
199 .ops
= &clk_rcg2_ops
,
203 static const struct freq_tbl ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
[] = {
204 F(19200000, P_XO
, 1, 0, 0),
205 F(37500000, P_GPLL0
, 16, 0, 0),
206 F(50000000, P_GPLL0
, 12, 0, 0),
210 static struct clk_rcg2 blsp1_qup1_i2c_apps_clk_src
= {
213 .parent_map
= gcc_xo_gpll0_map
,
214 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
215 .clkr
.hw
.init
= &(struct clk_init_data
){
216 .name
= "blsp1_qup1_i2c_apps_clk_src",
217 .parent_names
= gcc_xo_gpll0
,
219 .ops
= &clk_rcg2_ops
,
223 static const struct freq_tbl ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
[] = {
224 F(960000, P_XO
, 10, 1, 2),
225 F(4800000, P_XO
, 4, 0, 0),
226 F(9600000, P_XO
, 2, 0, 0),
227 F(15000000, P_GPLL0
, 10, 1, 4),
228 F(19200000, P_XO
, 1, 0, 0),
229 F(25000000, P_GPLL0
, 12, 1, 2),
230 F(50000000, P_GPLL0
, 12, 0, 0),
234 static struct clk_rcg2 blsp1_qup1_spi_apps_clk_src
= {
238 .parent_map
= gcc_xo_gpll0_map
,
239 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
240 .clkr
.hw
.init
= &(struct clk_init_data
){
241 .name
= "blsp1_qup1_spi_apps_clk_src",
242 .parent_names
= gcc_xo_gpll0
,
244 .ops
= &clk_rcg2_ops
,
248 static struct clk_rcg2 blsp1_qup2_i2c_apps_clk_src
= {
251 .parent_map
= gcc_xo_gpll0_map
,
252 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
253 .clkr
.hw
.init
= &(struct clk_init_data
){
254 .name
= "blsp1_qup2_i2c_apps_clk_src",
255 .parent_names
= gcc_xo_gpll0
,
257 .ops
= &clk_rcg2_ops
,
261 static struct clk_rcg2 blsp1_qup2_spi_apps_clk_src
= {
265 .parent_map
= gcc_xo_gpll0_map
,
266 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
267 .clkr
.hw
.init
= &(struct clk_init_data
){
268 .name
= "blsp1_qup2_spi_apps_clk_src",
269 .parent_names
= gcc_xo_gpll0
,
271 .ops
= &clk_rcg2_ops
,
275 static struct clk_rcg2 blsp1_qup3_i2c_apps_clk_src
= {
278 .parent_map
= gcc_xo_gpll0_map
,
279 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
280 .clkr
.hw
.init
= &(struct clk_init_data
){
281 .name
= "blsp1_qup3_i2c_apps_clk_src",
282 .parent_names
= gcc_xo_gpll0
,
284 .ops
= &clk_rcg2_ops
,
288 static struct clk_rcg2 blsp1_qup3_spi_apps_clk_src
= {
292 .parent_map
= gcc_xo_gpll0_map
,
293 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
294 .clkr
.hw
.init
= &(struct clk_init_data
){
295 .name
= "blsp1_qup3_spi_apps_clk_src",
296 .parent_names
= gcc_xo_gpll0
,
298 .ops
= &clk_rcg2_ops
,
302 static struct clk_rcg2 blsp1_qup4_i2c_apps_clk_src
= {
305 .parent_map
= gcc_xo_gpll0_map
,
306 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
307 .clkr
.hw
.init
= &(struct clk_init_data
){
308 .name
= "blsp1_qup4_i2c_apps_clk_src",
309 .parent_names
= gcc_xo_gpll0
,
311 .ops
= &clk_rcg2_ops
,
315 static struct clk_rcg2 blsp1_qup4_spi_apps_clk_src
= {
319 .parent_map
= gcc_xo_gpll0_map
,
320 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
321 .clkr
.hw
.init
= &(struct clk_init_data
){
322 .name
= "blsp1_qup4_spi_apps_clk_src",
323 .parent_names
= gcc_xo_gpll0
,
325 .ops
= &clk_rcg2_ops
,
329 static struct clk_rcg2 blsp1_qup5_i2c_apps_clk_src
= {
332 .parent_map
= gcc_xo_gpll0_map
,
333 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
334 .clkr
.hw
.init
= &(struct clk_init_data
){
335 .name
= "blsp1_qup5_i2c_apps_clk_src",
336 .parent_names
= gcc_xo_gpll0
,
338 .ops
= &clk_rcg2_ops
,
342 static struct clk_rcg2 blsp1_qup5_spi_apps_clk_src
= {
346 .parent_map
= gcc_xo_gpll0_map
,
347 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
348 .clkr
.hw
.init
= &(struct clk_init_data
){
349 .name
= "blsp1_qup5_spi_apps_clk_src",
350 .parent_names
= gcc_xo_gpll0
,
352 .ops
= &clk_rcg2_ops
,
356 static struct clk_rcg2 blsp1_qup6_i2c_apps_clk_src
= {
359 .parent_map
= gcc_xo_gpll0_map
,
360 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
361 .clkr
.hw
.init
= &(struct clk_init_data
){
362 .name
= "blsp1_qup6_i2c_apps_clk_src",
363 .parent_names
= gcc_xo_gpll0
,
365 .ops
= &clk_rcg2_ops
,
369 static struct clk_rcg2 blsp1_qup6_spi_apps_clk_src
= {
373 .parent_map
= gcc_xo_gpll0_map
,
374 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
375 .clkr
.hw
.init
= &(struct clk_init_data
){
376 .name
= "blsp1_qup6_spi_apps_clk_src",
377 .parent_names
= gcc_xo_gpll0
,
379 .ops
= &clk_rcg2_ops
,
383 static const struct freq_tbl ftbl_gcc_blsp1_2_uart1_6_apps_clk
[] = {
384 F(3686400, P_GPLL0
, 1, 96, 15625),
385 F(7372800, P_GPLL0
, 1, 192, 15625),
386 F(14745600, P_GPLL0
, 1, 384, 15625),
387 F(16000000, P_GPLL0
, 5, 2, 15),
388 F(19200000, P_XO
, 1, 0, 0),
389 F(24000000, P_GPLL0
, 5, 1, 5),
390 F(32000000, P_GPLL0
, 1, 4, 75),
391 F(40000000, P_GPLL0
, 15, 0, 0),
392 F(46400000, P_GPLL0
, 1, 29, 375),
393 F(48000000, P_GPLL0
, 12.5, 0, 0),
394 F(51200000, P_GPLL0
, 1, 32, 375),
395 F(56000000, P_GPLL0
, 1, 7, 75),
396 F(58982400, P_GPLL0
, 1, 1536, 15625),
397 F(60000000, P_GPLL0
, 10, 0, 0),
398 F(63160000, P_GPLL0
, 9.5, 0, 0),
402 static struct clk_rcg2 blsp1_uart1_apps_clk_src
= {
406 .parent_map
= gcc_xo_gpll0_map
,
407 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
408 .clkr
.hw
.init
= &(struct clk_init_data
){
409 .name
= "blsp1_uart1_apps_clk_src",
410 .parent_names
= gcc_xo_gpll0
,
412 .ops
= &clk_rcg2_ops
,
416 static struct clk_rcg2 blsp1_uart2_apps_clk_src
= {
420 .parent_map
= gcc_xo_gpll0_map
,
421 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
422 .clkr
.hw
.init
= &(struct clk_init_data
){
423 .name
= "blsp1_uart2_apps_clk_src",
424 .parent_names
= gcc_xo_gpll0
,
426 .ops
= &clk_rcg2_ops
,
430 static struct clk_rcg2 blsp1_uart3_apps_clk_src
= {
434 .parent_map
= gcc_xo_gpll0_map
,
435 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
436 .clkr
.hw
.init
= &(struct clk_init_data
){
437 .name
= "blsp1_uart3_apps_clk_src",
438 .parent_names
= gcc_xo_gpll0
,
440 .ops
= &clk_rcg2_ops
,
444 static struct clk_rcg2 blsp1_uart4_apps_clk_src
= {
448 .parent_map
= gcc_xo_gpll0_map
,
449 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
450 .clkr
.hw
.init
= &(struct clk_init_data
){
451 .name
= "blsp1_uart4_apps_clk_src",
452 .parent_names
= gcc_xo_gpll0
,
454 .ops
= &clk_rcg2_ops
,
458 static struct clk_rcg2 blsp1_uart5_apps_clk_src
= {
462 .parent_map
= gcc_xo_gpll0_map
,
463 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
464 .clkr
.hw
.init
= &(struct clk_init_data
){
465 .name
= "blsp1_uart5_apps_clk_src",
466 .parent_names
= gcc_xo_gpll0
,
468 .ops
= &clk_rcg2_ops
,
472 static struct clk_rcg2 blsp1_uart6_apps_clk_src
= {
476 .parent_map
= gcc_xo_gpll0_map
,
477 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
478 .clkr
.hw
.init
= &(struct clk_init_data
){
479 .name
= "blsp1_uart6_apps_clk_src",
480 .parent_names
= gcc_xo_gpll0
,
482 .ops
= &clk_rcg2_ops
,
486 static struct clk_rcg2 blsp2_qup1_i2c_apps_clk_src
= {
489 .parent_map
= gcc_xo_gpll0_map
,
490 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
491 .clkr
.hw
.init
= &(struct clk_init_data
){
492 .name
= "blsp2_qup1_i2c_apps_clk_src",
493 .parent_names
= gcc_xo_gpll0
,
495 .ops
= &clk_rcg2_ops
,
499 static struct clk_rcg2 blsp2_qup1_spi_apps_clk_src
= {
503 .parent_map
= gcc_xo_gpll0_map
,
504 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
505 .clkr
.hw
.init
= &(struct clk_init_data
){
506 .name
= "blsp2_qup1_spi_apps_clk_src",
507 .parent_names
= gcc_xo_gpll0
,
509 .ops
= &clk_rcg2_ops
,
513 static struct clk_rcg2 blsp2_qup2_i2c_apps_clk_src
= {
516 .parent_map
= gcc_xo_gpll0_map
,
517 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
518 .clkr
.hw
.init
= &(struct clk_init_data
){
519 .name
= "blsp2_qup2_i2c_apps_clk_src",
520 .parent_names
= gcc_xo_gpll0
,
522 .ops
= &clk_rcg2_ops
,
526 static struct clk_rcg2 blsp2_qup2_spi_apps_clk_src
= {
530 .parent_map
= gcc_xo_gpll0_map
,
531 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
532 .clkr
.hw
.init
= &(struct clk_init_data
){
533 .name
= "blsp2_qup2_spi_apps_clk_src",
534 .parent_names
= gcc_xo_gpll0
,
536 .ops
= &clk_rcg2_ops
,
540 static struct clk_rcg2 blsp2_qup3_i2c_apps_clk_src
= {
543 .parent_map
= gcc_xo_gpll0_map
,
544 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
545 .clkr
.hw
.init
= &(struct clk_init_data
){
546 .name
= "blsp2_qup3_i2c_apps_clk_src",
547 .parent_names
= gcc_xo_gpll0
,
549 .ops
= &clk_rcg2_ops
,
553 static struct clk_rcg2 blsp2_qup3_spi_apps_clk_src
= {
557 .parent_map
= gcc_xo_gpll0_map
,
558 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
559 .clkr
.hw
.init
= &(struct clk_init_data
){
560 .name
= "blsp2_qup3_spi_apps_clk_src",
561 .parent_names
= gcc_xo_gpll0
,
563 .ops
= &clk_rcg2_ops
,
567 static struct clk_rcg2 blsp2_qup4_i2c_apps_clk_src
= {
570 .parent_map
= gcc_xo_gpll0_map
,
571 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
572 .clkr
.hw
.init
= &(struct clk_init_data
){
573 .name
= "blsp2_qup4_i2c_apps_clk_src",
574 .parent_names
= gcc_xo_gpll0
,
576 .ops
= &clk_rcg2_ops
,
580 static struct clk_rcg2 blsp2_qup4_spi_apps_clk_src
= {
584 .parent_map
= gcc_xo_gpll0_map
,
585 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
586 .clkr
.hw
.init
= &(struct clk_init_data
){
587 .name
= "blsp2_qup4_spi_apps_clk_src",
588 .parent_names
= gcc_xo_gpll0
,
590 .ops
= &clk_rcg2_ops
,
594 static struct clk_rcg2 blsp2_qup5_i2c_apps_clk_src
= {
597 .parent_map
= gcc_xo_gpll0_map
,
598 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
599 .clkr
.hw
.init
= &(struct clk_init_data
){
600 .name
= "blsp2_qup5_i2c_apps_clk_src",
601 .parent_names
= gcc_xo_gpll0
,
603 .ops
= &clk_rcg2_ops
,
607 static struct clk_rcg2 blsp2_qup5_spi_apps_clk_src
= {
611 .parent_map
= gcc_xo_gpll0_map
,
612 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
613 .clkr
.hw
.init
= &(struct clk_init_data
){
614 .name
= "blsp2_qup5_spi_apps_clk_src",
615 .parent_names
= gcc_xo_gpll0
,
617 .ops
= &clk_rcg2_ops
,
621 static struct clk_rcg2 blsp2_qup6_i2c_apps_clk_src
= {
624 .parent_map
= gcc_xo_gpll0_map
,
625 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_i2c_apps_clk
,
626 .clkr
.hw
.init
= &(struct clk_init_data
){
627 .name
= "blsp2_qup6_i2c_apps_clk_src",
628 .parent_names
= gcc_xo_gpll0
,
630 .ops
= &clk_rcg2_ops
,
634 static struct clk_rcg2 blsp2_qup6_spi_apps_clk_src
= {
638 .parent_map
= gcc_xo_gpll0_map
,
639 .freq_tbl
= ftbl_gcc_blsp1_2_qup1_6_spi_apps_clk
,
640 .clkr
.hw
.init
= &(struct clk_init_data
){
641 .name
= "blsp2_qup6_spi_apps_clk_src",
642 .parent_names
= gcc_xo_gpll0
,
644 .ops
= &clk_rcg2_ops
,
648 static struct clk_rcg2 blsp2_uart1_apps_clk_src
= {
652 .parent_map
= gcc_xo_gpll0_map
,
653 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
654 .clkr
.hw
.init
= &(struct clk_init_data
){
655 .name
= "blsp2_uart1_apps_clk_src",
656 .parent_names
= gcc_xo_gpll0
,
658 .ops
= &clk_rcg2_ops
,
662 static struct clk_rcg2 blsp2_uart2_apps_clk_src
= {
666 .parent_map
= gcc_xo_gpll0_map
,
667 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
668 .clkr
.hw
.init
= &(struct clk_init_data
){
669 .name
= "blsp2_uart2_apps_clk_src",
670 .parent_names
= gcc_xo_gpll0
,
672 .ops
= &clk_rcg2_ops
,
676 static struct clk_rcg2 blsp2_uart3_apps_clk_src
= {
680 .parent_map
= gcc_xo_gpll0_map
,
681 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
682 .clkr
.hw
.init
= &(struct clk_init_data
){
683 .name
= "blsp2_uart3_apps_clk_src",
684 .parent_names
= gcc_xo_gpll0
,
686 .ops
= &clk_rcg2_ops
,
690 static struct clk_rcg2 blsp2_uart4_apps_clk_src
= {
694 .parent_map
= gcc_xo_gpll0_map
,
695 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
696 .clkr
.hw
.init
= &(struct clk_init_data
){
697 .name
= "blsp2_uart4_apps_clk_src",
698 .parent_names
= gcc_xo_gpll0
,
700 .ops
= &clk_rcg2_ops
,
704 static struct clk_rcg2 blsp2_uart5_apps_clk_src
= {
708 .parent_map
= gcc_xo_gpll0_map
,
709 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
710 .clkr
.hw
.init
= &(struct clk_init_data
){
711 .name
= "blsp2_uart5_apps_clk_src",
712 .parent_names
= gcc_xo_gpll0
,
714 .ops
= &clk_rcg2_ops
,
718 static struct clk_rcg2 blsp2_uart6_apps_clk_src
= {
722 .parent_map
= gcc_xo_gpll0_map
,
723 .freq_tbl
= ftbl_gcc_blsp1_2_uart1_6_apps_clk
,
724 .clkr
.hw
.init
= &(struct clk_init_data
){
725 .name
= "blsp2_uart6_apps_clk_src",
726 .parent_names
= gcc_xo_gpll0
,
728 .ops
= &clk_rcg2_ops
,
732 static const struct freq_tbl ftbl_gcc_ce1_clk
[] = {
733 F(50000000, P_GPLL0
, 12, 0, 0),
734 F(75000000, P_GPLL0
, 8, 0, 0),
735 F(100000000, P_GPLL0
, 6, 0, 0),
736 F(150000000, P_GPLL0
, 4, 0, 0),
740 static struct clk_rcg2 ce1_clk_src
= {
743 .parent_map
= gcc_xo_gpll0_map
,
744 .freq_tbl
= ftbl_gcc_ce1_clk
,
745 .clkr
.hw
.init
= &(struct clk_init_data
){
746 .name
= "ce1_clk_src",
747 .parent_names
= gcc_xo_gpll0
,
749 .ops
= &clk_rcg2_ops
,
753 static const struct freq_tbl ftbl_gcc_ce2_clk
[] = {
754 F(50000000, P_GPLL0
, 12, 0, 0),
755 F(75000000, P_GPLL0
, 8, 0, 0),
756 F(100000000, P_GPLL0
, 6, 0, 0),
757 F(150000000, P_GPLL0
, 4, 0, 0),
761 static struct clk_rcg2 ce2_clk_src
= {
764 .parent_map
= gcc_xo_gpll0_map
,
765 .freq_tbl
= ftbl_gcc_ce2_clk
,
766 .clkr
.hw
.init
= &(struct clk_init_data
){
767 .name
= "ce2_clk_src",
768 .parent_names
= gcc_xo_gpll0
,
770 .ops
= &clk_rcg2_ops
,
774 static const struct freq_tbl ftbl_gcc_gp_clk
[] = {
775 F(4800000, P_XO
, 4, 0, 0),
776 F(6000000, P_GPLL0
, 10, 1, 10),
777 F(6750000, P_GPLL0
, 1, 1, 89),
778 F(8000000, P_GPLL0
, 15, 1, 5),
779 F(9600000, P_XO
, 2, 0, 0),
780 F(16000000, P_GPLL0
, 1, 2, 75),
781 F(19200000, P_XO
, 1, 0, 0),
782 F(24000000, P_GPLL0
, 5, 1, 5),
787 static struct clk_rcg2 gp1_clk_src
= {
791 .parent_map
= gcc_xo_gpll0_map
,
792 .freq_tbl
= ftbl_gcc_gp_clk
,
793 .clkr
.hw
.init
= &(struct clk_init_data
){
794 .name
= "gp1_clk_src",
795 .parent_names
= gcc_xo_gpll0
,
797 .ops
= &clk_rcg2_ops
,
801 static struct clk_rcg2 gp2_clk_src
= {
805 .parent_map
= gcc_xo_gpll0_map
,
806 .freq_tbl
= ftbl_gcc_gp_clk
,
807 .clkr
.hw
.init
= &(struct clk_init_data
){
808 .name
= "gp2_clk_src",
809 .parent_names
= gcc_xo_gpll0
,
811 .ops
= &clk_rcg2_ops
,
815 static struct clk_rcg2 gp3_clk_src
= {
819 .parent_map
= gcc_xo_gpll0_map
,
820 .freq_tbl
= ftbl_gcc_gp_clk
,
821 .clkr
.hw
.init
= &(struct clk_init_data
){
822 .name
= "gp3_clk_src",
823 .parent_names
= gcc_xo_gpll0
,
825 .ops
= &clk_rcg2_ops
,
829 static const struct freq_tbl ftbl_gcc_pdm2_clk
[] = {
830 F(60000000, P_GPLL0
, 10, 0, 0),
834 static struct clk_rcg2 pdm2_clk_src
= {
837 .parent_map
= gcc_xo_gpll0_map
,
838 .freq_tbl
= ftbl_gcc_pdm2_clk
,
839 .clkr
.hw
.init
= &(struct clk_init_data
){
840 .name
= "pdm2_clk_src",
841 .parent_names
= gcc_xo_gpll0
,
843 .ops
= &clk_rcg2_ops
,
847 static const struct freq_tbl ftbl_gcc_sdcc1_4_apps_clk
[] = {
848 F(144000, P_XO
, 16, 3, 25),
849 F(400000, P_XO
, 12, 1, 4),
850 F(20000000, P_GPLL0
, 15, 1, 2),
851 F(25000000, P_GPLL0
, 12, 1, 2),
852 F(50000000, P_GPLL0
, 12, 0, 0),
853 F(100000000, P_GPLL0
, 6, 0, 0),
854 F(200000000, P_GPLL0
, 3, 0, 0),
858 static const struct freq_tbl ftbl_gcc_sdcc1_apps_clk_pro
[] = {
859 F(144000, P_XO
, 16, 3, 25),
860 F(400000, P_XO
, 12, 1, 4),
861 F(20000000, P_GPLL0
, 15, 1, 2),
862 F(25000000, P_GPLL0
, 12, 1, 2),
863 F(50000000, P_GPLL0
, 12, 0, 0),
864 F(100000000, P_GPLL0
, 6, 0, 0),
865 F(192000000, P_GPLL4
, 4, 0, 0),
866 F(200000000, P_GPLL0
, 3, 0, 0),
867 F(384000000, P_GPLL4
, 2, 0, 0),
871 static struct clk_init_data sdcc1_apps_clk_src_init
= {
872 .name
= "sdcc1_apps_clk_src",
873 .parent_names
= gcc_xo_gpll0
,
875 .ops
= &clk_rcg2_ops
,
878 static struct clk_rcg2 sdcc1_apps_clk_src
= {
882 .parent_map
= gcc_xo_gpll0_map
,
883 .freq_tbl
= ftbl_gcc_sdcc1_4_apps_clk
,
884 .clkr
.hw
.init
= &sdcc1_apps_clk_src_init
,
887 static struct clk_rcg2 sdcc2_apps_clk_src
= {
891 .parent_map
= gcc_xo_gpll0_map
,
892 .freq_tbl
= ftbl_gcc_sdcc1_4_apps_clk
,
893 .clkr
.hw
.init
= &(struct clk_init_data
){
894 .name
= "sdcc2_apps_clk_src",
895 .parent_names
= gcc_xo_gpll0
,
897 .ops
= &clk_rcg2_ops
,
901 static struct clk_rcg2 sdcc3_apps_clk_src
= {
905 .parent_map
= gcc_xo_gpll0_map
,
906 .freq_tbl
= ftbl_gcc_sdcc1_4_apps_clk
,
907 .clkr
.hw
.init
= &(struct clk_init_data
){
908 .name
= "sdcc3_apps_clk_src",
909 .parent_names
= gcc_xo_gpll0
,
911 .ops
= &clk_rcg2_ops
,
915 static struct clk_rcg2 sdcc4_apps_clk_src
= {
919 .parent_map
= gcc_xo_gpll0_map
,
920 .freq_tbl
= ftbl_gcc_sdcc1_4_apps_clk
,
921 .clkr
.hw
.init
= &(struct clk_init_data
){
922 .name
= "sdcc4_apps_clk_src",
923 .parent_names
= gcc_xo_gpll0
,
925 .ops
= &clk_rcg2_ops
,
929 static const struct freq_tbl ftbl_gcc_tsif_ref_clk
[] = {
930 F(105000, P_XO
, 2, 1, 91),
934 static struct clk_rcg2 tsif_ref_clk_src
= {
938 .parent_map
= gcc_xo_gpll0_map
,
939 .freq_tbl
= ftbl_gcc_tsif_ref_clk
,
940 .clkr
.hw
.init
= &(struct clk_init_data
){
941 .name
= "tsif_ref_clk_src",
942 .parent_names
= gcc_xo_gpll0
,
944 .ops
= &clk_rcg2_ops
,
948 static const struct freq_tbl ftbl_gcc_usb30_mock_utmi_clk
[] = {
949 F(60000000, P_GPLL0
, 10, 0, 0),
953 static struct clk_rcg2 usb30_mock_utmi_clk_src
= {
956 .parent_map
= gcc_xo_gpll0_map
,
957 .freq_tbl
= ftbl_gcc_usb30_mock_utmi_clk
,
958 .clkr
.hw
.init
= &(struct clk_init_data
){
959 .name
= "usb30_mock_utmi_clk_src",
960 .parent_names
= gcc_xo_gpll0
,
962 .ops
= &clk_rcg2_ops
,
966 static const struct freq_tbl ftbl_gcc_usb_hs_system_clk
[] = {
967 F(60000000, P_GPLL0
, 10, 0, 0),
968 F(75000000, P_GPLL0
, 8, 0, 0),
972 static struct clk_rcg2 usb_hs_system_clk_src
= {
975 .parent_map
= gcc_xo_gpll0_map
,
976 .freq_tbl
= ftbl_gcc_usb_hs_system_clk
,
977 .clkr
.hw
.init
= &(struct clk_init_data
){
978 .name
= "usb_hs_system_clk_src",
979 .parent_names
= gcc_xo_gpll0
,
981 .ops
= &clk_rcg2_ops
,
985 static const struct freq_tbl ftbl_gcc_usb_hsic_clk
[] = {
986 F(480000000, P_GPLL1
, 1, 0, 0),
990 static const struct parent_map usb_hsic_clk_src_map
[] = {
995 static struct clk_rcg2 usb_hsic_clk_src
= {
998 .parent_map
= usb_hsic_clk_src_map
,
999 .freq_tbl
= ftbl_gcc_usb_hsic_clk
,
1000 .clkr
.hw
.init
= &(struct clk_init_data
){
1001 .name
= "usb_hsic_clk_src",
1002 .parent_names
= (const char *[]){
1007 .ops
= &clk_rcg2_ops
,
1011 static const struct freq_tbl ftbl_gcc_usb_hsic_io_cal_clk
[] = {
1012 F(9600000, P_XO
, 2, 0, 0),
1016 static struct clk_rcg2 usb_hsic_io_cal_clk_src
= {
1019 .parent_map
= gcc_xo_gpll0_map
,
1020 .freq_tbl
= ftbl_gcc_usb_hsic_io_cal_clk
,
1021 .clkr
.hw
.init
= &(struct clk_init_data
){
1022 .name
= "usb_hsic_io_cal_clk_src",
1023 .parent_names
= gcc_xo_gpll0
,
1025 .ops
= &clk_rcg2_ops
,
1029 static const struct freq_tbl ftbl_gcc_usb_hsic_system_clk
[] = {
1030 F(60000000, P_GPLL0
, 10, 0, 0),
1031 F(75000000, P_GPLL0
, 8, 0, 0),
1035 static struct clk_rcg2 usb_hsic_system_clk_src
= {
1038 .parent_map
= gcc_xo_gpll0_map
,
1039 .freq_tbl
= ftbl_gcc_usb_hsic_system_clk
,
1040 .clkr
.hw
.init
= &(struct clk_init_data
){
1041 .name
= "usb_hsic_system_clk_src",
1042 .parent_names
= gcc_xo_gpll0
,
1044 .ops
= &clk_rcg2_ops
,
1048 static struct clk_regmap gcc_mmss_gpll0_clk_src
= {
1049 .enable_reg
= 0x1484,
1050 .enable_mask
= BIT(26),
1051 .hw
.init
= &(struct clk_init_data
){
1052 .name
= "mmss_gpll0_vote",
1053 .parent_names
= (const char *[]){
1057 .ops
= &clk_branch_simple_ops
,
1061 static struct clk_branch gcc_bam_dma_ahb_clk
= {
1063 .halt_check
= BRANCH_HALT_VOTED
,
1065 .enable_reg
= 0x1484,
1066 .enable_mask
= BIT(12),
1067 .hw
.init
= &(struct clk_init_data
){
1068 .name
= "gcc_bam_dma_ahb_clk",
1069 .parent_names
= (const char *[]){
1070 "periph_noc_clk_src",
1073 .ops
= &clk_branch2_ops
,
1078 static struct clk_branch gcc_blsp1_ahb_clk
= {
1080 .halt_check
= BRANCH_HALT_VOTED
,
1082 .enable_reg
= 0x1484,
1083 .enable_mask
= BIT(17),
1084 .hw
.init
= &(struct clk_init_data
){
1085 .name
= "gcc_blsp1_ahb_clk",
1086 .parent_names
= (const char *[]){
1087 "periph_noc_clk_src",
1090 .ops
= &clk_branch2_ops
,
1095 static struct clk_branch gcc_blsp1_qup1_i2c_apps_clk
= {
1098 .enable_reg
= 0x0648,
1099 .enable_mask
= BIT(0),
1100 .hw
.init
= &(struct clk_init_data
){
1101 .name
= "gcc_blsp1_qup1_i2c_apps_clk",
1102 .parent_names
= (const char *[]){
1103 "blsp1_qup1_i2c_apps_clk_src",
1106 .flags
= CLK_SET_RATE_PARENT
,
1107 .ops
= &clk_branch2_ops
,
1112 static struct clk_branch gcc_blsp1_qup1_spi_apps_clk
= {
1115 .enable_reg
= 0x0644,
1116 .enable_mask
= BIT(0),
1117 .hw
.init
= &(struct clk_init_data
){
1118 .name
= "gcc_blsp1_qup1_spi_apps_clk",
1119 .parent_names
= (const char *[]){
1120 "blsp1_qup1_spi_apps_clk_src",
1123 .flags
= CLK_SET_RATE_PARENT
,
1124 .ops
= &clk_branch2_ops
,
1129 static struct clk_branch gcc_blsp1_qup2_i2c_apps_clk
= {
1132 .enable_reg
= 0x06c8,
1133 .enable_mask
= BIT(0),
1134 .hw
.init
= &(struct clk_init_data
){
1135 .name
= "gcc_blsp1_qup2_i2c_apps_clk",
1136 .parent_names
= (const char *[]){
1137 "blsp1_qup2_i2c_apps_clk_src",
1140 .flags
= CLK_SET_RATE_PARENT
,
1141 .ops
= &clk_branch2_ops
,
1146 static struct clk_branch gcc_blsp1_qup2_spi_apps_clk
= {
1149 .enable_reg
= 0x06c4,
1150 .enable_mask
= BIT(0),
1151 .hw
.init
= &(struct clk_init_data
){
1152 .name
= "gcc_blsp1_qup2_spi_apps_clk",
1153 .parent_names
= (const char *[]){
1154 "blsp1_qup2_spi_apps_clk_src",
1157 .flags
= CLK_SET_RATE_PARENT
,
1158 .ops
= &clk_branch2_ops
,
1163 static struct clk_branch gcc_blsp1_qup3_i2c_apps_clk
= {
1166 .enable_reg
= 0x0748,
1167 .enable_mask
= BIT(0),
1168 .hw
.init
= &(struct clk_init_data
){
1169 .name
= "gcc_blsp1_qup3_i2c_apps_clk",
1170 .parent_names
= (const char *[]){
1171 "blsp1_qup3_i2c_apps_clk_src",
1174 .flags
= CLK_SET_RATE_PARENT
,
1175 .ops
= &clk_branch2_ops
,
1180 static struct clk_branch gcc_blsp1_qup3_spi_apps_clk
= {
1183 .enable_reg
= 0x0744,
1184 .enable_mask
= BIT(0),
1185 .hw
.init
= &(struct clk_init_data
){
1186 .name
= "gcc_blsp1_qup3_spi_apps_clk",
1187 .parent_names
= (const char *[]){
1188 "blsp1_qup3_spi_apps_clk_src",
1191 .flags
= CLK_SET_RATE_PARENT
,
1192 .ops
= &clk_branch2_ops
,
1197 static struct clk_branch gcc_blsp1_qup4_i2c_apps_clk
= {
1200 .enable_reg
= 0x07c8,
1201 .enable_mask
= BIT(0),
1202 .hw
.init
= &(struct clk_init_data
){
1203 .name
= "gcc_blsp1_qup4_i2c_apps_clk",
1204 .parent_names
= (const char *[]){
1205 "blsp1_qup4_i2c_apps_clk_src",
1208 .flags
= CLK_SET_RATE_PARENT
,
1209 .ops
= &clk_branch2_ops
,
1214 static struct clk_branch gcc_blsp1_qup4_spi_apps_clk
= {
1217 .enable_reg
= 0x07c4,
1218 .enable_mask
= BIT(0),
1219 .hw
.init
= &(struct clk_init_data
){
1220 .name
= "gcc_blsp1_qup4_spi_apps_clk",
1221 .parent_names
= (const char *[]){
1222 "blsp1_qup4_spi_apps_clk_src",
1225 .flags
= CLK_SET_RATE_PARENT
,
1226 .ops
= &clk_branch2_ops
,
1231 static struct clk_branch gcc_blsp1_qup5_i2c_apps_clk
= {
1234 .enable_reg
= 0x0848,
1235 .enable_mask
= BIT(0),
1236 .hw
.init
= &(struct clk_init_data
){
1237 .name
= "gcc_blsp1_qup5_i2c_apps_clk",
1238 .parent_names
= (const char *[]){
1239 "blsp1_qup5_i2c_apps_clk_src",
1242 .flags
= CLK_SET_RATE_PARENT
,
1243 .ops
= &clk_branch2_ops
,
1248 static struct clk_branch gcc_blsp1_qup5_spi_apps_clk
= {
1251 .enable_reg
= 0x0844,
1252 .enable_mask
= BIT(0),
1253 .hw
.init
= &(struct clk_init_data
){
1254 .name
= "gcc_blsp1_qup5_spi_apps_clk",
1255 .parent_names
= (const char *[]){
1256 "blsp1_qup5_spi_apps_clk_src",
1259 .flags
= CLK_SET_RATE_PARENT
,
1260 .ops
= &clk_branch2_ops
,
1265 static struct clk_branch gcc_blsp1_qup6_i2c_apps_clk
= {
1268 .enable_reg
= 0x08c8,
1269 .enable_mask
= BIT(0),
1270 .hw
.init
= &(struct clk_init_data
){
1271 .name
= "gcc_blsp1_qup6_i2c_apps_clk",
1272 .parent_names
= (const char *[]){
1273 "blsp1_qup6_i2c_apps_clk_src",
1276 .flags
= CLK_SET_RATE_PARENT
,
1277 .ops
= &clk_branch2_ops
,
1282 static struct clk_branch gcc_blsp1_qup6_spi_apps_clk
= {
1285 .enable_reg
= 0x08c4,
1286 .enable_mask
= BIT(0),
1287 .hw
.init
= &(struct clk_init_data
){
1288 .name
= "gcc_blsp1_qup6_spi_apps_clk",
1289 .parent_names
= (const char *[]){
1290 "blsp1_qup6_spi_apps_clk_src",
1293 .flags
= CLK_SET_RATE_PARENT
,
1294 .ops
= &clk_branch2_ops
,
1299 static struct clk_branch gcc_blsp1_uart1_apps_clk
= {
1302 .enable_reg
= 0x0684,
1303 .enable_mask
= BIT(0),
1304 .hw
.init
= &(struct clk_init_data
){
1305 .name
= "gcc_blsp1_uart1_apps_clk",
1306 .parent_names
= (const char *[]){
1307 "blsp1_uart1_apps_clk_src",
1310 .flags
= CLK_SET_RATE_PARENT
,
1311 .ops
= &clk_branch2_ops
,
1316 static struct clk_branch gcc_blsp1_uart2_apps_clk
= {
1319 .enable_reg
= 0x0704,
1320 .enable_mask
= BIT(0),
1321 .hw
.init
= &(struct clk_init_data
){
1322 .name
= "gcc_blsp1_uart2_apps_clk",
1323 .parent_names
= (const char *[]){
1324 "blsp1_uart2_apps_clk_src",
1327 .flags
= CLK_SET_RATE_PARENT
,
1328 .ops
= &clk_branch2_ops
,
1333 static struct clk_branch gcc_blsp1_uart3_apps_clk
= {
1336 .enable_reg
= 0x0784,
1337 .enable_mask
= BIT(0),
1338 .hw
.init
= &(struct clk_init_data
){
1339 .name
= "gcc_blsp1_uart3_apps_clk",
1340 .parent_names
= (const char *[]){
1341 "blsp1_uart3_apps_clk_src",
1344 .flags
= CLK_SET_RATE_PARENT
,
1345 .ops
= &clk_branch2_ops
,
1350 static struct clk_branch gcc_blsp1_uart4_apps_clk
= {
1353 .enable_reg
= 0x0804,
1354 .enable_mask
= BIT(0),
1355 .hw
.init
= &(struct clk_init_data
){
1356 .name
= "gcc_blsp1_uart4_apps_clk",
1357 .parent_names
= (const char *[]){
1358 "blsp1_uart4_apps_clk_src",
1361 .flags
= CLK_SET_RATE_PARENT
,
1362 .ops
= &clk_branch2_ops
,
1367 static struct clk_branch gcc_blsp1_uart5_apps_clk
= {
1370 .enable_reg
= 0x0884,
1371 .enable_mask
= BIT(0),
1372 .hw
.init
= &(struct clk_init_data
){
1373 .name
= "gcc_blsp1_uart5_apps_clk",
1374 .parent_names
= (const char *[]){
1375 "blsp1_uart5_apps_clk_src",
1378 .flags
= CLK_SET_RATE_PARENT
,
1379 .ops
= &clk_branch2_ops
,
1384 static struct clk_branch gcc_blsp1_uart6_apps_clk
= {
1387 .enable_reg
= 0x0904,
1388 .enable_mask
= BIT(0),
1389 .hw
.init
= &(struct clk_init_data
){
1390 .name
= "gcc_blsp1_uart6_apps_clk",
1391 .parent_names
= (const char *[]){
1392 "blsp1_uart6_apps_clk_src",
1395 .flags
= CLK_SET_RATE_PARENT
,
1396 .ops
= &clk_branch2_ops
,
1401 static struct clk_branch gcc_blsp2_ahb_clk
= {
1403 .halt_check
= BRANCH_HALT_VOTED
,
1405 .enable_reg
= 0x1484,
1406 .enable_mask
= BIT(15),
1407 .hw
.init
= &(struct clk_init_data
){
1408 .name
= "gcc_blsp2_ahb_clk",
1409 .parent_names
= (const char *[]){
1410 "periph_noc_clk_src",
1413 .ops
= &clk_branch2_ops
,
1418 static struct clk_branch gcc_blsp2_qup1_i2c_apps_clk
= {
1421 .enable_reg
= 0x0988,
1422 .enable_mask
= BIT(0),
1423 .hw
.init
= &(struct clk_init_data
){
1424 .name
= "gcc_blsp2_qup1_i2c_apps_clk",
1425 .parent_names
= (const char *[]){
1426 "blsp2_qup1_i2c_apps_clk_src",
1429 .flags
= CLK_SET_RATE_PARENT
,
1430 .ops
= &clk_branch2_ops
,
1435 static struct clk_branch gcc_blsp2_qup1_spi_apps_clk
= {
1438 .enable_reg
= 0x0984,
1439 .enable_mask
= BIT(0),
1440 .hw
.init
= &(struct clk_init_data
){
1441 .name
= "gcc_blsp2_qup1_spi_apps_clk",
1442 .parent_names
= (const char *[]){
1443 "blsp2_qup1_spi_apps_clk_src",
1446 .flags
= CLK_SET_RATE_PARENT
,
1447 .ops
= &clk_branch2_ops
,
1452 static struct clk_branch gcc_blsp2_qup2_i2c_apps_clk
= {
1455 .enable_reg
= 0x0a08,
1456 .enable_mask
= BIT(0),
1457 .hw
.init
= &(struct clk_init_data
){
1458 .name
= "gcc_blsp2_qup2_i2c_apps_clk",
1459 .parent_names
= (const char *[]){
1460 "blsp2_qup2_i2c_apps_clk_src",
1463 .flags
= CLK_SET_RATE_PARENT
,
1464 .ops
= &clk_branch2_ops
,
1469 static struct clk_branch gcc_blsp2_qup2_spi_apps_clk
= {
1472 .enable_reg
= 0x0a04,
1473 .enable_mask
= BIT(0),
1474 .hw
.init
= &(struct clk_init_data
){
1475 .name
= "gcc_blsp2_qup2_spi_apps_clk",
1476 .parent_names
= (const char *[]){
1477 "blsp2_qup2_spi_apps_clk_src",
1480 .flags
= CLK_SET_RATE_PARENT
,
1481 .ops
= &clk_branch2_ops
,
1486 static struct clk_branch gcc_blsp2_qup3_i2c_apps_clk
= {
1489 .enable_reg
= 0x0a88,
1490 .enable_mask
= BIT(0),
1491 .hw
.init
= &(struct clk_init_data
){
1492 .name
= "gcc_blsp2_qup3_i2c_apps_clk",
1493 .parent_names
= (const char *[]){
1494 "blsp2_qup3_i2c_apps_clk_src",
1497 .flags
= CLK_SET_RATE_PARENT
,
1498 .ops
= &clk_branch2_ops
,
1503 static struct clk_branch gcc_blsp2_qup3_spi_apps_clk
= {
1506 .enable_reg
= 0x0a84,
1507 .enable_mask
= BIT(0),
1508 .hw
.init
= &(struct clk_init_data
){
1509 .name
= "gcc_blsp2_qup3_spi_apps_clk",
1510 .parent_names
= (const char *[]){
1511 "blsp2_qup3_spi_apps_clk_src",
1514 .flags
= CLK_SET_RATE_PARENT
,
1515 .ops
= &clk_branch2_ops
,
1520 static struct clk_branch gcc_blsp2_qup4_i2c_apps_clk
= {
1523 .enable_reg
= 0x0b08,
1524 .enable_mask
= BIT(0),
1525 .hw
.init
= &(struct clk_init_data
){
1526 .name
= "gcc_blsp2_qup4_i2c_apps_clk",
1527 .parent_names
= (const char *[]){
1528 "blsp2_qup4_i2c_apps_clk_src",
1531 .flags
= CLK_SET_RATE_PARENT
,
1532 .ops
= &clk_branch2_ops
,
1537 static struct clk_branch gcc_blsp2_qup4_spi_apps_clk
= {
1540 .enable_reg
= 0x0b04,
1541 .enable_mask
= BIT(0),
1542 .hw
.init
= &(struct clk_init_data
){
1543 .name
= "gcc_blsp2_qup4_spi_apps_clk",
1544 .parent_names
= (const char *[]){
1545 "blsp2_qup4_spi_apps_clk_src",
1548 .flags
= CLK_SET_RATE_PARENT
,
1549 .ops
= &clk_branch2_ops
,
1554 static struct clk_branch gcc_blsp2_qup5_i2c_apps_clk
= {
1557 .enable_reg
= 0x0b88,
1558 .enable_mask
= BIT(0),
1559 .hw
.init
= &(struct clk_init_data
){
1560 .name
= "gcc_blsp2_qup5_i2c_apps_clk",
1561 .parent_names
= (const char *[]){
1562 "blsp2_qup5_i2c_apps_clk_src",
1565 .flags
= CLK_SET_RATE_PARENT
,
1566 .ops
= &clk_branch2_ops
,
1571 static struct clk_branch gcc_blsp2_qup5_spi_apps_clk
= {
1574 .enable_reg
= 0x0b84,
1575 .enable_mask
= BIT(0),
1576 .hw
.init
= &(struct clk_init_data
){
1577 .name
= "gcc_blsp2_qup5_spi_apps_clk",
1578 .parent_names
= (const char *[]){
1579 "blsp2_qup5_spi_apps_clk_src",
1582 .flags
= CLK_SET_RATE_PARENT
,
1583 .ops
= &clk_branch2_ops
,
1588 static struct clk_branch gcc_blsp2_qup6_i2c_apps_clk
= {
1591 .enable_reg
= 0x0c08,
1592 .enable_mask
= BIT(0),
1593 .hw
.init
= &(struct clk_init_data
){
1594 .name
= "gcc_blsp2_qup6_i2c_apps_clk",
1595 .parent_names
= (const char *[]){
1596 "blsp2_qup6_i2c_apps_clk_src",
1599 .flags
= CLK_SET_RATE_PARENT
,
1600 .ops
= &clk_branch2_ops
,
1605 static struct clk_branch gcc_blsp2_qup6_spi_apps_clk
= {
1608 .enable_reg
= 0x0c04,
1609 .enable_mask
= BIT(0),
1610 .hw
.init
= &(struct clk_init_data
){
1611 .name
= "gcc_blsp2_qup6_spi_apps_clk",
1612 .parent_names
= (const char *[]){
1613 "blsp2_qup6_spi_apps_clk_src",
1616 .flags
= CLK_SET_RATE_PARENT
,
1617 .ops
= &clk_branch2_ops
,
1622 static struct clk_branch gcc_blsp2_uart1_apps_clk
= {
1625 .enable_reg
= 0x09c4,
1626 .enable_mask
= BIT(0),
1627 .hw
.init
= &(struct clk_init_data
){
1628 .name
= "gcc_blsp2_uart1_apps_clk",
1629 .parent_names
= (const char *[]){
1630 "blsp2_uart1_apps_clk_src",
1633 .flags
= CLK_SET_RATE_PARENT
,
1634 .ops
= &clk_branch2_ops
,
1639 static struct clk_branch gcc_blsp2_uart2_apps_clk
= {
1642 .enable_reg
= 0x0a44,
1643 .enable_mask
= BIT(0),
1644 .hw
.init
= &(struct clk_init_data
){
1645 .name
= "gcc_blsp2_uart2_apps_clk",
1646 .parent_names
= (const char *[]){
1647 "blsp2_uart2_apps_clk_src",
1650 .flags
= CLK_SET_RATE_PARENT
,
1651 .ops
= &clk_branch2_ops
,
1656 static struct clk_branch gcc_blsp2_uart3_apps_clk
= {
1659 .enable_reg
= 0x0ac4,
1660 .enable_mask
= BIT(0),
1661 .hw
.init
= &(struct clk_init_data
){
1662 .name
= "gcc_blsp2_uart3_apps_clk",
1663 .parent_names
= (const char *[]){
1664 "blsp2_uart3_apps_clk_src",
1667 .flags
= CLK_SET_RATE_PARENT
,
1668 .ops
= &clk_branch2_ops
,
1673 static struct clk_branch gcc_blsp2_uart4_apps_clk
= {
1676 .enable_reg
= 0x0b44,
1677 .enable_mask
= BIT(0),
1678 .hw
.init
= &(struct clk_init_data
){
1679 .name
= "gcc_blsp2_uart4_apps_clk",
1680 .parent_names
= (const char *[]){
1681 "blsp2_uart4_apps_clk_src",
1684 .flags
= CLK_SET_RATE_PARENT
,
1685 .ops
= &clk_branch2_ops
,
1690 static struct clk_branch gcc_blsp2_uart5_apps_clk
= {
1693 .enable_reg
= 0x0bc4,
1694 .enable_mask
= BIT(0),
1695 .hw
.init
= &(struct clk_init_data
){
1696 .name
= "gcc_blsp2_uart5_apps_clk",
1697 .parent_names
= (const char *[]){
1698 "blsp2_uart5_apps_clk_src",
1701 .flags
= CLK_SET_RATE_PARENT
,
1702 .ops
= &clk_branch2_ops
,
1707 static struct clk_branch gcc_blsp2_uart6_apps_clk
= {
1710 .enable_reg
= 0x0c44,
1711 .enable_mask
= BIT(0),
1712 .hw
.init
= &(struct clk_init_data
){
1713 .name
= "gcc_blsp2_uart6_apps_clk",
1714 .parent_names
= (const char *[]){
1715 "blsp2_uart6_apps_clk_src",
1718 .flags
= CLK_SET_RATE_PARENT
,
1719 .ops
= &clk_branch2_ops
,
1724 static struct clk_branch gcc_boot_rom_ahb_clk
= {
1726 .halt_check
= BRANCH_HALT_VOTED
,
1728 .enable_reg
= 0x1484,
1729 .enable_mask
= BIT(10),
1730 .hw
.init
= &(struct clk_init_data
){
1731 .name
= "gcc_boot_rom_ahb_clk",
1732 .parent_names
= (const char *[]){
1733 "config_noc_clk_src",
1736 .ops
= &clk_branch2_ops
,
1741 static struct clk_branch gcc_ce1_ahb_clk
= {
1743 .halt_check
= BRANCH_HALT_VOTED
,
1745 .enable_reg
= 0x1484,
1746 .enable_mask
= BIT(3),
1747 .hw
.init
= &(struct clk_init_data
){
1748 .name
= "gcc_ce1_ahb_clk",
1749 .parent_names
= (const char *[]){
1750 "config_noc_clk_src",
1753 .ops
= &clk_branch2_ops
,
1758 static struct clk_branch gcc_ce1_axi_clk
= {
1760 .halt_check
= BRANCH_HALT_VOTED
,
1762 .enable_reg
= 0x1484,
1763 .enable_mask
= BIT(4),
1764 .hw
.init
= &(struct clk_init_data
){
1765 .name
= "gcc_ce1_axi_clk",
1766 .parent_names
= (const char *[]){
1767 "system_noc_clk_src",
1770 .ops
= &clk_branch2_ops
,
1775 static struct clk_branch gcc_ce1_clk
= {
1777 .halt_check
= BRANCH_HALT_VOTED
,
1779 .enable_reg
= 0x1484,
1780 .enable_mask
= BIT(5),
1781 .hw
.init
= &(struct clk_init_data
){
1782 .name
= "gcc_ce1_clk",
1783 .parent_names
= (const char *[]){
1787 .flags
= CLK_SET_RATE_PARENT
,
1788 .ops
= &clk_branch2_ops
,
1793 static struct clk_branch gcc_ce2_ahb_clk
= {
1795 .halt_check
= BRANCH_HALT_VOTED
,
1797 .enable_reg
= 0x1484,
1798 .enable_mask
= BIT(0),
1799 .hw
.init
= &(struct clk_init_data
){
1800 .name
= "gcc_ce2_ahb_clk",
1801 .parent_names
= (const char *[]){
1802 "config_noc_clk_src",
1805 .ops
= &clk_branch2_ops
,
1810 static struct clk_branch gcc_ce2_axi_clk
= {
1812 .halt_check
= BRANCH_HALT_VOTED
,
1814 .enable_reg
= 0x1484,
1815 .enable_mask
= BIT(1),
1816 .hw
.init
= &(struct clk_init_data
){
1817 .name
= "gcc_ce2_axi_clk",
1818 .parent_names
= (const char *[]){
1819 "system_noc_clk_src",
1822 .ops
= &clk_branch2_ops
,
1827 static struct clk_branch gcc_ce2_clk
= {
1829 .halt_check
= BRANCH_HALT_VOTED
,
1831 .enable_reg
= 0x1484,
1832 .enable_mask
= BIT(2),
1833 .hw
.init
= &(struct clk_init_data
){
1834 .name
= "gcc_ce2_clk",
1835 .parent_names
= (const char *[]){
1839 .flags
= CLK_SET_RATE_PARENT
,
1840 .ops
= &clk_branch2_ops
,
1845 static struct clk_branch gcc_gp1_clk
= {
1848 .enable_reg
= 0x1900,
1849 .enable_mask
= BIT(0),
1850 .hw
.init
= &(struct clk_init_data
){
1851 .name
= "gcc_gp1_clk",
1852 .parent_names
= (const char *[]){
1856 .flags
= CLK_SET_RATE_PARENT
,
1857 .ops
= &clk_branch2_ops
,
1862 static struct clk_branch gcc_gp2_clk
= {
1865 .enable_reg
= 0x1940,
1866 .enable_mask
= BIT(0),
1867 .hw
.init
= &(struct clk_init_data
){
1868 .name
= "gcc_gp2_clk",
1869 .parent_names
= (const char *[]){
1873 .flags
= CLK_SET_RATE_PARENT
,
1874 .ops
= &clk_branch2_ops
,
1879 static struct clk_branch gcc_gp3_clk
= {
1882 .enable_reg
= 0x1980,
1883 .enable_mask
= BIT(0),
1884 .hw
.init
= &(struct clk_init_data
){
1885 .name
= "gcc_gp3_clk",
1886 .parent_names
= (const char *[]){
1890 .flags
= CLK_SET_RATE_PARENT
,
1891 .ops
= &clk_branch2_ops
,
1896 static struct clk_branch gcc_lpass_q6_axi_clk
= {
1899 .enable_reg
= 0x11c0,
1900 .enable_mask
= BIT(0),
1901 .hw
.init
= &(struct clk_init_data
){
1902 .name
= "gcc_lpass_q6_axi_clk",
1903 .parent_names
= (const char *[]){
1904 "system_noc_clk_src",
1907 .ops
= &clk_branch2_ops
,
1912 static struct clk_branch gcc_mmss_noc_cfg_ahb_clk
= {
1915 .enable_reg
= 0x024c,
1916 .enable_mask
= BIT(0),
1917 .hw
.init
= &(struct clk_init_data
){
1918 .name
= "gcc_mmss_noc_cfg_ahb_clk",
1919 .parent_names
= (const char *[]){
1920 "config_noc_clk_src",
1923 .ops
= &clk_branch2_ops
,
1924 .flags
= CLK_IGNORE_UNUSED
,
1929 static struct clk_branch gcc_ocmem_noc_cfg_ahb_clk
= {
1932 .enable_reg
= 0x0248,
1933 .enable_mask
= BIT(0),
1934 .hw
.init
= &(struct clk_init_data
){
1935 .name
= "gcc_ocmem_noc_cfg_ahb_clk",
1936 .parent_names
= (const char *[]){
1937 "config_noc_clk_src",
1940 .ops
= &clk_branch2_ops
,
1945 static struct clk_branch gcc_mss_cfg_ahb_clk
= {
1948 .enable_reg
= 0x0280,
1949 .enable_mask
= BIT(0),
1950 .hw
.init
= &(struct clk_init_data
){
1951 .name
= "gcc_mss_cfg_ahb_clk",
1952 .parent_names
= (const char *[]){
1953 "config_noc_clk_src",
1956 .ops
= &clk_branch2_ops
,
1961 static struct clk_branch gcc_mss_q6_bimc_axi_clk
= {
1964 .enable_reg
= 0x0284,
1965 .enable_mask
= BIT(0),
1966 .hw
.init
= &(struct clk_init_data
){
1967 .name
= "gcc_mss_q6_bimc_axi_clk",
1968 .flags
= CLK_IS_ROOT
,
1969 .ops
= &clk_branch2_ops
,
1974 static struct clk_branch gcc_pdm2_clk
= {
1977 .enable_reg
= 0x0ccc,
1978 .enable_mask
= BIT(0),
1979 .hw
.init
= &(struct clk_init_data
){
1980 .name
= "gcc_pdm2_clk",
1981 .parent_names
= (const char *[]){
1985 .flags
= CLK_SET_RATE_PARENT
,
1986 .ops
= &clk_branch2_ops
,
1991 static struct clk_branch gcc_pdm_ahb_clk
= {
1994 .enable_reg
= 0x0cc4,
1995 .enable_mask
= BIT(0),
1996 .hw
.init
= &(struct clk_init_data
){
1997 .name
= "gcc_pdm_ahb_clk",
1998 .parent_names
= (const char *[]){
1999 "periph_noc_clk_src",
2002 .ops
= &clk_branch2_ops
,
2007 static struct clk_branch gcc_prng_ahb_clk
= {
2009 .halt_check
= BRANCH_HALT_VOTED
,
2011 .enable_reg
= 0x1484,
2012 .enable_mask
= BIT(13),
2013 .hw
.init
= &(struct clk_init_data
){
2014 .name
= "gcc_prng_ahb_clk",
2015 .parent_names
= (const char *[]){
2016 "periph_noc_clk_src",
2019 .ops
= &clk_branch2_ops
,
2024 static struct clk_branch gcc_sdcc1_ahb_clk
= {
2027 .enable_reg
= 0x04c8,
2028 .enable_mask
= BIT(0),
2029 .hw
.init
= &(struct clk_init_data
){
2030 .name
= "gcc_sdcc1_ahb_clk",
2031 .parent_names
= (const char *[]){
2032 "periph_noc_clk_src",
2035 .ops
= &clk_branch2_ops
,
2040 static struct clk_branch gcc_sdcc1_apps_clk
= {
2043 .enable_reg
= 0x04c4,
2044 .enable_mask
= BIT(0),
2045 .hw
.init
= &(struct clk_init_data
){
2046 .name
= "gcc_sdcc1_apps_clk",
2047 .parent_names
= (const char *[]){
2048 "sdcc1_apps_clk_src",
2051 .flags
= CLK_SET_RATE_PARENT
,
2052 .ops
= &clk_branch2_ops
,
2057 static struct clk_branch gcc_sdcc1_cdccal_ff_clk
= {
2060 .enable_reg
= 0x04e8,
2061 .enable_mask
= BIT(0),
2062 .hw
.init
= &(struct clk_init_data
){
2063 .name
= "gcc_sdcc1_cdccal_ff_clk",
2064 .parent_names
= (const char *[]){
2068 .ops
= &clk_branch2_ops
,
2073 static struct clk_branch gcc_sdcc1_cdccal_sleep_clk
= {
2076 .enable_reg
= 0x04e4,
2077 .enable_mask
= BIT(0),
2078 .hw
.init
= &(struct clk_init_data
){
2079 .name
= "gcc_sdcc1_cdccal_sleep_clk",
2080 .parent_names
= (const char *[]){
2084 .ops
= &clk_branch2_ops
,
2089 static struct clk_branch gcc_sdcc2_ahb_clk
= {
2092 .enable_reg
= 0x0508,
2093 .enable_mask
= BIT(0),
2094 .hw
.init
= &(struct clk_init_data
){
2095 .name
= "gcc_sdcc2_ahb_clk",
2096 .parent_names
= (const char *[]){
2097 "periph_noc_clk_src",
2100 .ops
= &clk_branch2_ops
,
2105 static struct clk_branch gcc_sdcc2_apps_clk
= {
2108 .enable_reg
= 0x0504,
2109 .enable_mask
= BIT(0),
2110 .hw
.init
= &(struct clk_init_data
){
2111 .name
= "gcc_sdcc2_apps_clk",
2112 .parent_names
= (const char *[]){
2113 "sdcc2_apps_clk_src",
2116 .flags
= CLK_SET_RATE_PARENT
,
2117 .ops
= &clk_branch2_ops
,
2122 static struct clk_branch gcc_sdcc3_ahb_clk
= {
2125 .enable_reg
= 0x0548,
2126 .enable_mask
= BIT(0),
2127 .hw
.init
= &(struct clk_init_data
){
2128 .name
= "gcc_sdcc3_ahb_clk",
2129 .parent_names
= (const char *[]){
2130 "periph_noc_clk_src",
2133 .ops
= &clk_branch2_ops
,
2138 static struct clk_branch gcc_sdcc3_apps_clk
= {
2141 .enable_reg
= 0x0544,
2142 .enable_mask
= BIT(0),
2143 .hw
.init
= &(struct clk_init_data
){
2144 .name
= "gcc_sdcc3_apps_clk",
2145 .parent_names
= (const char *[]){
2146 "sdcc3_apps_clk_src",
2149 .flags
= CLK_SET_RATE_PARENT
,
2150 .ops
= &clk_branch2_ops
,
2155 static struct clk_branch gcc_sdcc4_ahb_clk
= {
2158 .enable_reg
= 0x0588,
2159 .enable_mask
= BIT(0),
2160 .hw
.init
= &(struct clk_init_data
){
2161 .name
= "gcc_sdcc4_ahb_clk",
2162 .parent_names
= (const char *[]){
2163 "periph_noc_clk_src",
2166 .ops
= &clk_branch2_ops
,
2171 static struct clk_branch gcc_sdcc4_apps_clk
= {
2174 .enable_reg
= 0x0584,
2175 .enable_mask
= BIT(0),
2176 .hw
.init
= &(struct clk_init_data
){
2177 .name
= "gcc_sdcc4_apps_clk",
2178 .parent_names
= (const char *[]){
2179 "sdcc4_apps_clk_src",
2182 .flags
= CLK_SET_RATE_PARENT
,
2183 .ops
= &clk_branch2_ops
,
2188 static struct clk_branch gcc_sys_noc_usb3_axi_clk
= {
2191 .enable_reg
= 0x0108,
2192 .enable_mask
= BIT(0),
2193 .hw
.init
= &(struct clk_init_data
){
2194 .name
= "gcc_sys_noc_usb3_axi_clk",
2195 .parent_names
= (const char *[]){
2196 "usb30_master_clk_src",
2199 .flags
= CLK_SET_RATE_PARENT
,
2200 .ops
= &clk_branch2_ops
,
2205 static struct clk_branch gcc_tsif_ahb_clk
= {
2208 .enable_reg
= 0x0d84,
2209 .enable_mask
= BIT(0),
2210 .hw
.init
= &(struct clk_init_data
){
2211 .name
= "gcc_tsif_ahb_clk",
2212 .parent_names
= (const char *[]){
2213 "periph_noc_clk_src",
2216 .ops
= &clk_branch2_ops
,
2221 static struct clk_branch gcc_tsif_ref_clk
= {
2224 .enable_reg
= 0x0d88,
2225 .enable_mask
= BIT(0),
2226 .hw
.init
= &(struct clk_init_data
){
2227 .name
= "gcc_tsif_ref_clk",
2228 .parent_names
= (const char *[]){
2232 .flags
= CLK_SET_RATE_PARENT
,
2233 .ops
= &clk_branch2_ops
,
2238 static struct clk_branch gcc_usb2a_phy_sleep_clk
= {
2241 .enable_reg
= 0x04ac,
2242 .enable_mask
= BIT(0),
2243 .hw
.init
= &(struct clk_init_data
){
2244 .name
= "gcc_usb2a_phy_sleep_clk",
2245 .parent_names
= (const char *[]){
2249 .ops
= &clk_branch2_ops
,
2254 static struct clk_branch gcc_usb2b_phy_sleep_clk
= {
2257 .enable_reg
= 0x04b4,
2258 .enable_mask
= BIT(0),
2259 .hw
.init
= &(struct clk_init_data
){
2260 .name
= "gcc_usb2b_phy_sleep_clk",
2261 .parent_names
= (const char *[]){
2265 .ops
= &clk_branch2_ops
,
2270 static struct clk_branch gcc_usb30_master_clk
= {
2273 .enable_reg
= 0x03c8,
2274 .enable_mask
= BIT(0),
2275 .hw
.init
= &(struct clk_init_data
){
2276 .name
= "gcc_usb30_master_clk",
2277 .parent_names
= (const char *[]){
2278 "usb30_master_clk_src",
2281 .flags
= CLK_SET_RATE_PARENT
,
2282 .ops
= &clk_branch2_ops
,
2287 static struct clk_branch gcc_usb30_mock_utmi_clk
= {
2290 .enable_reg
= 0x03d0,
2291 .enable_mask
= BIT(0),
2292 .hw
.init
= &(struct clk_init_data
){
2293 .name
= "gcc_usb30_mock_utmi_clk",
2294 .parent_names
= (const char *[]){
2295 "usb30_mock_utmi_clk_src",
2298 .flags
= CLK_SET_RATE_PARENT
,
2299 .ops
= &clk_branch2_ops
,
2304 static struct clk_branch gcc_usb30_sleep_clk
= {
2307 .enable_reg
= 0x03cc,
2308 .enable_mask
= BIT(0),
2309 .hw
.init
= &(struct clk_init_data
){
2310 .name
= "gcc_usb30_sleep_clk",
2311 .parent_names
= (const char *[]){
2315 .ops
= &clk_branch2_ops
,
2320 static struct clk_branch gcc_usb_hs_ahb_clk
= {
2323 .enable_reg
= 0x0488,
2324 .enable_mask
= BIT(0),
2325 .hw
.init
= &(struct clk_init_data
){
2326 .name
= "gcc_usb_hs_ahb_clk",
2327 .parent_names
= (const char *[]){
2328 "periph_noc_clk_src",
2331 .ops
= &clk_branch2_ops
,
2336 static struct clk_branch gcc_usb_hs_system_clk
= {
2339 .enable_reg
= 0x0484,
2340 .enable_mask
= BIT(0),
2341 .hw
.init
= &(struct clk_init_data
){
2342 .name
= "gcc_usb_hs_system_clk",
2343 .parent_names
= (const char *[]){
2344 "usb_hs_system_clk_src",
2347 .flags
= CLK_SET_RATE_PARENT
,
2348 .ops
= &clk_branch2_ops
,
2353 static struct clk_branch gcc_usb_hsic_ahb_clk
= {
2356 .enable_reg
= 0x0408,
2357 .enable_mask
= BIT(0),
2358 .hw
.init
= &(struct clk_init_data
){
2359 .name
= "gcc_usb_hsic_ahb_clk",
2360 .parent_names
= (const char *[]){
2361 "periph_noc_clk_src",
2364 .ops
= &clk_branch2_ops
,
2369 static struct clk_branch gcc_usb_hsic_clk
= {
2372 .enable_reg
= 0x0410,
2373 .enable_mask
= BIT(0),
2374 .hw
.init
= &(struct clk_init_data
){
2375 .name
= "gcc_usb_hsic_clk",
2376 .parent_names
= (const char *[]){
2380 .flags
= CLK_SET_RATE_PARENT
,
2381 .ops
= &clk_branch2_ops
,
2386 static struct clk_branch gcc_usb_hsic_io_cal_clk
= {
2389 .enable_reg
= 0x0414,
2390 .enable_mask
= BIT(0),
2391 .hw
.init
= &(struct clk_init_data
){
2392 .name
= "gcc_usb_hsic_io_cal_clk",
2393 .parent_names
= (const char *[]){
2394 "usb_hsic_io_cal_clk_src",
2397 .flags
= CLK_SET_RATE_PARENT
,
2398 .ops
= &clk_branch2_ops
,
2403 static struct clk_branch gcc_usb_hsic_io_cal_sleep_clk
= {
2406 .enable_reg
= 0x0418,
2407 .enable_mask
= BIT(0),
2408 .hw
.init
= &(struct clk_init_data
){
2409 .name
= "gcc_usb_hsic_io_cal_sleep_clk",
2410 .parent_names
= (const char *[]){
2414 .ops
= &clk_branch2_ops
,
2419 static struct clk_branch gcc_usb_hsic_system_clk
= {
2422 .enable_reg
= 0x040c,
2423 .enable_mask
= BIT(0),
2424 .hw
.init
= &(struct clk_init_data
){
2425 .name
= "gcc_usb_hsic_system_clk",
2426 .parent_names
= (const char *[]){
2427 "usb_hsic_system_clk_src",
2430 .flags
= CLK_SET_RATE_PARENT
,
2431 .ops
= &clk_branch2_ops
,
2436 static struct gdsc usb_hs_hsic_gdsc
= {
2439 .name
= "usb_hs_hsic",
2441 .pwrsts
= PWRSTS_OFF_ON
,
2444 static struct clk_regmap
*gcc_msm8974_clocks
[] = {
2445 [GPLL0
] = &gpll0
.clkr
,
2446 [GPLL0_VOTE
] = &gpll0_vote
,
2447 [CONFIG_NOC_CLK_SRC
] = &config_noc_clk_src
.clkr
,
2448 [PERIPH_NOC_CLK_SRC
] = &periph_noc_clk_src
.clkr
,
2449 [SYSTEM_NOC_CLK_SRC
] = &system_noc_clk_src
.clkr
,
2450 [GPLL1
] = &gpll1
.clkr
,
2451 [GPLL1_VOTE
] = &gpll1_vote
,
2452 [USB30_MASTER_CLK_SRC
] = &usb30_master_clk_src
.clkr
,
2453 [BLSP1_QUP1_I2C_APPS_CLK_SRC
] = &blsp1_qup1_i2c_apps_clk_src
.clkr
,
2454 [BLSP1_QUP1_SPI_APPS_CLK_SRC
] = &blsp1_qup1_spi_apps_clk_src
.clkr
,
2455 [BLSP1_QUP2_I2C_APPS_CLK_SRC
] = &blsp1_qup2_i2c_apps_clk_src
.clkr
,
2456 [BLSP1_QUP2_SPI_APPS_CLK_SRC
] = &blsp1_qup2_spi_apps_clk_src
.clkr
,
2457 [BLSP1_QUP3_I2C_APPS_CLK_SRC
] = &blsp1_qup3_i2c_apps_clk_src
.clkr
,
2458 [BLSP1_QUP3_SPI_APPS_CLK_SRC
] = &blsp1_qup3_spi_apps_clk_src
.clkr
,
2459 [BLSP1_QUP4_I2C_APPS_CLK_SRC
] = &blsp1_qup4_i2c_apps_clk_src
.clkr
,
2460 [BLSP1_QUP4_SPI_APPS_CLK_SRC
] = &blsp1_qup4_spi_apps_clk_src
.clkr
,
2461 [BLSP1_QUP5_I2C_APPS_CLK_SRC
] = &blsp1_qup5_i2c_apps_clk_src
.clkr
,
2462 [BLSP1_QUP5_SPI_APPS_CLK_SRC
] = &blsp1_qup5_spi_apps_clk_src
.clkr
,
2463 [BLSP1_QUP6_I2C_APPS_CLK_SRC
] = &blsp1_qup6_i2c_apps_clk_src
.clkr
,
2464 [BLSP1_QUP6_SPI_APPS_CLK_SRC
] = &blsp1_qup6_spi_apps_clk_src
.clkr
,
2465 [BLSP1_UART1_APPS_CLK_SRC
] = &blsp1_uart1_apps_clk_src
.clkr
,
2466 [BLSP1_UART2_APPS_CLK_SRC
] = &blsp1_uart2_apps_clk_src
.clkr
,
2467 [BLSP1_UART3_APPS_CLK_SRC
] = &blsp1_uart3_apps_clk_src
.clkr
,
2468 [BLSP1_UART4_APPS_CLK_SRC
] = &blsp1_uart4_apps_clk_src
.clkr
,
2469 [BLSP1_UART5_APPS_CLK_SRC
] = &blsp1_uart5_apps_clk_src
.clkr
,
2470 [BLSP1_UART6_APPS_CLK_SRC
] = &blsp1_uart6_apps_clk_src
.clkr
,
2471 [BLSP2_QUP1_I2C_APPS_CLK_SRC
] = &blsp2_qup1_i2c_apps_clk_src
.clkr
,
2472 [BLSP2_QUP1_SPI_APPS_CLK_SRC
] = &blsp2_qup1_spi_apps_clk_src
.clkr
,
2473 [BLSP2_QUP2_I2C_APPS_CLK_SRC
] = &blsp2_qup2_i2c_apps_clk_src
.clkr
,
2474 [BLSP2_QUP2_SPI_APPS_CLK_SRC
] = &blsp2_qup2_spi_apps_clk_src
.clkr
,
2475 [BLSP2_QUP3_I2C_APPS_CLK_SRC
] = &blsp2_qup3_i2c_apps_clk_src
.clkr
,
2476 [BLSP2_QUP3_SPI_APPS_CLK_SRC
] = &blsp2_qup3_spi_apps_clk_src
.clkr
,
2477 [BLSP2_QUP4_I2C_APPS_CLK_SRC
] = &blsp2_qup4_i2c_apps_clk_src
.clkr
,
2478 [BLSP2_QUP4_SPI_APPS_CLK_SRC
] = &blsp2_qup4_spi_apps_clk_src
.clkr
,
2479 [BLSP2_QUP5_I2C_APPS_CLK_SRC
] = &blsp2_qup5_i2c_apps_clk_src
.clkr
,
2480 [BLSP2_QUP5_SPI_APPS_CLK_SRC
] = &blsp2_qup5_spi_apps_clk_src
.clkr
,
2481 [BLSP2_QUP6_I2C_APPS_CLK_SRC
] = &blsp2_qup6_i2c_apps_clk_src
.clkr
,
2482 [BLSP2_QUP6_SPI_APPS_CLK_SRC
] = &blsp2_qup6_spi_apps_clk_src
.clkr
,
2483 [BLSP2_UART1_APPS_CLK_SRC
] = &blsp2_uart1_apps_clk_src
.clkr
,
2484 [BLSP2_UART2_APPS_CLK_SRC
] = &blsp2_uart2_apps_clk_src
.clkr
,
2485 [BLSP2_UART3_APPS_CLK_SRC
] = &blsp2_uart3_apps_clk_src
.clkr
,
2486 [BLSP2_UART4_APPS_CLK_SRC
] = &blsp2_uart4_apps_clk_src
.clkr
,
2487 [BLSP2_UART5_APPS_CLK_SRC
] = &blsp2_uart5_apps_clk_src
.clkr
,
2488 [BLSP2_UART6_APPS_CLK_SRC
] = &blsp2_uart6_apps_clk_src
.clkr
,
2489 [CE1_CLK_SRC
] = &ce1_clk_src
.clkr
,
2490 [CE2_CLK_SRC
] = &ce2_clk_src
.clkr
,
2491 [GP1_CLK_SRC
] = &gp1_clk_src
.clkr
,
2492 [GP2_CLK_SRC
] = &gp2_clk_src
.clkr
,
2493 [GP3_CLK_SRC
] = &gp3_clk_src
.clkr
,
2494 [PDM2_CLK_SRC
] = &pdm2_clk_src
.clkr
,
2495 [SDCC1_APPS_CLK_SRC
] = &sdcc1_apps_clk_src
.clkr
,
2496 [SDCC2_APPS_CLK_SRC
] = &sdcc2_apps_clk_src
.clkr
,
2497 [SDCC3_APPS_CLK_SRC
] = &sdcc3_apps_clk_src
.clkr
,
2498 [SDCC4_APPS_CLK_SRC
] = &sdcc4_apps_clk_src
.clkr
,
2499 [TSIF_REF_CLK_SRC
] = &tsif_ref_clk_src
.clkr
,
2500 [USB30_MOCK_UTMI_CLK_SRC
] = &usb30_mock_utmi_clk_src
.clkr
,
2501 [USB_HS_SYSTEM_CLK_SRC
] = &usb_hs_system_clk_src
.clkr
,
2502 [USB_HSIC_CLK_SRC
] = &usb_hsic_clk_src
.clkr
,
2503 [USB_HSIC_IO_CAL_CLK_SRC
] = &usb_hsic_io_cal_clk_src
.clkr
,
2504 [USB_HSIC_SYSTEM_CLK_SRC
] = &usb_hsic_system_clk_src
.clkr
,
2505 [GCC_BAM_DMA_AHB_CLK
] = &gcc_bam_dma_ahb_clk
.clkr
,
2506 [GCC_BLSP1_AHB_CLK
] = &gcc_blsp1_ahb_clk
.clkr
,
2507 [GCC_BLSP1_QUP1_I2C_APPS_CLK
] = &gcc_blsp1_qup1_i2c_apps_clk
.clkr
,
2508 [GCC_BLSP1_QUP1_SPI_APPS_CLK
] = &gcc_blsp1_qup1_spi_apps_clk
.clkr
,
2509 [GCC_BLSP1_QUP2_I2C_APPS_CLK
] = &gcc_blsp1_qup2_i2c_apps_clk
.clkr
,
2510 [GCC_BLSP1_QUP2_SPI_APPS_CLK
] = &gcc_blsp1_qup2_spi_apps_clk
.clkr
,
2511 [GCC_BLSP1_QUP3_I2C_APPS_CLK
] = &gcc_blsp1_qup3_i2c_apps_clk
.clkr
,
2512 [GCC_BLSP1_QUP3_SPI_APPS_CLK
] = &gcc_blsp1_qup3_spi_apps_clk
.clkr
,
2513 [GCC_BLSP1_QUP4_I2C_APPS_CLK
] = &gcc_blsp1_qup4_i2c_apps_clk
.clkr
,
2514 [GCC_BLSP1_QUP4_SPI_APPS_CLK
] = &gcc_blsp1_qup4_spi_apps_clk
.clkr
,
2515 [GCC_BLSP1_QUP5_I2C_APPS_CLK
] = &gcc_blsp1_qup5_i2c_apps_clk
.clkr
,
2516 [GCC_BLSP1_QUP5_SPI_APPS_CLK
] = &gcc_blsp1_qup5_spi_apps_clk
.clkr
,
2517 [GCC_BLSP1_QUP6_I2C_APPS_CLK
] = &gcc_blsp1_qup6_i2c_apps_clk
.clkr
,
2518 [GCC_BLSP1_QUP6_SPI_APPS_CLK
] = &gcc_blsp1_qup6_spi_apps_clk
.clkr
,
2519 [GCC_BLSP1_UART1_APPS_CLK
] = &gcc_blsp1_uart1_apps_clk
.clkr
,
2520 [GCC_BLSP1_UART2_APPS_CLK
] = &gcc_blsp1_uart2_apps_clk
.clkr
,
2521 [GCC_BLSP1_UART3_APPS_CLK
] = &gcc_blsp1_uart3_apps_clk
.clkr
,
2522 [GCC_BLSP1_UART4_APPS_CLK
] = &gcc_blsp1_uart4_apps_clk
.clkr
,
2523 [GCC_BLSP1_UART5_APPS_CLK
] = &gcc_blsp1_uart5_apps_clk
.clkr
,
2524 [GCC_BLSP1_UART6_APPS_CLK
] = &gcc_blsp1_uart6_apps_clk
.clkr
,
2525 [GCC_BLSP2_AHB_CLK
] = &gcc_blsp2_ahb_clk
.clkr
,
2526 [GCC_BLSP2_QUP1_I2C_APPS_CLK
] = &gcc_blsp2_qup1_i2c_apps_clk
.clkr
,
2527 [GCC_BLSP2_QUP1_SPI_APPS_CLK
] = &gcc_blsp2_qup1_spi_apps_clk
.clkr
,
2528 [GCC_BLSP2_QUP2_I2C_APPS_CLK
] = &gcc_blsp2_qup2_i2c_apps_clk
.clkr
,
2529 [GCC_BLSP2_QUP2_SPI_APPS_CLK
] = &gcc_blsp2_qup2_spi_apps_clk
.clkr
,
2530 [GCC_BLSP2_QUP3_I2C_APPS_CLK
] = &gcc_blsp2_qup3_i2c_apps_clk
.clkr
,
2531 [GCC_BLSP2_QUP3_SPI_APPS_CLK
] = &gcc_blsp2_qup3_spi_apps_clk
.clkr
,
2532 [GCC_BLSP2_QUP4_I2C_APPS_CLK
] = &gcc_blsp2_qup4_i2c_apps_clk
.clkr
,
2533 [GCC_BLSP2_QUP4_SPI_APPS_CLK
] = &gcc_blsp2_qup4_spi_apps_clk
.clkr
,
2534 [GCC_BLSP2_QUP5_I2C_APPS_CLK
] = &gcc_blsp2_qup5_i2c_apps_clk
.clkr
,
2535 [GCC_BLSP2_QUP5_SPI_APPS_CLK
] = &gcc_blsp2_qup5_spi_apps_clk
.clkr
,
2536 [GCC_BLSP2_QUP6_I2C_APPS_CLK
] = &gcc_blsp2_qup6_i2c_apps_clk
.clkr
,
2537 [GCC_BLSP2_QUP6_SPI_APPS_CLK
] = &gcc_blsp2_qup6_spi_apps_clk
.clkr
,
2538 [GCC_BLSP2_UART1_APPS_CLK
] = &gcc_blsp2_uart1_apps_clk
.clkr
,
2539 [GCC_BLSP2_UART2_APPS_CLK
] = &gcc_blsp2_uart2_apps_clk
.clkr
,
2540 [GCC_BLSP2_UART3_APPS_CLK
] = &gcc_blsp2_uart3_apps_clk
.clkr
,
2541 [GCC_BLSP2_UART4_APPS_CLK
] = &gcc_blsp2_uart4_apps_clk
.clkr
,
2542 [GCC_BLSP2_UART5_APPS_CLK
] = &gcc_blsp2_uart5_apps_clk
.clkr
,
2543 [GCC_BLSP2_UART6_APPS_CLK
] = &gcc_blsp2_uart6_apps_clk
.clkr
,
2544 [GCC_BOOT_ROM_AHB_CLK
] = &gcc_boot_rom_ahb_clk
.clkr
,
2545 [GCC_CE1_AHB_CLK
] = &gcc_ce1_ahb_clk
.clkr
,
2546 [GCC_CE1_AXI_CLK
] = &gcc_ce1_axi_clk
.clkr
,
2547 [GCC_CE1_CLK
] = &gcc_ce1_clk
.clkr
,
2548 [GCC_CE2_AHB_CLK
] = &gcc_ce2_ahb_clk
.clkr
,
2549 [GCC_CE2_AXI_CLK
] = &gcc_ce2_axi_clk
.clkr
,
2550 [GCC_CE2_CLK
] = &gcc_ce2_clk
.clkr
,
2551 [GCC_GP1_CLK
] = &gcc_gp1_clk
.clkr
,
2552 [GCC_GP2_CLK
] = &gcc_gp2_clk
.clkr
,
2553 [GCC_GP3_CLK
] = &gcc_gp3_clk
.clkr
,
2554 [GCC_LPASS_Q6_AXI_CLK
] = &gcc_lpass_q6_axi_clk
.clkr
,
2555 [GCC_MMSS_NOC_CFG_AHB_CLK
] = &gcc_mmss_noc_cfg_ahb_clk
.clkr
,
2556 [GCC_OCMEM_NOC_CFG_AHB_CLK
] = &gcc_ocmem_noc_cfg_ahb_clk
.clkr
,
2557 [GCC_MSS_CFG_AHB_CLK
] = &gcc_mss_cfg_ahb_clk
.clkr
,
2558 [GCC_MSS_Q6_BIMC_AXI_CLK
] = &gcc_mss_q6_bimc_axi_clk
.clkr
,
2559 [GCC_PDM2_CLK
] = &gcc_pdm2_clk
.clkr
,
2560 [GCC_PDM_AHB_CLK
] = &gcc_pdm_ahb_clk
.clkr
,
2561 [GCC_PRNG_AHB_CLK
] = &gcc_prng_ahb_clk
.clkr
,
2562 [GCC_SDCC1_AHB_CLK
] = &gcc_sdcc1_ahb_clk
.clkr
,
2563 [GCC_SDCC1_APPS_CLK
] = &gcc_sdcc1_apps_clk
.clkr
,
2564 [GCC_SDCC2_AHB_CLK
] = &gcc_sdcc2_ahb_clk
.clkr
,
2565 [GCC_SDCC2_APPS_CLK
] = &gcc_sdcc2_apps_clk
.clkr
,
2566 [GCC_SDCC3_AHB_CLK
] = &gcc_sdcc3_ahb_clk
.clkr
,
2567 [GCC_SDCC3_APPS_CLK
] = &gcc_sdcc3_apps_clk
.clkr
,
2568 [GCC_SDCC4_AHB_CLK
] = &gcc_sdcc4_ahb_clk
.clkr
,
2569 [GCC_SDCC4_APPS_CLK
] = &gcc_sdcc4_apps_clk
.clkr
,
2570 [GCC_SYS_NOC_USB3_AXI_CLK
] = &gcc_sys_noc_usb3_axi_clk
.clkr
,
2571 [GCC_TSIF_AHB_CLK
] = &gcc_tsif_ahb_clk
.clkr
,
2572 [GCC_TSIF_REF_CLK
] = &gcc_tsif_ref_clk
.clkr
,
2573 [GCC_USB2A_PHY_SLEEP_CLK
] = &gcc_usb2a_phy_sleep_clk
.clkr
,
2574 [GCC_USB2B_PHY_SLEEP_CLK
] = &gcc_usb2b_phy_sleep_clk
.clkr
,
2575 [GCC_USB30_MASTER_CLK
] = &gcc_usb30_master_clk
.clkr
,
2576 [GCC_USB30_MOCK_UTMI_CLK
] = &gcc_usb30_mock_utmi_clk
.clkr
,
2577 [GCC_USB30_SLEEP_CLK
] = &gcc_usb30_sleep_clk
.clkr
,
2578 [GCC_USB_HS_AHB_CLK
] = &gcc_usb_hs_ahb_clk
.clkr
,
2579 [GCC_USB_HS_SYSTEM_CLK
] = &gcc_usb_hs_system_clk
.clkr
,
2580 [GCC_USB_HSIC_AHB_CLK
] = &gcc_usb_hsic_ahb_clk
.clkr
,
2581 [GCC_USB_HSIC_CLK
] = &gcc_usb_hsic_clk
.clkr
,
2582 [GCC_USB_HSIC_IO_CAL_CLK
] = &gcc_usb_hsic_io_cal_clk
.clkr
,
2583 [GCC_USB_HSIC_IO_CAL_SLEEP_CLK
] = &gcc_usb_hsic_io_cal_sleep_clk
.clkr
,
2584 [GCC_USB_HSIC_SYSTEM_CLK
] = &gcc_usb_hsic_system_clk
.clkr
,
2585 [GCC_MMSS_GPLL0_CLK_SRC
] = &gcc_mmss_gpll0_clk_src
,
2587 [GPLL4_VOTE
] = NULL
,
2588 [GCC_SDCC1_CDCCAL_SLEEP_CLK
] = NULL
,
2589 [GCC_SDCC1_CDCCAL_FF_CLK
] = NULL
,
2592 static const struct qcom_reset_map gcc_msm8974_resets
[] = {
2593 [GCC_SYSTEM_NOC_BCR
] = { 0x0100 },
2594 [GCC_CONFIG_NOC_BCR
] = { 0x0140 },
2595 [GCC_PERIPH_NOC_BCR
] = { 0x0180 },
2596 [GCC_IMEM_BCR
] = { 0x0200 },
2597 [GCC_MMSS_BCR
] = { 0x0240 },
2598 [GCC_QDSS_BCR
] = { 0x0300 },
2599 [GCC_USB_30_BCR
] = { 0x03c0 },
2600 [GCC_USB3_PHY_BCR
] = { 0x03fc },
2601 [GCC_USB_HS_HSIC_BCR
] = { 0x0400 },
2602 [GCC_USB_HS_BCR
] = { 0x0480 },
2603 [GCC_USB2A_PHY_BCR
] = { 0x04a8 },
2604 [GCC_USB2B_PHY_BCR
] = { 0x04b0 },
2605 [GCC_SDCC1_BCR
] = { 0x04c0 },
2606 [GCC_SDCC2_BCR
] = { 0x0500 },
2607 [GCC_SDCC3_BCR
] = { 0x0540 },
2608 [GCC_SDCC4_BCR
] = { 0x0580 },
2609 [GCC_BLSP1_BCR
] = { 0x05c0 },
2610 [GCC_BLSP1_QUP1_BCR
] = { 0x0640 },
2611 [GCC_BLSP1_UART1_BCR
] = { 0x0680 },
2612 [GCC_BLSP1_QUP2_BCR
] = { 0x06c0 },
2613 [GCC_BLSP1_UART2_BCR
] = { 0x0700 },
2614 [GCC_BLSP1_QUP3_BCR
] = { 0x0740 },
2615 [GCC_BLSP1_UART3_BCR
] = { 0x0780 },
2616 [GCC_BLSP1_QUP4_BCR
] = { 0x07c0 },
2617 [GCC_BLSP1_UART4_BCR
] = { 0x0800 },
2618 [GCC_BLSP1_QUP5_BCR
] = { 0x0840 },
2619 [GCC_BLSP1_UART5_BCR
] = { 0x0880 },
2620 [GCC_BLSP1_QUP6_BCR
] = { 0x08c0 },
2621 [GCC_BLSP1_UART6_BCR
] = { 0x0900 },
2622 [GCC_BLSP2_BCR
] = { 0x0940 },
2623 [GCC_BLSP2_QUP1_BCR
] = { 0x0980 },
2624 [GCC_BLSP2_UART1_BCR
] = { 0x09c0 },
2625 [GCC_BLSP2_QUP2_BCR
] = { 0x0a00 },
2626 [GCC_BLSP2_UART2_BCR
] = { 0x0a40 },
2627 [GCC_BLSP2_QUP3_BCR
] = { 0x0a80 },
2628 [GCC_BLSP2_UART3_BCR
] = { 0x0ac0 },
2629 [GCC_BLSP2_QUP4_BCR
] = { 0x0b00 },
2630 [GCC_BLSP2_UART4_BCR
] = { 0x0b40 },
2631 [GCC_BLSP2_QUP5_BCR
] = { 0x0b80 },
2632 [GCC_BLSP2_UART5_BCR
] = { 0x0bc0 },
2633 [GCC_BLSP2_QUP6_BCR
] = { 0x0c00 },
2634 [GCC_BLSP2_UART6_BCR
] = { 0x0c40 },
2635 [GCC_PDM_BCR
] = { 0x0cc0 },
2636 [GCC_BAM_DMA_BCR
] = { 0x0d40 },
2637 [GCC_TSIF_BCR
] = { 0x0d80 },
2638 [GCC_TCSR_BCR
] = { 0x0dc0 },
2639 [GCC_BOOT_ROM_BCR
] = { 0x0e00 },
2640 [GCC_MSG_RAM_BCR
] = { 0x0e40 },
2641 [GCC_TLMM_BCR
] = { 0x0e80 },
2642 [GCC_MPM_BCR
] = { 0x0ec0 },
2643 [GCC_SEC_CTRL_BCR
] = { 0x0f40 },
2644 [GCC_SPMI_BCR
] = { 0x0fc0 },
2645 [GCC_SPDM_BCR
] = { 0x1000 },
2646 [GCC_CE1_BCR
] = { 0x1040 },
2647 [GCC_CE2_BCR
] = { 0x1080 },
2648 [GCC_BIMC_BCR
] = { 0x1100 },
2649 [GCC_MPM_NON_AHB_RESET
] = { 0x0ec4, 2 },
2650 [GCC_MPM_AHB_RESET
] = { 0x0ec4, 1 },
2651 [GCC_SNOC_BUS_TIMEOUT0_BCR
] = { 0x1240 },
2652 [GCC_SNOC_BUS_TIMEOUT2_BCR
] = { 0x1248 },
2653 [GCC_PNOC_BUS_TIMEOUT0_BCR
] = { 0x1280 },
2654 [GCC_PNOC_BUS_TIMEOUT1_BCR
] = { 0x1288 },
2655 [GCC_PNOC_BUS_TIMEOUT2_BCR
] = { 0x1290 },
2656 [GCC_PNOC_BUS_TIMEOUT3_BCR
] = { 0x1298 },
2657 [GCC_PNOC_BUS_TIMEOUT4_BCR
] = { 0x12a0 },
2658 [GCC_CNOC_BUS_TIMEOUT0_BCR
] = { 0x12c0 },
2659 [GCC_CNOC_BUS_TIMEOUT1_BCR
] = { 0x12c8 },
2660 [GCC_CNOC_BUS_TIMEOUT2_BCR
] = { 0x12d0 },
2661 [GCC_CNOC_BUS_TIMEOUT3_BCR
] = { 0x12d8 },
2662 [GCC_CNOC_BUS_TIMEOUT4_BCR
] = { 0x12e0 },
2663 [GCC_CNOC_BUS_TIMEOUT5_BCR
] = { 0x12e8 },
2664 [GCC_CNOC_BUS_TIMEOUT6_BCR
] = { 0x12f0 },
2665 [GCC_DEHR_BCR
] = { 0x1300 },
2666 [GCC_RBCPR_BCR
] = { 0x1380 },
2667 [GCC_MSS_RESTART
] = { 0x1680 },
2668 [GCC_LPASS_RESTART
] = { 0x16c0 },
2669 [GCC_WCSS_RESTART
] = { 0x1700 },
2670 [GCC_VENUS_RESTART
] = { 0x1740 },
2673 static struct gdsc
*gcc_msm8974_gdscs
[] = {
2674 [USB_HS_HSIC_GDSC
] = &usb_hs_hsic_gdsc
,
2677 static const struct regmap_config gcc_msm8974_regmap_config
= {
2681 .max_register
= 0x1fc0,
2685 static const struct qcom_cc_desc gcc_msm8974_desc
= {
2686 .config
= &gcc_msm8974_regmap_config
,
2687 .clks
= gcc_msm8974_clocks
,
2688 .num_clks
= ARRAY_SIZE(gcc_msm8974_clocks
),
2689 .resets
= gcc_msm8974_resets
,
2690 .num_resets
= ARRAY_SIZE(gcc_msm8974_resets
),
2691 .gdscs
= gcc_msm8974_gdscs
,
2692 .num_gdscs
= ARRAY_SIZE(gcc_msm8974_gdscs
),
2695 static const struct of_device_id gcc_msm8974_match_table
[] = {
2696 { .compatible
= "qcom,gcc-msm8974" },
2697 { .compatible
= "qcom,gcc-msm8974pro" , .data
= (void *)1UL },
2698 { .compatible
= "qcom,gcc-msm8974pro-ac", .data
= (void *)1UL },
2701 MODULE_DEVICE_TABLE(of
, gcc_msm8974_match_table
);
2703 static void msm8974_pro_clock_override(void)
2705 sdcc1_apps_clk_src_init
.parent_names
= gcc_xo_gpll0_gpll4
;
2706 sdcc1_apps_clk_src_init
.num_parents
= 3;
2707 sdcc1_apps_clk_src
.freq_tbl
= ftbl_gcc_sdcc1_apps_clk_pro
;
2708 sdcc1_apps_clk_src
.parent_map
= gcc_xo_gpll0_gpll4_map
;
2710 gcc_msm8974_clocks
[GPLL4
] = &gpll4
.clkr
;
2711 gcc_msm8974_clocks
[GPLL4_VOTE
] = &gpll4_vote
;
2712 gcc_msm8974_clocks
[GCC_SDCC1_CDCCAL_SLEEP_CLK
] =
2713 &gcc_sdcc1_cdccal_sleep_clk
.clkr
;
2714 gcc_msm8974_clocks
[GCC_SDCC1_CDCCAL_FF_CLK
] =
2715 &gcc_sdcc1_cdccal_ff_clk
.clkr
;
2718 static int gcc_msm8974_probe(struct platform_device
*pdev
)
2721 struct device
*dev
= &pdev
->dev
;
2723 const struct of_device_id
*id
;
2725 id
= of_match_device(gcc_msm8974_match_table
, dev
);
2731 msm8974_pro_clock_override();
2733 /* Temporary until RPM clocks supported */
2734 clk
= clk_register_fixed_rate(dev
, "xo", NULL
, CLK_IS_ROOT
, 19200000);
2736 return PTR_ERR(clk
);
2738 /* Should move to DT node? */
2739 clk
= clk_register_fixed_rate(dev
, "sleep_clk_src", NULL
,
2740 CLK_IS_ROOT
, 32768);
2742 return PTR_ERR(clk
);
2744 return qcom_cc_probe(pdev
, &gcc_msm8974_desc
);
2747 static struct platform_driver gcc_msm8974_driver
= {
2748 .probe
= gcc_msm8974_probe
,
2750 .name
= "gcc-msm8974",
2751 .of_match_table
= gcc_msm8974_match_table
,
2755 static int __init
gcc_msm8974_init(void)
2757 return platform_driver_register(&gcc_msm8974_driver
);
2759 core_initcall(gcc_msm8974_init
);
2761 static void __exit
gcc_msm8974_exit(void)
2763 platform_driver_unregister(&gcc_msm8974_driver
);
2765 module_exit(gcc_msm8974_exit
);
2767 MODULE_DESCRIPTION("QCOM GCC MSM8974 Driver");
2768 MODULE_LICENSE("GPL v2");
2769 MODULE_ALIAS("platform:gcc-msm8974");