2 * Copyright (c) 2015, 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>
24 #include <linux/clk.h>
26 #include <dt-bindings/clock/qcom,mmcc-msm8996.h>
29 #include "clk-regmap.h"
30 #include "clk-regmap-divider.h"
31 #include "clk-alpha-pll.h"
33 #include "clk-branch.h"
37 #define F(f, s, h, m, n) { (f), (s), (2 * (h) - 1), (m), (n) }
58 static const struct parent_map mmss_xo_hdmi_map
[] = {
63 static const char * const mmss_xo_hdmi
[] = {
68 static const struct parent_map mmss_xo_dsi0pll_dsi1pll_map
[] = {
74 static const char * const mmss_xo_dsi0pll_dsi1pll
[] = {
80 static const struct parent_map mmss_xo_gpll0_gpll0_div_map
[] = {
86 static const char * const mmss_xo_gpll0_gpll0_div
[] = {
92 static const struct parent_map mmss_xo_dsibyte_map
[] = {
94 { P_DSI0PLL_BYTE
, 1 },
98 static const char * const mmss_xo_dsibyte
[] = {
104 static const struct parent_map mmss_xo_mmpll0_gpll0_gpll0_div_map
[] = {
111 static const char * const mmss_xo_mmpll0_gpll0_gpll0_div
[] = {
118 static const struct parent_map mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map
[] = {
126 static const char * const mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div
[] = {
134 static const struct parent_map mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map
[] = {
142 static const char * const mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div
[] = {
150 static const struct parent_map mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map
[] = {
158 static const char * const mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div
[] = {
166 static const struct parent_map mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
[] = {
174 static const char * const mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
[] = {
182 static const struct parent_map mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_map
[] = {
191 static const char * const mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0
[] = {
200 static const struct parent_map mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div_map
[] = {
210 static const char * const mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div
[] = {
220 static const struct parent_map mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
[] = {
230 static const char * const mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
[] = {
240 static struct clk_fixed_factor gpll0_div
= {
243 .hw
.init
= &(struct clk_init_data
){
245 .parent_names
= (const char *[]){ "gpll0" },
247 .ops
= &clk_fixed_factor_ops
,
251 static struct pll_vco mmpll_p_vco
[] = {
252 { 250000000, 500000000, 3 },
253 { 500000000, 1000000000, 2 },
254 { 1000000000, 1500000000, 1 },
255 { 1500000000, 2000000000, 0 },
258 static struct pll_vco mmpll_gfx_vco
[] = {
259 { 400000000, 1000000000, 2 },
260 { 1000000000, 1500000000, 1 },
261 { 1500000000, 2000000000, 0 },
264 static struct pll_vco mmpll_t_vco
[] = {
265 { 500000000, 1500000000, 0 },
268 static struct clk_alpha_pll mmpll0_early
= {
270 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
271 .vco_table
= mmpll_p_vco
,
272 .num_vco
= ARRAY_SIZE(mmpll_p_vco
),
275 .enable_mask
= BIT(0),
276 .hw
.init
= &(struct clk_init_data
){
277 .name
= "mmpll0_early",
278 .parent_names
= (const char *[]){ "xo" },
280 .ops
= &clk_alpha_pll_ops
,
285 static struct clk_alpha_pll_postdiv mmpll0
= {
287 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
289 .clkr
.hw
.init
= &(struct clk_init_data
){
291 .parent_names
= (const char *[]){ "mmpll0_early" },
293 .ops
= &clk_alpha_pll_postdiv_ops
,
294 .flags
= CLK_SET_RATE_PARENT
,
298 static struct clk_alpha_pll mmpll1_early
= {
300 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
301 .vco_table
= mmpll_p_vco
,
302 .num_vco
= ARRAY_SIZE(mmpll_p_vco
),
305 .enable_mask
= BIT(1),
306 .hw
.init
= &(struct clk_init_data
){
307 .name
= "mmpll1_early",
308 .parent_names
= (const char *[]){ "xo" },
310 .ops
= &clk_alpha_pll_ops
,
315 static struct clk_alpha_pll_postdiv mmpll1
= {
317 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
319 .clkr
.hw
.init
= &(struct clk_init_data
){
321 .parent_names
= (const char *[]){ "mmpll1_early" },
323 .ops
= &clk_alpha_pll_postdiv_ops
,
324 .flags
= CLK_SET_RATE_PARENT
,
328 static struct clk_alpha_pll mmpll2_early
= {
330 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
331 .vco_table
= mmpll_gfx_vco
,
332 .num_vco
= ARRAY_SIZE(mmpll_gfx_vco
),
333 .clkr
.hw
.init
= &(struct clk_init_data
){
334 .name
= "mmpll2_early",
335 .parent_names
= (const char *[]){ "xo" },
337 .ops
= &clk_alpha_pll_ops
,
341 static struct clk_alpha_pll_postdiv mmpll2
= {
343 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
345 .clkr
.hw
.init
= &(struct clk_init_data
){
347 .parent_names
= (const char *[]){ "mmpll2_early" },
349 .ops
= &clk_alpha_pll_postdiv_ops
,
350 .flags
= CLK_SET_RATE_PARENT
,
354 static struct clk_alpha_pll mmpll3_early
= {
356 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
357 .vco_table
= mmpll_p_vco
,
358 .num_vco
= ARRAY_SIZE(mmpll_p_vco
),
359 .clkr
.hw
.init
= &(struct clk_init_data
){
360 .name
= "mmpll3_early",
361 .parent_names
= (const char *[]){ "xo" },
363 .ops
= &clk_alpha_pll_ops
,
367 static struct clk_alpha_pll_postdiv mmpll3
= {
369 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
371 .clkr
.hw
.init
= &(struct clk_init_data
){
373 .parent_names
= (const char *[]){ "mmpll3_early" },
375 .ops
= &clk_alpha_pll_postdiv_ops
,
376 .flags
= CLK_SET_RATE_PARENT
,
380 static struct clk_alpha_pll mmpll4_early
= {
382 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
383 .vco_table
= mmpll_t_vco
,
384 .num_vco
= ARRAY_SIZE(mmpll_t_vco
),
385 .clkr
.hw
.init
= &(struct clk_init_data
){
386 .name
= "mmpll4_early",
387 .parent_names
= (const char *[]){ "xo" },
389 .ops
= &clk_alpha_pll_ops
,
393 static struct clk_alpha_pll_postdiv mmpll4
= {
395 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
397 .clkr
.hw
.init
= &(struct clk_init_data
){
399 .parent_names
= (const char *[]){ "mmpll4_early" },
401 .ops
= &clk_alpha_pll_postdiv_ops
,
402 .flags
= CLK_SET_RATE_PARENT
,
406 static struct clk_alpha_pll mmpll5_early
= {
408 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
409 .vco_table
= mmpll_p_vco
,
410 .num_vco
= ARRAY_SIZE(mmpll_p_vco
),
411 .clkr
.hw
.init
= &(struct clk_init_data
){
412 .name
= "mmpll5_early",
413 .parent_names
= (const char *[]){ "xo" },
415 .ops
= &clk_alpha_pll_ops
,
419 static struct clk_alpha_pll_postdiv mmpll5
= {
421 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
423 .clkr
.hw
.init
= &(struct clk_init_data
){
425 .parent_names
= (const char *[]){ "mmpll5_early" },
427 .ops
= &clk_alpha_pll_postdiv_ops
,
428 .flags
= CLK_SET_RATE_PARENT
,
432 static struct clk_alpha_pll mmpll8_early
= {
434 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
435 .vco_table
= mmpll_gfx_vco
,
436 .num_vco
= ARRAY_SIZE(mmpll_gfx_vco
),
437 .clkr
.hw
.init
= &(struct clk_init_data
){
438 .name
= "mmpll8_early",
439 .parent_names
= (const char *[]){ "xo" },
441 .ops
= &clk_alpha_pll_ops
,
445 static struct clk_alpha_pll_postdiv mmpll8
= {
447 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
449 .clkr
.hw
.init
= &(struct clk_init_data
){
451 .parent_names
= (const char *[]){ "mmpll8_early" },
453 .ops
= &clk_alpha_pll_postdiv_ops
,
454 .flags
= CLK_SET_RATE_PARENT
,
458 static struct clk_alpha_pll mmpll9_early
= {
460 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
461 .vco_table
= mmpll_t_vco
,
462 .num_vco
= ARRAY_SIZE(mmpll_t_vco
),
463 .clkr
.hw
.init
= &(struct clk_init_data
){
464 .name
= "mmpll9_early",
465 .parent_names
= (const char *[]){ "xo" },
467 .ops
= &clk_alpha_pll_ops
,
471 static struct clk_alpha_pll_postdiv mmpll9
= {
473 .regs
= clk_alpha_pll_regs
[CLK_ALPHA_PLL_TYPE_DEFAULT
],
475 .clkr
.hw
.init
= &(struct clk_init_data
){
477 .parent_names
= (const char *[]){ "mmpll9_early" },
479 .ops
= &clk_alpha_pll_postdiv_ops
,
480 .flags
= CLK_SET_RATE_PARENT
,
484 static const struct freq_tbl ftbl_ahb_clk_src
[] = {
485 F(19200000, P_XO
, 1, 0, 0),
486 F(40000000, P_GPLL0_DIV
, 7.5, 0, 0),
487 F(80000000, P_MMPLL0
, 10, 0, 0),
491 static struct clk_rcg2 ahb_clk_src
= {
494 .parent_map
= mmss_xo_mmpll0_gpll0_gpll0_div_map
,
495 .freq_tbl
= ftbl_ahb_clk_src
,
496 .clkr
.hw
.init
= &(struct clk_init_data
){
497 .name
= "ahb_clk_src",
498 .parent_names
= mmss_xo_mmpll0_gpll0_gpll0_div
,
500 .ops
= &clk_rcg2_ops
,
504 static const struct freq_tbl ftbl_axi_clk_src
[] = {
505 F(19200000, P_XO
, 1, 0, 0),
506 F(75000000, P_GPLL0_DIV
, 4, 0, 0),
507 F(100000000, P_GPLL0
, 6, 0, 0),
508 F(171430000, P_GPLL0
, 3.5, 0, 0),
509 F(200000000, P_GPLL0
, 3, 0, 0),
510 F(320000000, P_MMPLL0
, 2.5, 0, 0),
511 F(400000000, P_MMPLL0
, 2, 0, 0),
515 static struct clk_rcg2 axi_clk_src
= {
518 .parent_map
= mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map
,
519 .freq_tbl
= ftbl_axi_clk_src
,
520 .clkr
.hw
.init
= &(struct clk_init_data
){
521 .name
= "axi_clk_src",
522 .parent_names
= mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div
,
524 .ops
= &clk_rcg2_ops
,
528 static struct clk_rcg2 maxi_clk_src
= {
531 .parent_map
= mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map
,
532 .freq_tbl
= ftbl_axi_clk_src
,
533 .clkr
.hw
.init
= &(struct clk_init_data
){
534 .name
= "maxi_clk_src",
535 .parent_names
= mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div
,
537 .ops
= &clk_rcg2_ops
,
541 static struct clk_rcg2 gfx3d_clk_src
= {
544 .parent_map
= mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_map
,
545 .clkr
.hw
.init
= &(struct clk_init_data
){
546 .name
= "gfx3d_clk_src",
547 .parent_names
= mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0
,
549 .ops
= &clk_gfx3d_ops
,
550 .flags
= CLK_SET_RATE_PARENT
,
554 static const struct freq_tbl ftbl_rbbmtimer_clk_src
[] = {
555 F(19200000, P_XO
, 1, 0, 0),
559 static struct clk_rcg2 rbbmtimer_clk_src
= {
562 .parent_map
= mmss_xo_mmpll0_gpll0_gpll0_div_map
,
563 .freq_tbl
= ftbl_rbbmtimer_clk_src
,
564 .clkr
.hw
.init
= &(struct clk_init_data
){
565 .name
= "rbbmtimer_clk_src",
566 .parent_names
= mmss_xo_mmpll0_gpll0_gpll0_div
,
568 .ops
= &clk_rcg2_ops
,
572 static struct clk_rcg2 isense_clk_src
= {
575 .parent_map
= mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div_map
,
576 .clkr
.hw
.init
= &(struct clk_init_data
){
577 .name
= "isense_clk_src",
578 .parent_names
= mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div
,
580 .ops
= &clk_rcg2_ops
,
584 static const struct freq_tbl ftbl_rbcpr_clk_src
[] = {
585 F(19200000, P_XO
, 1, 0, 0),
586 F(50000000, P_GPLL0
, 12, 0, 0),
590 static struct clk_rcg2 rbcpr_clk_src
= {
593 .parent_map
= mmss_xo_mmpll0_gpll0_gpll0_div_map
,
594 .freq_tbl
= ftbl_rbcpr_clk_src
,
595 .clkr
.hw
.init
= &(struct clk_init_data
){
596 .name
= "rbcpr_clk_src",
597 .parent_names
= mmss_xo_mmpll0_gpll0_gpll0_div
,
599 .ops
= &clk_rcg2_ops
,
603 static const struct freq_tbl ftbl_video_core_clk_src
[] = {
604 F(75000000, P_GPLL0_DIV
, 4, 0, 0),
605 F(150000000, P_GPLL0
, 4, 0, 0),
606 F(346666667, P_MMPLL3
, 3, 0, 0),
607 F(520000000, P_MMPLL3
, 2, 0, 0),
611 static struct clk_rcg2 video_core_clk_src
= {
615 .parent_map
= mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map
,
616 .freq_tbl
= ftbl_video_core_clk_src
,
617 .clkr
.hw
.init
= &(struct clk_init_data
){
618 .name
= "video_core_clk_src",
619 .parent_names
= mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div
,
621 .ops
= &clk_rcg2_ops
,
625 static struct clk_rcg2 video_subcore0_clk_src
= {
629 .parent_map
= mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map
,
630 .freq_tbl
= ftbl_video_core_clk_src
,
631 .clkr
.hw
.init
= &(struct clk_init_data
){
632 .name
= "video_subcore0_clk_src",
633 .parent_names
= mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div
,
635 .ops
= &clk_rcg2_ops
,
639 static struct clk_rcg2 video_subcore1_clk_src
= {
643 .parent_map
= mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map
,
644 .freq_tbl
= ftbl_video_core_clk_src
,
645 .clkr
.hw
.init
= &(struct clk_init_data
){
646 .name
= "video_subcore1_clk_src",
647 .parent_names
= mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div
,
649 .ops
= &clk_rcg2_ops
,
653 static struct clk_rcg2 pclk0_clk_src
= {
657 .parent_map
= mmss_xo_dsi0pll_dsi1pll_map
,
658 .clkr
.hw
.init
= &(struct clk_init_data
){
659 .name
= "pclk0_clk_src",
660 .parent_names
= mmss_xo_dsi0pll_dsi1pll
,
662 .ops
= &clk_pixel_ops
,
663 .flags
= CLK_SET_RATE_PARENT
,
667 static struct clk_rcg2 pclk1_clk_src
= {
671 .parent_map
= mmss_xo_dsi0pll_dsi1pll_map
,
672 .clkr
.hw
.init
= &(struct clk_init_data
){
673 .name
= "pclk1_clk_src",
674 .parent_names
= mmss_xo_dsi0pll_dsi1pll
,
676 .ops
= &clk_pixel_ops
,
677 .flags
= CLK_SET_RATE_PARENT
,
681 static const struct freq_tbl ftbl_mdp_clk_src
[] = {
682 F(85714286, P_GPLL0
, 7, 0, 0),
683 F(100000000, P_GPLL0
, 6, 0, 0),
684 F(150000000, P_GPLL0
, 4, 0, 0),
685 F(171428571, P_GPLL0
, 3.5, 0, 0),
686 F(200000000, P_GPLL0
, 3, 0, 0),
687 F(275000000, P_MMPLL5
, 3, 0, 0),
688 F(300000000, P_GPLL0
, 2, 0, 0),
689 F(330000000, P_MMPLL5
, 2.5, 0, 0),
690 F(412500000, P_MMPLL5
, 2, 0, 0),
694 static struct clk_rcg2 mdp_clk_src
= {
697 .parent_map
= mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map
,
698 .freq_tbl
= ftbl_mdp_clk_src
,
699 .clkr
.hw
.init
= &(struct clk_init_data
){
700 .name
= "mdp_clk_src",
701 .parent_names
= mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div
,
703 .ops
= &clk_rcg2_ops
,
707 static struct freq_tbl extpclk_freq_tbl
[] = {
708 { .src
= P_HDMIPLL
},
712 static struct clk_rcg2 extpclk_clk_src
= {
715 .parent_map
= mmss_xo_hdmi_map
,
716 .freq_tbl
= extpclk_freq_tbl
,
717 .clkr
.hw
.init
= &(struct clk_init_data
){
718 .name
= "extpclk_clk_src",
719 .parent_names
= mmss_xo_hdmi
,
721 .ops
= &clk_byte_ops
,
722 .flags
= CLK_SET_RATE_PARENT
,
726 static struct freq_tbl ftbl_mdss_vsync_clk
[] = {
727 F(19200000, P_XO
, 1, 0, 0),
731 static struct clk_rcg2 vsync_clk_src
= {
734 .parent_map
= mmss_xo_gpll0_gpll0_div_map
,
735 .freq_tbl
= ftbl_mdss_vsync_clk
,
736 .clkr
.hw
.init
= &(struct clk_init_data
){
737 .name
= "vsync_clk_src",
738 .parent_names
= mmss_xo_gpll0_gpll0_div
,
740 .ops
= &clk_rcg2_ops
,
744 static struct freq_tbl ftbl_mdss_hdmi_clk
[] = {
745 F(19200000, P_XO
, 1, 0, 0),
749 static struct clk_rcg2 hdmi_clk_src
= {
752 .parent_map
= mmss_xo_gpll0_gpll0_div_map
,
753 .freq_tbl
= ftbl_mdss_hdmi_clk
,
754 .clkr
.hw
.init
= &(struct clk_init_data
){
755 .name
= "hdmi_clk_src",
756 .parent_names
= mmss_xo_gpll0_gpll0_div
,
758 .ops
= &clk_rcg2_ops
,
762 static struct clk_rcg2 byte0_clk_src
= {
765 .parent_map
= mmss_xo_dsibyte_map
,
766 .clkr
.hw
.init
= &(struct clk_init_data
){
767 .name
= "byte0_clk_src",
768 .parent_names
= mmss_xo_dsibyte
,
770 .ops
= &clk_byte2_ops
,
771 .flags
= CLK_SET_RATE_PARENT
,
775 static struct clk_rcg2 byte1_clk_src
= {
778 .parent_map
= mmss_xo_dsibyte_map
,
779 .clkr
.hw
.init
= &(struct clk_init_data
){
780 .name
= "byte1_clk_src",
781 .parent_names
= mmss_xo_dsibyte
,
783 .ops
= &clk_byte2_ops
,
784 .flags
= CLK_SET_RATE_PARENT
,
788 static struct freq_tbl ftbl_mdss_esc0_1_clk
[] = {
789 F(19200000, P_XO
, 1, 0, 0),
793 static struct clk_rcg2 esc0_clk_src
= {
796 .parent_map
= mmss_xo_dsibyte_map
,
797 .freq_tbl
= ftbl_mdss_esc0_1_clk
,
798 .clkr
.hw
.init
= &(struct clk_init_data
){
799 .name
= "esc0_clk_src",
800 .parent_names
= mmss_xo_dsibyte
,
802 .ops
= &clk_rcg2_ops
,
806 static struct clk_rcg2 esc1_clk_src
= {
809 .parent_map
= mmss_xo_dsibyte_map
,
810 .freq_tbl
= ftbl_mdss_esc0_1_clk
,
811 .clkr
.hw
.init
= &(struct clk_init_data
){
812 .name
= "esc1_clk_src",
813 .parent_names
= mmss_xo_dsibyte
,
815 .ops
= &clk_rcg2_ops
,
819 static const struct freq_tbl ftbl_camss_gp0_clk_src
[] = {
820 F(10000, P_XO
, 16, 1, 120),
821 F(24000, P_XO
, 16, 1, 50),
822 F(6000000, P_GPLL0_DIV
, 10, 1, 5),
823 F(12000000, P_GPLL0_DIV
, 1, 1, 25),
824 F(13000000, P_GPLL0_DIV
, 2, 13, 150),
825 F(24000000, P_GPLL0_DIV
, 1, 2, 25),
829 static struct clk_rcg2 camss_gp0_clk_src
= {
833 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
834 .freq_tbl
= ftbl_camss_gp0_clk_src
,
835 .clkr
.hw
.init
= &(struct clk_init_data
){
836 .name
= "camss_gp0_clk_src",
837 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
839 .ops
= &clk_rcg2_ops
,
843 static struct clk_rcg2 camss_gp1_clk_src
= {
847 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
848 .freq_tbl
= ftbl_camss_gp0_clk_src
,
849 .clkr
.hw
.init
= &(struct clk_init_data
){
850 .name
= "camss_gp1_clk_src",
851 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
853 .ops
= &clk_rcg2_ops
,
857 static const struct freq_tbl ftbl_mclk0_clk_src
[] = {
858 F(4800000, P_XO
, 4, 0, 0),
859 F(6000000, P_GPLL0_DIV
, 10, 1, 5),
860 F(8000000, P_GPLL0_DIV
, 1, 2, 75),
861 F(9600000, P_XO
, 2, 0, 0),
862 F(16666667, P_GPLL0_DIV
, 2, 1, 9),
863 F(19200000, P_XO
, 1, 0, 0),
864 F(24000000, P_GPLL0_DIV
, 1, 2, 25),
865 F(33333333, P_GPLL0_DIV
, 1, 1, 9),
866 F(48000000, P_GPLL0
, 1, 2, 25),
867 F(66666667, P_GPLL0
, 1, 1, 9),
871 static struct clk_rcg2 mclk0_clk_src
= {
875 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
876 .freq_tbl
= ftbl_mclk0_clk_src
,
877 .clkr
.hw
.init
= &(struct clk_init_data
){
878 .name
= "mclk0_clk_src",
879 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
881 .ops
= &clk_rcg2_ops
,
885 static struct clk_rcg2 mclk1_clk_src
= {
889 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
890 .freq_tbl
= ftbl_mclk0_clk_src
,
891 .clkr
.hw
.init
= &(struct clk_init_data
){
892 .name
= "mclk1_clk_src",
893 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
895 .ops
= &clk_rcg2_ops
,
899 static struct clk_rcg2 mclk2_clk_src
= {
903 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
904 .freq_tbl
= ftbl_mclk0_clk_src
,
905 .clkr
.hw
.init
= &(struct clk_init_data
){
906 .name
= "mclk2_clk_src",
907 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
909 .ops
= &clk_rcg2_ops
,
913 static struct clk_rcg2 mclk3_clk_src
= {
917 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
918 .freq_tbl
= ftbl_mclk0_clk_src
,
919 .clkr
.hw
.init
= &(struct clk_init_data
){
920 .name
= "mclk3_clk_src",
921 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
923 .ops
= &clk_rcg2_ops
,
927 static const struct freq_tbl ftbl_cci_clk_src
[] = {
928 F(19200000, P_XO
, 1, 0, 0),
929 F(37500000, P_GPLL0
, 16, 0, 0),
930 F(50000000, P_GPLL0
, 12, 0, 0),
931 F(100000000, P_GPLL0
, 6, 0, 0),
935 static struct clk_rcg2 cci_clk_src
= {
939 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
940 .freq_tbl
= ftbl_cci_clk_src
,
941 .clkr
.hw
.init
= &(struct clk_init_data
){
942 .name
= "cci_clk_src",
943 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
945 .ops
= &clk_rcg2_ops
,
949 static const struct freq_tbl ftbl_csi0phytimer_clk_src
[] = {
950 F(100000000, P_GPLL0_DIV
, 3, 0, 0),
951 F(200000000, P_GPLL0
, 3, 0, 0),
952 F(266666667, P_MMPLL0
, 3, 0, 0),
956 static struct clk_rcg2 csi0phytimer_clk_src
= {
959 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
960 .freq_tbl
= ftbl_csi0phytimer_clk_src
,
961 .clkr
.hw
.init
= &(struct clk_init_data
){
962 .name
= "csi0phytimer_clk_src",
963 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
965 .ops
= &clk_rcg2_ops
,
969 static struct clk_rcg2 csi1phytimer_clk_src
= {
972 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
973 .freq_tbl
= ftbl_csi0phytimer_clk_src
,
974 .clkr
.hw
.init
= &(struct clk_init_data
){
975 .name
= "csi1phytimer_clk_src",
976 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
978 .ops
= &clk_rcg2_ops
,
982 static struct clk_rcg2 csi2phytimer_clk_src
= {
985 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
986 .freq_tbl
= ftbl_csi0phytimer_clk_src
,
987 .clkr
.hw
.init
= &(struct clk_init_data
){
988 .name
= "csi2phytimer_clk_src",
989 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
991 .ops
= &clk_rcg2_ops
,
995 static const struct freq_tbl ftbl_csiphy0_3p_clk_src
[] = {
996 F(100000000, P_GPLL0_DIV
, 3, 0, 0),
997 F(200000000, P_GPLL0
, 3, 0, 0),
998 F(320000000, P_MMPLL4
, 3, 0, 0),
999 F(384000000, P_MMPLL4
, 2.5, 0, 0),
1003 static struct clk_rcg2 csiphy0_3p_clk_src
= {
1006 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1007 .freq_tbl
= ftbl_csiphy0_3p_clk_src
,
1008 .clkr
.hw
.init
= &(struct clk_init_data
){
1009 .name
= "csiphy0_3p_clk_src",
1010 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1012 .ops
= &clk_rcg2_ops
,
1016 static struct clk_rcg2 csiphy1_3p_clk_src
= {
1019 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1020 .freq_tbl
= ftbl_csiphy0_3p_clk_src
,
1021 .clkr
.hw
.init
= &(struct clk_init_data
){
1022 .name
= "csiphy1_3p_clk_src",
1023 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1025 .ops
= &clk_rcg2_ops
,
1029 static struct clk_rcg2 csiphy2_3p_clk_src
= {
1032 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1033 .freq_tbl
= ftbl_csiphy0_3p_clk_src
,
1034 .clkr
.hw
.init
= &(struct clk_init_data
){
1035 .name
= "csiphy2_3p_clk_src",
1036 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1038 .ops
= &clk_rcg2_ops
,
1042 static const struct freq_tbl ftbl_jpeg0_clk_src
[] = {
1043 F(75000000, P_GPLL0_DIV
, 4, 0, 0),
1044 F(150000000, P_GPLL0
, 4, 0, 0),
1045 F(228571429, P_MMPLL0
, 3.5, 0, 0),
1046 F(266666667, P_MMPLL0
, 3, 0, 0),
1047 F(320000000, P_MMPLL0
, 2.5, 0, 0),
1048 F(480000000, P_MMPLL4
, 2, 0, 0),
1052 static struct clk_rcg2 jpeg0_clk_src
= {
1055 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1056 .freq_tbl
= ftbl_jpeg0_clk_src
,
1057 .clkr
.hw
.init
= &(struct clk_init_data
){
1058 .name
= "jpeg0_clk_src",
1059 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1061 .ops
= &clk_rcg2_ops
,
1065 static const struct freq_tbl ftbl_jpeg2_clk_src
[] = {
1066 F(75000000, P_GPLL0_DIV
, 4, 0, 0),
1067 F(150000000, P_GPLL0
, 4, 0, 0),
1068 F(228571429, P_MMPLL0
, 3.5, 0, 0),
1069 F(266666667, P_MMPLL0
, 3, 0, 0),
1070 F(320000000, P_MMPLL0
, 2.5, 0, 0),
1074 static struct clk_rcg2 jpeg2_clk_src
= {
1077 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1078 .freq_tbl
= ftbl_jpeg2_clk_src
,
1079 .clkr
.hw
.init
= &(struct clk_init_data
){
1080 .name
= "jpeg2_clk_src",
1081 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1083 .ops
= &clk_rcg2_ops
,
1087 static struct clk_rcg2 jpeg_dma_clk_src
= {
1090 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1091 .freq_tbl
= ftbl_jpeg0_clk_src
,
1092 .clkr
.hw
.init
= &(struct clk_init_data
){
1093 .name
= "jpeg_dma_clk_src",
1094 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1096 .ops
= &clk_rcg2_ops
,
1100 static const struct freq_tbl ftbl_vfe0_clk_src
[] = {
1101 F(75000000, P_GPLL0_DIV
, 4, 0, 0),
1102 F(100000000, P_GPLL0_DIV
, 3, 0, 0),
1103 F(300000000, P_GPLL0
, 2, 0, 0),
1104 F(320000000, P_MMPLL0
, 2.5, 0, 0),
1105 F(480000000, P_MMPLL4
, 2, 0, 0),
1106 F(600000000, P_GPLL0
, 1, 0, 0),
1110 static struct clk_rcg2 vfe0_clk_src
= {
1113 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1114 .freq_tbl
= ftbl_vfe0_clk_src
,
1115 .clkr
.hw
.init
= &(struct clk_init_data
){
1116 .name
= "vfe0_clk_src",
1117 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1119 .ops
= &clk_rcg2_ops
,
1123 static struct clk_rcg2 vfe1_clk_src
= {
1126 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1127 .freq_tbl
= ftbl_vfe0_clk_src
,
1128 .clkr
.hw
.init
= &(struct clk_init_data
){
1129 .name
= "vfe1_clk_src",
1130 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1132 .ops
= &clk_rcg2_ops
,
1136 static const struct freq_tbl ftbl_cpp_clk_src
[] = {
1137 F(100000000, P_GPLL0_DIV
, 3, 0, 0),
1138 F(200000000, P_GPLL0
, 3, 0, 0),
1139 F(320000000, P_MMPLL0
, 2.5, 0, 0),
1140 F(480000000, P_MMPLL4
, 2, 0, 0),
1141 F(640000000, P_MMPLL4
, 1.5, 0, 0),
1145 static struct clk_rcg2 cpp_clk_src
= {
1148 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1149 .freq_tbl
= ftbl_cpp_clk_src
,
1150 .clkr
.hw
.init
= &(struct clk_init_data
){
1151 .name
= "cpp_clk_src",
1152 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1154 .ops
= &clk_rcg2_ops
,
1158 static const struct freq_tbl ftbl_csi0_clk_src
[] = {
1159 F(100000000, P_GPLL0_DIV
, 3, 0, 0),
1160 F(200000000, P_GPLL0
, 3, 0, 0),
1161 F(266666667, P_MMPLL0
, 3, 0, 0),
1162 F(480000000, P_MMPLL4
, 2, 0, 0),
1163 F(600000000, P_GPLL0
, 1, 0, 0),
1167 static struct clk_rcg2 csi0_clk_src
= {
1170 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1171 .freq_tbl
= ftbl_csi0_clk_src
,
1172 .clkr
.hw
.init
= &(struct clk_init_data
){
1173 .name
= "csi0_clk_src",
1174 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1176 .ops
= &clk_rcg2_ops
,
1180 static struct clk_rcg2 csi1_clk_src
= {
1183 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1184 .freq_tbl
= ftbl_csi0_clk_src
,
1185 .clkr
.hw
.init
= &(struct clk_init_data
){
1186 .name
= "csi1_clk_src",
1187 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1189 .ops
= &clk_rcg2_ops
,
1193 static struct clk_rcg2 csi2_clk_src
= {
1196 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1197 .freq_tbl
= ftbl_csi0_clk_src
,
1198 .clkr
.hw
.init
= &(struct clk_init_data
){
1199 .name
= "csi2_clk_src",
1200 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1202 .ops
= &clk_rcg2_ops
,
1206 static struct clk_rcg2 csi3_clk_src
= {
1209 .parent_map
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map
,
1210 .freq_tbl
= ftbl_csi0_clk_src
,
1211 .clkr
.hw
.init
= &(struct clk_init_data
){
1212 .name
= "csi3_clk_src",
1213 .parent_names
= mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div
,
1215 .ops
= &clk_rcg2_ops
,
1219 static const struct freq_tbl ftbl_fd_core_clk_src
[] = {
1220 F(100000000, P_GPLL0_DIV
, 3, 0, 0),
1221 F(200000000, P_GPLL0
, 3, 0, 0),
1222 F(400000000, P_MMPLL0
, 2, 0, 0),
1226 static struct clk_rcg2 fd_core_clk_src
= {
1229 .parent_map
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map
,
1230 .freq_tbl
= ftbl_fd_core_clk_src
,
1231 .clkr
.hw
.init
= &(struct clk_init_data
){
1232 .name
= "fd_core_clk_src",
1233 .parent_names
= mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div
,
1235 .ops
= &clk_rcg2_ops
,
1239 static struct clk_branch mmss_mmagic_ahb_clk
= {
1242 .enable_reg
= 0x5024,
1243 .enable_mask
= BIT(0),
1244 .hw
.init
= &(struct clk_init_data
){
1245 .name
= "mmss_mmagic_ahb_clk",
1246 .parent_names
= (const char *[]){ "ahb_clk_src" },
1248 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1249 .ops
= &clk_branch2_ops
,
1254 static struct clk_branch mmss_mmagic_cfg_ahb_clk
= {
1257 .enable_reg
= 0x5054,
1258 .enable_mask
= BIT(0),
1259 .hw
.init
= &(struct clk_init_data
){
1260 .name
= "mmss_mmagic_cfg_ahb_clk",
1261 .parent_names
= (const char *[]){ "ahb_clk_src" },
1263 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1264 .ops
= &clk_branch2_ops
,
1269 static struct clk_branch mmss_misc_ahb_clk
= {
1272 .enable_reg
= 0x5018,
1273 .enable_mask
= BIT(0),
1274 .hw
.init
= &(struct clk_init_data
){
1275 .name
= "mmss_misc_ahb_clk",
1276 .parent_names
= (const char *[]){ "ahb_clk_src" },
1278 .flags
= CLK_SET_RATE_PARENT
,
1279 .ops
= &clk_branch2_ops
,
1284 static struct clk_branch mmss_misc_cxo_clk
= {
1287 .enable_reg
= 0x5014,
1288 .enable_mask
= BIT(0),
1289 .hw
.init
= &(struct clk_init_data
){
1290 .name
= "mmss_misc_cxo_clk",
1291 .parent_names
= (const char *[]){ "xo" },
1293 .ops
= &clk_branch2_ops
,
1298 static struct clk_branch mmss_mmagic_maxi_clk
= {
1301 .enable_reg
= 0x5074,
1302 .enable_mask
= BIT(0),
1303 .hw
.init
= &(struct clk_init_data
){
1304 .name
= "mmss_mmagic_maxi_clk",
1305 .parent_names
= (const char *[]){ "maxi_clk_src" },
1307 .flags
= CLK_SET_RATE_PARENT
,
1308 .ops
= &clk_branch2_ops
,
1313 static struct clk_branch mmagic_camss_axi_clk
= {
1316 .enable_reg
= 0x3c44,
1317 .enable_mask
= BIT(0),
1318 .hw
.init
= &(struct clk_init_data
){
1319 .name
= "mmagic_camss_axi_clk",
1320 .parent_names
= (const char *[]){ "axi_clk_src" },
1322 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1323 .ops
= &clk_branch2_ops
,
1328 static struct clk_branch mmagic_camss_noc_cfg_ahb_clk
= {
1331 .enable_reg
= 0x3c48,
1332 .enable_mask
= BIT(0),
1333 .hw
.init
= &(struct clk_init_data
){
1334 .name
= "mmagic_camss_noc_cfg_ahb_clk",
1335 .parent_names
= (const char *[]){ "gcc_mmss_noc_cfg_ahb_clk" },
1337 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1338 .ops
= &clk_branch2_ops
,
1343 static struct clk_branch smmu_vfe_ahb_clk
= {
1346 .enable_reg
= 0x3c04,
1347 .enable_mask
= BIT(0),
1348 .hw
.init
= &(struct clk_init_data
){
1349 .name
= "smmu_vfe_ahb_clk",
1350 .parent_names
= (const char *[]){ "ahb_clk_src" },
1352 .flags
= CLK_SET_RATE_PARENT
,
1353 .ops
= &clk_branch2_ops
,
1358 static struct clk_branch smmu_vfe_axi_clk
= {
1361 .enable_reg
= 0x3c08,
1362 .enable_mask
= BIT(0),
1363 .hw
.init
= &(struct clk_init_data
){
1364 .name
= "smmu_vfe_axi_clk",
1365 .parent_names
= (const char *[]){ "axi_clk_src" },
1367 .flags
= CLK_SET_RATE_PARENT
,
1368 .ops
= &clk_branch2_ops
,
1373 static struct clk_branch smmu_cpp_ahb_clk
= {
1376 .enable_reg
= 0x3c14,
1377 .enable_mask
= BIT(0),
1378 .hw
.init
= &(struct clk_init_data
){
1379 .name
= "smmu_cpp_ahb_clk",
1380 .parent_names
= (const char *[]){ "ahb_clk_src" },
1382 .flags
= CLK_SET_RATE_PARENT
,
1383 .ops
= &clk_branch2_ops
,
1388 static struct clk_branch smmu_cpp_axi_clk
= {
1391 .enable_reg
= 0x3c18,
1392 .enable_mask
= BIT(0),
1393 .hw
.init
= &(struct clk_init_data
){
1394 .name
= "smmu_cpp_axi_clk",
1395 .parent_names
= (const char *[]){ "axi_clk_src" },
1397 .flags
= CLK_SET_RATE_PARENT
,
1398 .ops
= &clk_branch2_ops
,
1403 static struct clk_branch smmu_jpeg_ahb_clk
= {
1406 .enable_reg
= 0x3c24,
1407 .enable_mask
= BIT(0),
1408 .hw
.init
= &(struct clk_init_data
){
1409 .name
= "smmu_jpeg_ahb_clk",
1410 .parent_names
= (const char *[]){ "ahb_clk_src" },
1412 .flags
= CLK_SET_RATE_PARENT
,
1413 .ops
= &clk_branch2_ops
,
1418 static struct clk_branch smmu_jpeg_axi_clk
= {
1421 .enable_reg
= 0x3c28,
1422 .enable_mask
= BIT(0),
1423 .hw
.init
= &(struct clk_init_data
){
1424 .name
= "smmu_jpeg_axi_clk",
1425 .parent_names
= (const char *[]){ "axi_clk_src" },
1427 .flags
= CLK_SET_RATE_PARENT
,
1428 .ops
= &clk_branch2_ops
,
1433 static struct clk_branch mmagic_mdss_axi_clk
= {
1436 .enable_reg
= 0x2474,
1437 .enable_mask
= BIT(0),
1438 .hw
.init
= &(struct clk_init_data
){
1439 .name
= "mmagic_mdss_axi_clk",
1440 .parent_names
= (const char *[]){ "axi_clk_src" },
1442 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1443 .ops
= &clk_branch2_ops
,
1448 static struct clk_branch mmagic_mdss_noc_cfg_ahb_clk
= {
1451 .enable_reg
= 0x2478,
1452 .enable_mask
= BIT(0),
1453 .hw
.init
= &(struct clk_init_data
){
1454 .name
= "mmagic_mdss_noc_cfg_ahb_clk",
1455 .parent_names
= (const char *[]){ "gcc_mmss_noc_cfg_ahb_clk" },
1457 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1458 .ops
= &clk_branch2_ops
,
1463 static struct clk_branch smmu_rot_ahb_clk
= {
1466 .enable_reg
= 0x2444,
1467 .enable_mask
= BIT(0),
1468 .hw
.init
= &(struct clk_init_data
){
1469 .name
= "smmu_rot_ahb_clk",
1470 .parent_names
= (const char *[]){ "ahb_clk_src" },
1472 .flags
= CLK_SET_RATE_PARENT
,
1473 .ops
= &clk_branch2_ops
,
1478 static struct clk_branch smmu_rot_axi_clk
= {
1481 .enable_reg
= 0x2448,
1482 .enable_mask
= BIT(0),
1483 .hw
.init
= &(struct clk_init_data
){
1484 .name
= "smmu_rot_axi_clk",
1485 .parent_names
= (const char *[]){ "axi_clk_src" },
1487 .flags
= CLK_SET_RATE_PARENT
,
1488 .ops
= &clk_branch2_ops
,
1493 static struct clk_branch smmu_mdp_ahb_clk
= {
1496 .enable_reg
= 0x2454,
1497 .enable_mask
= BIT(0),
1498 .hw
.init
= &(struct clk_init_data
){
1499 .name
= "smmu_mdp_ahb_clk",
1500 .parent_names
= (const char *[]){ "ahb_clk_src" },
1502 .flags
= CLK_SET_RATE_PARENT
,
1503 .ops
= &clk_branch2_ops
,
1508 static struct clk_branch smmu_mdp_axi_clk
= {
1511 .enable_reg
= 0x2458,
1512 .enable_mask
= BIT(0),
1513 .hw
.init
= &(struct clk_init_data
){
1514 .name
= "smmu_mdp_axi_clk",
1515 .parent_names
= (const char *[]){ "axi_clk_src" },
1517 .flags
= CLK_SET_RATE_PARENT
,
1518 .ops
= &clk_branch2_ops
,
1523 static struct clk_branch mmagic_video_axi_clk
= {
1526 .enable_reg
= 0x1194,
1527 .enable_mask
= BIT(0),
1528 .hw
.init
= &(struct clk_init_data
){
1529 .name
= "mmagic_video_axi_clk",
1530 .parent_names
= (const char *[]){ "axi_clk_src" },
1532 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1533 .ops
= &clk_branch2_ops
,
1538 static struct clk_branch mmagic_video_noc_cfg_ahb_clk
= {
1541 .enable_reg
= 0x1198,
1542 .enable_mask
= BIT(0),
1543 .hw
.init
= &(struct clk_init_data
){
1544 .name
= "mmagic_video_noc_cfg_ahb_clk",
1545 .parent_names
= (const char *[]){ "gcc_mmss_noc_cfg_ahb_clk" },
1547 .flags
= CLK_SET_RATE_PARENT
| CLK_IS_CRITICAL
,
1548 .ops
= &clk_branch2_ops
,
1553 static struct clk_branch smmu_video_ahb_clk
= {
1556 .enable_reg
= 0x1174,
1557 .enable_mask
= BIT(0),
1558 .hw
.init
= &(struct clk_init_data
){
1559 .name
= "smmu_video_ahb_clk",
1560 .parent_names
= (const char *[]){ "ahb_clk_src" },
1562 .flags
= CLK_SET_RATE_PARENT
,
1563 .ops
= &clk_branch2_ops
,
1568 static struct clk_branch smmu_video_axi_clk
= {
1571 .enable_reg
= 0x1178,
1572 .enable_mask
= BIT(0),
1573 .hw
.init
= &(struct clk_init_data
){
1574 .name
= "smmu_video_axi_clk",
1575 .parent_names
= (const char *[]){ "axi_clk_src" },
1577 .flags
= CLK_SET_RATE_PARENT
,
1578 .ops
= &clk_branch2_ops
,
1583 static struct clk_branch mmagic_bimc_noc_cfg_ahb_clk
= {
1586 .enable_reg
= 0x5298,
1587 .enable_mask
= BIT(0),
1588 .hw
.init
= &(struct clk_init_data
){
1589 .name
= "mmagic_bimc_noc_cfg_ahb_clk",
1590 .parent_names
= (const char *[]){ "gcc_mmss_noc_cfg_ahb_clk" },
1592 .flags
= CLK_SET_RATE_PARENT
,
1593 .ops
= &clk_branch2_ops
,
1598 static struct clk_branch gpu_gx_gfx3d_clk
= {
1601 .enable_reg
= 0x4028,
1602 .enable_mask
= BIT(0),
1603 .hw
.init
= &(struct clk_init_data
){
1604 .name
= "gpu_gx_gfx3d_clk",
1605 .parent_names
= (const char *[]){ "gfx3d_clk_src" },
1607 .flags
= CLK_SET_RATE_PARENT
,
1608 .ops
= &clk_branch2_ops
,
1613 static struct clk_branch gpu_gx_rbbmtimer_clk
= {
1616 .enable_reg
= 0x40b0,
1617 .enable_mask
= BIT(0),
1618 .hw
.init
= &(struct clk_init_data
){
1619 .name
= "gpu_gx_rbbmtimer_clk",
1620 .parent_names
= (const char *[]){ "rbbmtimer_clk_src" },
1622 .flags
= CLK_SET_RATE_PARENT
,
1623 .ops
= &clk_branch2_ops
,
1628 static struct clk_branch gpu_ahb_clk
= {
1631 .enable_reg
= 0x403c,
1632 .enable_mask
= BIT(0),
1633 .hw
.init
= &(struct clk_init_data
){
1634 .name
= "gpu_ahb_clk",
1635 .parent_names
= (const char *[]){ "ahb_clk_src" },
1637 .flags
= CLK_SET_RATE_PARENT
,
1638 .ops
= &clk_branch2_ops
,
1643 static struct clk_branch gpu_aon_isense_clk
= {
1646 .enable_reg
= 0x4044,
1647 .enable_mask
= BIT(0),
1648 .hw
.init
= &(struct clk_init_data
){
1649 .name
= "gpu_aon_isense_clk",
1650 .parent_names
= (const char *[]){ "isense_clk_src" },
1652 .flags
= CLK_SET_RATE_PARENT
,
1653 .ops
= &clk_branch2_ops
,
1658 static struct clk_branch vmem_maxi_clk
= {
1661 .enable_reg
= 0x1204,
1662 .enable_mask
= BIT(0),
1663 .hw
.init
= &(struct clk_init_data
){
1664 .name
= "vmem_maxi_clk",
1665 .parent_names
= (const char *[]){ "maxi_clk_src" },
1667 .flags
= CLK_SET_RATE_PARENT
,
1668 .ops
= &clk_branch2_ops
,
1673 static struct clk_branch vmem_ahb_clk
= {
1676 .enable_reg
= 0x1208,
1677 .enable_mask
= BIT(0),
1678 .hw
.init
= &(struct clk_init_data
){
1679 .name
= "vmem_ahb_clk",
1680 .parent_names
= (const char *[]){ "ahb_clk_src" },
1682 .flags
= CLK_SET_RATE_PARENT
,
1683 .ops
= &clk_branch2_ops
,
1688 static struct clk_branch mmss_rbcpr_clk
= {
1691 .enable_reg
= 0x4084,
1692 .enable_mask
= BIT(0),
1693 .hw
.init
= &(struct clk_init_data
){
1694 .name
= "mmss_rbcpr_clk",
1695 .parent_names
= (const char *[]){ "rbcpr_clk_src" },
1697 .flags
= CLK_SET_RATE_PARENT
,
1698 .ops
= &clk_branch2_ops
,
1703 static struct clk_branch mmss_rbcpr_ahb_clk
= {
1706 .enable_reg
= 0x4088,
1707 .enable_mask
= BIT(0),
1708 .hw
.init
= &(struct clk_init_data
){
1709 .name
= "mmss_rbcpr_ahb_clk",
1710 .parent_names
= (const char *[]){ "ahb_clk_src" },
1712 .flags
= CLK_SET_RATE_PARENT
,
1713 .ops
= &clk_branch2_ops
,
1718 static struct clk_branch video_core_clk
= {
1721 .enable_reg
= 0x1028,
1722 .enable_mask
= BIT(0),
1723 .hw
.init
= &(struct clk_init_data
){
1724 .name
= "video_core_clk",
1725 .parent_names
= (const char *[]){ "video_core_clk_src" },
1727 .flags
= CLK_SET_RATE_PARENT
,
1728 .ops
= &clk_branch2_ops
,
1733 static struct clk_branch video_axi_clk
= {
1736 .enable_reg
= 0x1034,
1737 .enable_mask
= BIT(0),
1738 .hw
.init
= &(struct clk_init_data
){
1739 .name
= "video_axi_clk",
1740 .parent_names
= (const char *[]){ "axi_clk_src" },
1742 .flags
= CLK_SET_RATE_PARENT
,
1743 .ops
= &clk_branch2_ops
,
1748 static struct clk_branch video_maxi_clk
= {
1751 .enable_reg
= 0x1038,
1752 .enable_mask
= BIT(0),
1753 .hw
.init
= &(struct clk_init_data
){
1754 .name
= "video_maxi_clk",
1755 .parent_names
= (const char *[]){ "maxi_clk_src" },
1757 .flags
= CLK_SET_RATE_PARENT
,
1758 .ops
= &clk_branch2_ops
,
1763 static struct clk_branch video_ahb_clk
= {
1766 .enable_reg
= 0x1030,
1767 .enable_mask
= BIT(0),
1768 .hw
.init
= &(struct clk_init_data
){
1769 .name
= "video_ahb_clk",
1770 .parent_names
= (const char *[]){ "ahb_clk_src" },
1772 .flags
= CLK_SET_RATE_PARENT
,
1773 .ops
= &clk_branch2_ops
,
1778 static struct clk_branch video_subcore0_clk
= {
1781 .enable_reg
= 0x1048,
1782 .enable_mask
= BIT(0),
1783 .hw
.init
= &(struct clk_init_data
){
1784 .name
= "video_subcore0_clk",
1785 .parent_names
= (const char *[]){ "video_subcore0_clk_src" },
1787 .flags
= CLK_SET_RATE_PARENT
,
1788 .ops
= &clk_branch2_ops
,
1793 static struct clk_branch video_subcore1_clk
= {
1796 .enable_reg
= 0x104c,
1797 .enable_mask
= BIT(0),
1798 .hw
.init
= &(struct clk_init_data
){
1799 .name
= "video_subcore1_clk",
1800 .parent_names
= (const char *[]){ "video_subcore1_clk_src" },
1802 .flags
= CLK_SET_RATE_PARENT
,
1803 .ops
= &clk_branch2_ops
,
1808 static struct clk_branch mdss_ahb_clk
= {
1811 .enable_reg
= 0x2308,
1812 .enable_mask
= BIT(0),
1813 .hw
.init
= &(struct clk_init_data
){
1814 .name
= "mdss_ahb_clk",
1815 .parent_names
= (const char *[]){ "ahb_clk_src" },
1817 .flags
= CLK_SET_RATE_PARENT
,
1818 .ops
= &clk_branch2_ops
,
1823 static struct clk_branch mdss_hdmi_ahb_clk
= {
1826 .enable_reg
= 0x230c,
1827 .enable_mask
= BIT(0),
1828 .hw
.init
= &(struct clk_init_data
){
1829 .name
= "mdss_hdmi_ahb_clk",
1830 .parent_names
= (const char *[]){ "ahb_clk_src" },
1832 .flags
= CLK_SET_RATE_PARENT
,
1833 .ops
= &clk_branch2_ops
,
1838 static struct clk_branch mdss_axi_clk
= {
1841 .enable_reg
= 0x2310,
1842 .enable_mask
= BIT(0),
1843 .hw
.init
= &(struct clk_init_data
){
1844 .name
= "mdss_axi_clk",
1845 .parent_names
= (const char *[]){ "axi_clk_src" },
1847 .flags
= CLK_SET_RATE_PARENT
,
1848 .ops
= &clk_branch2_ops
,
1853 static struct clk_branch mdss_pclk0_clk
= {
1856 .enable_reg
= 0x2314,
1857 .enable_mask
= BIT(0),
1858 .hw
.init
= &(struct clk_init_data
){
1859 .name
= "mdss_pclk0_clk",
1860 .parent_names
= (const char *[]){ "pclk0_clk_src" },
1862 .flags
= CLK_SET_RATE_PARENT
,
1863 .ops
= &clk_branch2_ops
,
1868 static struct clk_branch mdss_pclk1_clk
= {
1871 .enable_reg
= 0x2318,
1872 .enable_mask
= BIT(0),
1873 .hw
.init
= &(struct clk_init_data
){
1874 .name
= "mdss_pclk1_clk",
1875 .parent_names
= (const char *[]){ "pclk1_clk_src" },
1877 .flags
= CLK_SET_RATE_PARENT
,
1878 .ops
= &clk_branch2_ops
,
1883 static struct clk_branch mdss_mdp_clk
= {
1886 .enable_reg
= 0x231c,
1887 .enable_mask
= BIT(0),
1888 .hw
.init
= &(struct clk_init_data
){
1889 .name
= "mdss_mdp_clk",
1890 .parent_names
= (const char *[]){ "mdp_clk_src" },
1892 .flags
= CLK_SET_RATE_PARENT
,
1893 .ops
= &clk_branch2_ops
,
1898 static struct clk_branch mdss_extpclk_clk
= {
1901 .enable_reg
= 0x2324,
1902 .enable_mask
= BIT(0),
1903 .hw
.init
= &(struct clk_init_data
){
1904 .name
= "mdss_extpclk_clk",
1905 .parent_names
= (const char *[]){ "extpclk_clk_src" },
1907 .flags
= CLK_SET_RATE_PARENT
,
1908 .ops
= &clk_branch2_ops
,
1913 static struct clk_branch mdss_vsync_clk
= {
1916 .enable_reg
= 0x2328,
1917 .enable_mask
= BIT(0),
1918 .hw
.init
= &(struct clk_init_data
){
1919 .name
= "mdss_vsync_clk",
1920 .parent_names
= (const char *[]){ "vsync_clk_src" },
1922 .flags
= CLK_SET_RATE_PARENT
,
1923 .ops
= &clk_branch2_ops
,
1928 static struct clk_branch mdss_hdmi_clk
= {
1931 .enable_reg
= 0x2338,
1932 .enable_mask
= BIT(0),
1933 .hw
.init
= &(struct clk_init_data
){
1934 .name
= "mdss_hdmi_clk",
1935 .parent_names
= (const char *[]){ "hdmi_clk_src" },
1937 .flags
= CLK_SET_RATE_PARENT
,
1938 .ops
= &clk_branch2_ops
,
1943 static struct clk_branch mdss_byte0_clk
= {
1946 .enable_reg
= 0x233c,
1947 .enable_mask
= BIT(0),
1948 .hw
.init
= &(struct clk_init_data
){
1949 .name
= "mdss_byte0_clk",
1950 .parent_names
= (const char *[]){ "byte0_clk_src" },
1952 .flags
= CLK_SET_RATE_PARENT
,
1953 .ops
= &clk_branch2_ops
,
1958 static struct clk_branch mdss_byte1_clk
= {
1961 .enable_reg
= 0x2340,
1962 .enable_mask
= BIT(0),
1963 .hw
.init
= &(struct clk_init_data
){
1964 .name
= "mdss_byte1_clk",
1965 .parent_names
= (const char *[]){ "byte1_clk_src" },
1967 .flags
= CLK_SET_RATE_PARENT
,
1968 .ops
= &clk_branch2_ops
,
1973 static struct clk_branch mdss_esc0_clk
= {
1976 .enable_reg
= 0x2344,
1977 .enable_mask
= BIT(0),
1978 .hw
.init
= &(struct clk_init_data
){
1979 .name
= "mdss_esc0_clk",
1980 .parent_names
= (const char *[]){ "esc0_clk_src" },
1982 .flags
= CLK_SET_RATE_PARENT
,
1983 .ops
= &clk_branch2_ops
,
1988 static struct clk_branch mdss_esc1_clk
= {
1991 .enable_reg
= 0x2348,
1992 .enable_mask
= BIT(0),
1993 .hw
.init
= &(struct clk_init_data
){
1994 .name
= "mdss_esc1_clk",
1995 .parent_names
= (const char *[]){ "esc1_clk_src" },
1997 .flags
= CLK_SET_RATE_PARENT
,
1998 .ops
= &clk_branch2_ops
,
2003 static struct clk_branch camss_top_ahb_clk
= {
2006 .enable_reg
= 0x3484,
2007 .enable_mask
= BIT(0),
2008 .hw
.init
= &(struct clk_init_data
){
2009 .name
= "camss_top_ahb_clk",
2010 .parent_names
= (const char *[]){ "ahb_clk_src" },
2012 .flags
= CLK_SET_RATE_PARENT
,
2013 .ops
= &clk_branch2_ops
,
2018 static struct clk_branch camss_ahb_clk
= {
2021 .enable_reg
= 0x348c,
2022 .enable_mask
= BIT(0),
2023 .hw
.init
= &(struct clk_init_data
){
2024 .name
= "camss_ahb_clk",
2025 .parent_names
= (const char *[]){ "ahb_clk_src" },
2027 .flags
= CLK_SET_RATE_PARENT
,
2028 .ops
= &clk_branch2_ops
,
2033 static struct clk_branch camss_micro_ahb_clk
= {
2036 .enable_reg
= 0x3494,
2037 .enable_mask
= BIT(0),
2038 .hw
.init
= &(struct clk_init_data
){
2039 .name
= "camss_micro_ahb_clk",
2040 .parent_names
= (const char *[]){ "ahb_clk_src" },
2042 .flags
= CLK_SET_RATE_PARENT
,
2043 .ops
= &clk_branch2_ops
,
2048 static struct clk_branch camss_gp0_clk
= {
2051 .enable_reg
= 0x3444,
2052 .enable_mask
= BIT(0),
2053 .hw
.init
= &(struct clk_init_data
){
2054 .name
= "camss_gp0_clk",
2055 .parent_names
= (const char *[]){ "camss_gp0_clk_src" },
2057 .flags
= CLK_SET_RATE_PARENT
,
2058 .ops
= &clk_branch2_ops
,
2063 static struct clk_branch camss_gp1_clk
= {
2066 .enable_reg
= 0x3474,
2067 .enable_mask
= BIT(0),
2068 .hw
.init
= &(struct clk_init_data
){
2069 .name
= "camss_gp1_clk",
2070 .parent_names
= (const char *[]){ "camss_gp1_clk_src" },
2072 .flags
= CLK_SET_RATE_PARENT
,
2073 .ops
= &clk_branch2_ops
,
2078 static struct clk_branch camss_mclk0_clk
= {
2081 .enable_reg
= 0x3384,
2082 .enable_mask
= BIT(0),
2083 .hw
.init
= &(struct clk_init_data
){
2084 .name
= "camss_mclk0_clk",
2085 .parent_names
= (const char *[]){ "mclk0_clk_src" },
2087 .flags
= CLK_SET_RATE_PARENT
,
2088 .ops
= &clk_branch2_ops
,
2093 static struct clk_branch camss_mclk1_clk
= {
2096 .enable_reg
= 0x33b4,
2097 .enable_mask
= BIT(0),
2098 .hw
.init
= &(struct clk_init_data
){
2099 .name
= "camss_mclk1_clk",
2100 .parent_names
= (const char *[]){ "mclk1_clk_src" },
2102 .flags
= CLK_SET_RATE_PARENT
,
2103 .ops
= &clk_branch2_ops
,
2108 static struct clk_branch camss_mclk2_clk
= {
2111 .enable_reg
= 0x33e4,
2112 .enable_mask
= BIT(0),
2113 .hw
.init
= &(struct clk_init_data
){
2114 .name
= "camss_mclk2_clk",
2115 .parent_names
= (const char *[]){ "mclk2_clk_src" },
2117 .flags
= CLK_SET_RATE_PARENT
,
2118 .ops
= &clk_branch2_ops
,
2123 static struct clk_branch camss_mclk3_clk
= {
2126 .enable_reg
= 0x3414,
2127 .enable_mask
= BIT(0),
2128 .hw
.init
= &(struct clk_init_data
){
2129 .name
= "camss_mclk3_clk",
2130 .parent_names
= (const char *[]){ "mclk3_clk_src" },
2132 .flags
= CLK_SET_RATE_PARENT
,
2133 .ops
= &clk_branch2_ops
,
2138 static struct clk_branch camss_cci_clk
= {
2141 .enable_reg
= 0x3344,
2142 .enable_mask
= BIT(0),
2143 .hw
.init
= &(struct clk_init_data
){
2144 .name
= "camss_cci_clk",
2145 .parent_names
= (const char *[]){ "cci_clk_src" },
2147 .flags
= CLK_SET_RATE_PARENT
,
2148 .ops
= &clk_branch2_ops
,
2153 static struct clk_branch camss_cci_ahb_clk
= {
2156 .enable_reg
= 0x3348,
2157 .enable_mask
= BIT(0),
2158 .hw
.init
= &(struct clk_init_data
){
2159 .name
= "camss_cci_ahb_clk",
2160 .parent_names
= (const char *[]){ "ahb_clk_src" },
2162 .flags
= CLK_SET_RATE_PARENT
,
2163 .ops
= &clk_branch2_ops
,
2168 static struct clk_branch camss_csi0phytimer_clk
= {
2171 .enable_reg
= 0x3024,
2172 .enable_mask
= BIT(0),
2173 .hw
.init
= &(struct clk_init_data
){
2174 .name
= "camss_csi0phytimer_clk",
2175 .parent_names
= (const char *[]){ "csi0phytimer_clk_src" },
2177 .flags
= CLK_SET_RATE_PARENT
,
2178 .ops
= &clk_branch2_ops
,
2183 static struct clk_branch camss_csi1phytimer_clk
= {
2186 .enable_reg
= 0x3054,
2187 .enable_mask
= BIT(0),
2188 .hw
.init
= &(struct clk_init_data
){
2189 .name
= "camss_csi1phytimer_clk",
2190 .parent_names
= (const char *[]){ "csi1phytimer_clk_src" },
2192 .flags
= CLK_SET_RATE_PARENT
,
2193 .ops
= &clk_branch2_ops
,
2198 static struct clk_branch camss_csi2phytimer_clk
= {
2201 .enable_reg
= 0x3084,
2202 .enable_mask
= BIT(0),
2203 .hw
.init
= &(struct clk_init_data
){
2204 .name
= "camss_csi2phytimer_clk",
2205 .parent_names
= (const char *[]){ "csi2phytimer_clk_src" },
2207 .flags
= CLK_SET_RATE_PARENT
,
2208 .ops
= &clk_branch2_ops
,
2213 static struct clk_branch camss_csiphy0_3p_clk
= {
2216 .enable_reg
= 0x3234,
2217 .enable_mask
= BIT(0),
2218 .hw
.init
= &(struct clk_init_data
){
2219 .name
= "camss_csiphy0_3p_clk",
2220 .parent_names
= (const char *[]){ "csiphy0_3p_clk_src" },
2222 .flags
= CLK_SET_RATE_PARENT
,
2223 .ops
= &clk_branch2_ops
,
2228 static struct clk_branch camss_csiphy1_3p_clk
= {
2231 .enable_reg
= 0x3254,
2232 .enable_mask
= BIT(0),
2233 .hw
.init
= &(struct clk_init_data
){
2234 .name
= "camss_csiphy1_3p_clk",
2235 .parent_names
= (const char *[]){ "csiphy1_3p_clk_src" },
2237 .flags
= CLK_SET_RATE_PARENT
,
2238 .ops
= &clk_branch2_ops
,
2243 static struct clk_branch camss_csiphy2_3p_clk
= {
2246 .enable_reg
= 0x3274,
2247 .enable_mask
= BIT(0),
2248 .hw
.init
= &(struct clk_init_data
){
2249 .name
= "camss_csiphy2_3p_clk",
2250 .parent_names
= (const char *[]){ "csiphy2_3p_clk_src" },
2252 .flags
= CLK_SET_RATE_PARENT
,
2253 .ops
= &clk_branch2_ops
,
2258 static struct clk_branch camss_jpeg0_clk
= {
2261 .enable_reg
= 0x35a8,
2262 .enable_mask
= BIT(0),
2263 .hw
.init
= &(struct clk_init_data
){
2264 .name
= "camss_jpeg0_clk",
2265 .parent_names
= (const char *[]){ "jpeg0_clk_src" },
2267 .flags
= CLK_SET_RATE_PARENT
,
2268 .ops
= &clk_branch2_ops
,
2273 static struct clk_branch camss_jpeg2_clk
= {
2276 .enable_reg
= 0x35b0,
2277 .enable_mask
= BIT(0),
2278 .hw
.init
= &(struct clk_init_data
){
2279 .name
= "camss_jpeg2_clk",
2280 .parent_names
= (const char *[]){ "jpeg2_clk_src" },
2282 .flags
= CLK_SET_RATE_PARENT
,
2283 .ops
= &clk_branch2_ops
,
2288 static struct clk_branch camss_jpeg_dma_clk
= {
2291 .enable_reg
= 0x35c0,
2292 .enable_mask
= BIT(0),
2293 .hw
.init
= &(struct clk_init_data
){
2294 .name
= "camss_jpeg_dma_clk",
2295 .parent_names
= (const char *[]){ "jpeg_dma_clk_src" },
2297 .flags
= CLK_SET_RATE_PARENT
,
2298 .ops
= &clk_branch2_ops
,
2303 static struct clk_branch camss_jpeg_ahb_clk
= {
2306 .enable_reg
= 0x35b4,
2307 .enable_mask
= BIT(0),
2308 .hw
.init
= &(struct clk_init_data
){
2309 .name
= "camss_jpeg_ahb_clk",
2310 .parent_names
= (const char *[]){ "ahb_clk_src" },
2312 .flags
= CLK_SET_RATE_PARENT
,
2313 .ops
= &clk_branch2_ops
,
2318 static struct clk_branch camss_jpeg_axi_clk
= {
2321 .enable_reg
= 0x35b8,
2322 .enable_mask
= BIT(0),
2323 .hw
.init
= &(struct clk_init_data
){
2324 .name
= "camss_jpeg_axi_clk",
2325 .parent_names
= (const char *[]){ "axi_clk_src" },
2327 .flags
= CLK_SET_RATE_PARENT
,
2328 .ops
= &clk_branch2_ops
,
2333 static struct clk_branch camss_vfe_ahb_clk
= {
2336 .enable_reg
= 0x36b8,
2337 .enable_mask
= BIT(0),
2338 .hw
.init
= &(struct clk_init_data
){
2339 .name
= "camss_vfe_ahb_clk",
2340 .parent_names
= (const char *[]){ "ahb_clk_src" },
2342 .flags
= CLK_SET_RATE_PARENT
,
2343 .ops
= &clk_branch2_ops
,
2348 static struct clk_branch camss_vfe_axi_clk
= {
2351 .enable_reg
= 0x36bc,
2352 .enable_mask
= BIT(0),
2353 .hw
.init
= &(struct clk_init_data
){
2354 .name
= "camss_vfe_axi_clk",
2355 .parent_names
= (const char *[]){ "axi_clk_src" },
2357 .flags
= CLK_SET_RATE_PARENT
,
2358 .ops
= &clk_branch2_ops
,
2363 static struct clk_branch camss_vfe0_clk
= {
2366 .enable_reg
= 0x36a8,
2367 .enable_mask
= BIT(0),
2368 .hw
.init
= &(struct clk_init_data
){
2369 .name
= "camss_vfe0_clk",
2370 .parent_names
= (const char *[]){ "vfe0_clk_src" },
2372 .flags
= CLK_SET_RATE_PARENT
,
2373 .ops
= &clk_branch2_ops
,
2378 static struct clk_branch camss_vfe0_stream_clk
= {
2381 .enable_reg
= 0x3720,
2382 .enable_mask
= BIT(0),
2383 .hw
.init
= &(struct clk_init_data
){
2384 .name
= "camss_vfe0_stream_clk",
2385 .parent_names
= (const char *[]){ "vfe0_clk_src" },
2387 .flags
= CLK_SET_RATE_PARENT
,
2388 .ops
= &clk_branch2_ops
,
2393 static struct clk_branch camss_vfe0_ahb_clk
= {
2396 .enable_reg
= 0x3668,
2397 .enable_mask
= BIT(0),
2398 .hw
.init
= &(struct clk_init_data
){
2399 .name
= "camss_vfe0_ahb_clk",
2400 .parent_names
= (const char *[]){ "ahb_clk_src" },
2402 .flags
= CLK_SET_RATE_PARENT
,
2403 .ops
= &clk_branch2_ops
,
2408 static struct clk_branch camss_vfe1_clk
= {
2411 .enable_reg
= 0x36ac,
2412 .enable_mask
= BIT(0),
2413 .hw
.init
= &(struct clk_init_data
){
2414 .name
= "camss_vfe1_clk",
2415 .parent_names
= (const char *[]){ "vfe1_clk_src" },
2417 .flags
= CLK_SET_RATE_PARENT
,
2418 .ops
= &clk_branch2_ops
,
2423 static struct clk_branch camss_vfe1_stream_clk
= {
2426 .enable_reg
= 0x3724,
2427 .enable_mask
= BIT(0),
2428 .hw
.init
= &(struct clk_init_data
){
2429 .name
= "camss_vfe1_stream_clk",
2430 .parent_names
= (const char *[]){ "vfe1_clk_src" },
2432 .flags
= CLK_SET_RATE_PARENT
,
2433 .ops
= &clk_branch2_ops
,
2438 static struct clk_branch camss_vfe1_ahb_clk
= {
2441 .enable_reg
= 0x3678,
2442 .enable_mask
= BIT(0),
2443 .hw
.init
= &(struct clk_init_data
){
2444 .name
= "camss_vfe1_ahb_clk",
2445 .parent_names
= (const char *[]){ "ahb_clk_src" },
2447 .flags
= CLK_SET_RATE_PARENT
,
2448 .ops
= &clk_branch2_ops
,
2453 static struct clk_branch camss_csi_vfe0_clk
= {
2456 .enable_reg
= 0x3704,
2457 .enable_mask
= BIT(0),
2458 .hw
.init
= &(struct clk_init_data
){
2459 .name
= "camss_csi_vfe0_clk",
2460 .parent_names
= (const char *[]){ "vfe0_clk_src" },
2462 .flags
= CLK_SET_RATE_PARENT
,
2463 .ops
= &clk_branch2_ops
,
2468 static struct clk_branch camss_csi_vfe1_clk
= {
2471 .enable_reg
= 0x3714,
2472 .enable_mask
= BIT(0),
2473 .hw
.init
= &(struct clk_init_data
){
2474 .name
= "camss_csi_vfe1_clk",
2475 .parent_names
= (const char *[]){ "vfe1_clk_src" },
2477 .flags
= CLK_SET_RATE_PARENT
,
2478 .ops
= &clk_branch2_ops
,
2483 static struct clk_branch camss_cpp_vbif_ahb_clk
= {
2486 .enable_reg
= 0x36c8,
2487 .enable_mask
= BIT(0),
2488 .hw
.init
= &(struct clk_init_data
){
2489 .name
= "camss_cpp_vbif_ahb_clk",
2490 .parent_names
= (const char *[]){ "ahb_clk_src" },
2492 .flags
= CLK_SET_RATE_PARENT
,
2493 .ops
= &clk_branch2_ops
,
2498 static struct clk_branch camss_cpp_axi_clk
= {
2501 .enable_reg
= 0x36c4,
2502 .enable_mask
= BIT(0),
2503 .hw
.init
= &(struct clk_init_data
){
2504 .name
= "camss_cpp_axi_clk",
2505 .parent_names
= (const char *[]){ "axi_clk_src" },
2507 .flags
= CLK_SET_RATE_PARENT
,
2508 .ops
= &clk_branch2_ops
,
2513 static struct clk_branch camss_cpp_clk
= {
2516 .enable_reg
= 0x36b0,
2517 .enable_mask
= BIT(0),
2518 .hw
.init
= &(struct clk_init_data
){
2519 .name
= "camss_cpp_clk",
2520 .parent_names
= (const char *[]){ "cpp_clk_src" },
2522 .flags
= CLK_SET_RATE_PARENT
,
2523 .ops
= &clk_branch2_ops
,
2528 static struct clk_branch camss_cpp_ahb_clk
= {
2531 .enable_reg
= 0x36b4,
2532 .enable_mask
= BIT(0),
2533 .hw
.init
= &(struct clk_init_data
){
2534 .name
= "camss_cpp_ahb_clk",
2535 .parent_names
= (const char *[]){ "ahb_clk_src" },
2537 .flags
= CLK_SET_RATE_PARENT
,
2538 .ops
= &clk_branch2_ops
,
2543 static struct clk_branch camss_csi0_clk
= {
2546 .enable_reg
= 0x30b4,
2547 .enable_mask
= BIT(0),
2548 .hw
.init
= &(struct clk_init_data
){
2549 .name
= "camss_csi0_clk",
2550 .parent_names
= (const char *[]){ "csi0_clk_src" },
2552 .flags
= CLK_SET_RATE_PARENT
,
2553 .ops
= &clk_branch2_ops
,
2558 static struct clk_branch camss_csi0_ahb_clk
= {
2561 .enable_reg
= 0x30bc,
2562 .enable_mask
= BIT(0),
2563 .hw
.init
= &(struct clk_init_data
){
2564 .name
= "camss_csi0_ahb_clk",
2565 .parent_names
= (const char *[]){ "ahb_clk_src" },
2567 .flags
= CLK_SET_RATE_PARENT
,
2568 .ops
= &clk_branch2_ops
,
2573 static struct clk_branch camss_csi0phy_clk
= {
2576 .enable_reg
= 0x30c4,
2577 .enable_mask
= BIT(0),
2578 .hw
.init
= &(struct clk_init_data
){
2579 .name
= "camss_csi0phy_clk",
2580 .parent_names
= (const char *[]){ "csi0_clk_src" },
2582 .flags
= CLK_SET_RATE_PARENT
,
2583 .ops
= &clk_branch2_ops
,
2588 static struct clk_branch camss_csi0rdi_clk
= {
2591 .enable_reg
= 0x30d4,
2592 .enable_mask
= BIT(0),
2593 .hw
.init
= &(struct clk_init_data
){
2594 .name
= "camss_csi0rdi_clk",
2595 .parent_names
= (const char *[]){ "csi0_clk_src" },
2597 .flags
= CLK_SET_RATE_PARENT
,
2598 .ops
= &clk_branch2_ops
,
2603 static struct clk_branch camss_csi0pix_clk
= {
2606 .enable_reg
= 0x30e4,
2607 .enable_mask
= BIT(0),
2608 .hw
.init
= &(struct clk_init_data
){
2609 .name
= "camss_csi0pix_clk",
2610 .parent_names
= (const char *[]){ "csi0_clk_src" },
2612 .flags
= CLK_SET_RATE_PARENT
,
2613 .ops
= &clk_branch2_ops
,
2618 static struct clk_branch camss_csi1_clk
= {
2621 .enable_reg
= 0x3124,
2622 .enable_mask
= BIT(0),
2623 .hw
.init
= &(struct clk_init_data
){
2624 .name
= "camss_csi1_clk",
2625 .parent_names
= (const char *[]){ "csi1_clk_src" },
2627 .flags
= CLK_SET_RATE_PARENT
,
2628 .ops
= &clk_branch2_ops
,
2633 static struct clk_branch camss_csi1_ahb_clk
= {
2636 .enable_reg
= 0x3128,
2637 .enable_mask
= BIT(0),
2638 .hw
.init
= &(struct clk_init_data
){
2639 .name
= "camss_csi1_ahb_clk",
2640 .parent_names
= (const char *[]){ "ahb_clk_src" },
2642 .flags
= CLK_SET_RATE_PARENT
,
2643 .ops
= &clk_branch2_ops
,
2648 static struct clk_branch camss_csi1phy_clk
= {
2651 .enable_reg
= 0x3134,
2652 .enable_mask
= BIT(0),
2653 .hw
.init
= &(struct clk_init_data
){
2654 .name
= "camss_csi1phy_clk",
2655 .parent_names
= (const char *[]){ "csi1_clk_src" },
2657 .flags
= CLK_SET_RATE_PARENT
,
2658 .ops
= &clk_branch2_ops
,
2663 static struct clk_branch camss_csi1rdi_clk
= {
2666 .enable_reg
= 0x3144,
2667 .enable_mask
= BIT(0),
2668 .hw
.init
= &(struct clk_init_data
){
2669 .name
= "camss_csi1rdi_clk",
2670 .parent_names
= (const char *[]){ "csi1_clk_src" },
2672 .flags
= CLK_SET_RATE_PARENT
,
2673 .ops
= &clk_branch2_ops
,
2678 static struct clk_branch camss_csi1pix_clk
= {
2681 .enable_reg
= 0x3154,
2682 .enable_mask
= BIT(0),
2683 .hw
.init
= &(struct clk_init_data
){
2684 .name
= "camss_csi1pix_clk",
2685 .parent_names
= (const char *[]){ "csi1_clk_src" },
2687 .flags
= CLK_SET_RATE_PARENT
,
2688 .ops
= &clk_branch2_ops
,
2693 static struct clk_branch camss_csi2_clk
= {
2696 .enable_reg
= 0x3184,
2697 .enable_mask
= BIT(0),
2698 .hw
.init
= &(struct clk_init_data
){
2699 .name
= "camss_csi2_clk",
2700 .parent_names
= (const char *[]){ "csi2_clk_src" },
2702 .flags
= CLK_SET_RATE_PARENT
,
2703 .ops
= &clk_branch2_ops
,
2708 static struct clk_branch camss_csi2_ahb_clk
= {
2711 .enable_reg
= 0x3188,
2712 .enable_mask
= BIT(0),
2713 .hw
.init
= &(struct clk_init_data
){
2714 .name
= "camss_csi2_ahb_clk",
2715 .parent_names
= (const char *[]){ "ahb_clk_src" },
2717 .flags
= CLK_SET_RATE_PARENT
,
2718 .ops
= &clk_branch2_ops
,
2723 static struct clk_branch camss_csi2phy_clk
= {
2726 .enable_reg
= 0x3194,
2727 .enable_mask
= BIT(0),
2728 .hw
.init
= &(struct clk_init_data
){
2729 .name
= "camss_csi2phy_clk",
2730 .parent_names
= (const char *[]){ "csi2_clk_src" },
2732 .flags
= CLK_SET_RATE_PARENT
,
2733 .ops
= &clk_branch2_ops
,
2738 static struct clk_branch camss_csi2rdi_clk
= {
2741 .enable_reg
= 0x31a4,
2742 .enable_mask
= BIT(0),
2743 .hw
.init
= &(struct clk_init_data
){
2744 .name
= "camss_csi2rdi_clk",
2745 .parent_names
= (const char *[]){ "csi2_clk_src" },
2747 .flags
= CLK_SET_RATE_PARENT
,
2748 .ops
= &clk_branch2_ops
,
2753 static struct clk_branch camss_csi2pix_clk
= {
2756 .enable_reg
= 0x31b4,
2757 .enable_mask
= BIT(0),
2758 .hw
.init
= &(struct clk_init_data
){
2759 .name
= "camss_csi2pix_clk",
2760 .parent_names
= (const char *[]){ "csi2_clk_src" },
2762 .flags
= CLK_SET_RATE_PARENT
,
2763 .ops
= &clk_branch2_ops
,
2768 static struct clk_branch camss_csi3_clk
= {
2771 .enable_reg
= 0x31e4,
2772 .enable_mask
= BIT(0),
2773 .hw
.init
= &(struct clk_init_data
){
2774 .name
= "camss_csi3_clk",
2775 .parent_names
= (const char *[]){ "csi3_clk_src" },
2777 .flags
= CLK_SET_RATE_PARENT
,
2778 .ops
= &clk_branch2_ops
,
2783 static struct clk_branch camss_csi3_ahb_clk
= {
2786 .enable_reg
= 0x31e8,
2787 .enable_mask
= BIT(0),
2788 .hw
.init
= &(struct clk_init_data
){
2789 .name
= "camss_csi3_ahb_clk",
2790 .parent_names
= (const char *[]){ "ahb_clk_src" },
2792 .flags
= CLK_SET_RATE_PARENT
,
2793 .ops
= &clk_branch2_ops
,
2798 static struct clk_branch camss_csi3phy_clk
= {
2801 .enable_reg
= 0x31f4,
2802 .enable_mask
= BIT(0),
2803 .hw
.init
= &(struct clk_init_data
){
2804 .name
= "camss_csi3phy_clk",
2805 .parent_names
= (const char *[]){ "csi3_clk_src" },
2807 .flags
= CLK_SET_RATE_PARENT
,
2808 .ops
= &clk_branch2_ops
,
2813 static struct clk_branch camss_csi3rdi_clk
= {
2816 .enable_reg
= 0x3204,
2817 .enable_mask
= BIT(0),
2818 .hw
.init
= &(struct clk_init_data
){
2819 .name
= "camss_csi3rdi_clk",
2820 .parent_names
= (const char *[]){ "csi3_clk_src" },
2822 .flags
= CLK_SET_RATE_PARENT
,
2823 .ops
= &clk_branch2_ops
,
2828 static struct clk_branch camss_csi3pix_clk
= {
2831 .enable_reg
= 0x3214,
2832 .enable_mask
= BIT(0),
2833 .hw
.init
= &(struct clk_init_data
){
2834 .name
= "camss_csi3pix_clk",
2835 .parent_names
= (const char *[]){ "csi3_clk_src" },
2837 .flags
= CLK_SET_RATE_PARENT
,
2838 .ops
= &clk_branch2_ops
,
2843 static struct clk_branch camss_ispif_ahb_clk
= {
2846 .enable_reg
= 0x3224,
2847 .enable_mask
= BIT(0),
2848 .hw
.init
= &(struct clk_init_data
){
2849 .name
= "camss_ispif_ahb_clk",
2850 .parent_names
= (const char *[]){ "ahb_clk_src" },
2852 .flags
= CLK_SET_RATE_PARENT
,
2853 .ops
= &clk_branch2_ops
,
2858 static struct clk_branch fd_core_clk
= {
2861 .enable_reg
= 0x3b68,
2862 .enable_mask
= BIT(0),
2863 .hw
.init
= &(struct clk_init_data
){
2864 .name
= "fd_core_clk",
2865 .parent_names
= (const char *[]){ "fd_core_clk_src" },
2867 .flags
= CLK_SET_RATE_PARENT
,
2868 .ops
= &clk_branch2_ops
,
2873 static struct clk_branch fd_core_uar_clk
= {
2876 .enable_reg
= 0x3b6c,
2877 .enable_mask
= BIT(0),
2878 .hw
.init
= &(struct clk_init_data
){
2879 .name
= "fd_core_uar_clk",
2880 .parent_names
= (const char *[]){ "fd_core_clk_src" },
2882 .flags
= CLK_SET_RATE_PARENT
,
2883 .ops
= &clk_branch2_ops
,
2888 static struct clk_branch fd_ahb_clk
= {
2889 .halt_reg
= 0x3ba74,
2891 .enable_reg
= 0x3ba74,
2892 .enable_mask
= BIT(0),
2893 .hw
.init
= &(struct clk_init_data
){
2894 .name
= "fd_ahb_clk",
2895 .parent_names
= (const char *[]){ "ahb_clk_src" },
2897 .flags
= CLK_SET_RATE_PARENT
,
2898 .ops
= &clk_branch2_ops
,
2903 static struct clk_hw
*mmcc_msm8996_hws
[] = {
2907 static struct gdsc mmagic_bimc_gdsc
= {
2910 .name
= "mmagic_bimc",
2912 .pwrsts
= PWRSTS_OFF_ON
,
2916 static struct gdsc mmagic_video_gdsc
= {
2918 .gds_hw_ctrl
= 0x120c,
2920 .name
= "mmagic_video",
2922 .pwrsts
= PWRSTS_OFF_ON
,
2923 .flags
= VOTABLE
| ALWAYS_ON
,
2926 static struct gdsc mmagic_mdss_gdsc
= {
2928 .gds_hw_ctrl
= 0x2480,
2930 .name
= "mmagic_mdss",
2932 .pwrsts
= PWRSTS_OFF_ON
,
2933 .flags
= VOTABLE
| ALWAYS_ON
,
2936 static struct gdsc mmagic_camss_gdsc
= {
2938 .gds_hw_ctrl
= 0x3c50,
2940 .name
= "mmagic_camss",
2942 .pwrsts
= PWRSTS_OFF_ON
,
2943 .flags
= VOTABLE
| ALWAYS_ON
,
2946 static struct gdsc venus_gdsc
= {
2948 .cxcs
= (unsigned int []){ 0x1028, 0x1034, 0x1038 },
2953 .parent
= &mmagic_video_gdsc
.pd
,
2954 .pwrsts
= PWRSTS_OFF_ON
,
2957 static struct gdsc venus_core0_gdsc
= {
2959 .cxcs
= (unsigned int []){ 0x1048 },
2962 .name
= "venus_core0",
2964 .parent
= &venus_gdsc
.pd
,
2965 .pwrsts
= PWRSTS_OFF_ON
,
2969 static struct gdsc venus_core1_gdsc
= {
2971 .cxcs
= (unsigned int []){ 0x104c },
2974 .name
= "venus_core1",
2976 .parent
= &venus_gdsc
.pd
,
2977 .pwrsts
= PWRSTS_OFF_ON
,
2981 static struct gdsc camss_gdsc
= {
2983 .cxcs
= (unsigned int []){ 0x36bc, 0x36c4 },
2988 .parent
= &mmagic_camss_gdsc
.pd
,
2989 .pwrsts
= PWRSTS_OFF_ON
,
2992 static struct gdsc vfe0_gdsc
= {
2994 .cxcs
= (unsigned int []){ 0x36a8 },
2999 .parent
= &camss_gdsc
.pd
,
3000 .pwrsts
= PWRSTS_OFF_ON
,
3003 static struct gdsc vfe1_gdsc
= {
3005 .cxcs
= (unsigned int []){ 0x36ac },
3010 .parent
= &camss_gdsc
.pd
,
3011 .pwrsts
= PWRSTS_OFF_ON
,
3014 static struct gdsc jpeg_gdsc
= {
3016 .cxcs
= (unsigned int []){ 0x35a8, 0x35b0, 0x35c0, 0x35b8 },
3021 .parent
= &camss_gdsc
.pd
,
3022 .pwrsts
= PWRSTS_OFF_ON
,
3025 static struct gdsc cpp_gdsc
= {
3027 .cxcs
= (unsigned int []){ 0x36b0 },
3032 .parent
= &camss_gdsc
.pd
,
3033 .pwrsts
= PWRSTS_OFF_ON
,
3036 static struct gdsc fd_gdsc
= {
3038 .cxcs
= (unsigned int []){ 0x3b68, 0x3b6c },
3043 .parent
= &camss_gdsc
.pd
,
3044 .pwrsts
= PWRSTS_OFF_ON
,
3047 static struct gdsc mdss_gdsc
= {
3049 .cxcs
= (unsigned int []){ 0x2310, 0x231c },
3054 .parent
= &mmagic_mdss_gdsc
.pd
,
3055 .pwrsts
= PWRSTS_OFF_ON
,
3058 static struct gdsc gpu_gdsc
= {
3060 .gds_hw_ctrl
= 0x4038,
3064 .pwrsts
= PWRSTS_OFF_ON
,
3068 static struct gdsc gpu_gx_gdsc
= {
3070 .clamp_io_ctrl
= 0x4300,
3071 .cxcs
= (unsigned int []){ 0x4028 },
3076 .pwrsts
= PWRSTS_OFF_ON
,
3080 static struct clk_regmap
*mmcc_msm8996_clocks
[] = {
3081 [MMPLL0_EARLY
] = &mmpll0_early
.clkr
,
3082 [MMPLL0_PLL
] = &mmpll0
.clkr
,
3083 [MMPLL1_EARLY
] = &mmpll1_early
.clkr
,
3084 [MMPLL1_PLL
] = &mmpll1
.clkr
,
3085 [MMPLL2_EARLY
] = &mmpll2_early
.clkr
,
3086 [MMPLL2_PLL
] = &mmpll2
.clkr
,
3087 [MMPLL3_EARLY
] = &mmpll3_early
.clkr
,
3088 [MMPLL3_PLL
] = &mmpll3
.clkr
,
3089 [MMPLL4_EARLY
] = &mmpll4_early
.clkr
,
3090 [MMPLL4_PLL
] = &mmpll4
.clkr
,
3091 [MMPLL5_EARLY
] = &mmpll5_early
.clkr
,
3092 [MMPLL5_PLL
] = &mmpll5
.clkr
,
3093 [MMPLL8_EARLY
] = &mmpll8_early
.clkr
,
3094 [MMPLL8_PLL
] = &mmpll8
.clkr
,
3095 [MMPLL9_EARLY
] = &mmpll9_early
.clkr
,
3096 [MMPLL9_PLL
] = &mmpll9
.clkr
,
3097 [AHB_CLK_SRC
] = &ahb_clk_src
.clkr
,
3098 [AXI_CLK_SRC
] = &axi_clk_src
.clkr
,
3099 [MAXI_CLK_SRC
] = &maxi_clk_src
.clkr
,
3100 [GFX3D_CLK_SRC
] = &gfx3d_clk_src
.clkr
,
3101 [RBBMTIMER_CLK_SRC
] = &rbbmtimer_clk_src
.clkr
,
3102 [ISENSE_CLK_SRC
] = &isense_clk_src
.clkr
,
3103 [RBCPR_CLK_SRC
] = &rbcpr_clk_src
.clkr
,
3104 [VIDEO_CORE_CLK_SRC
] = &video_core_clk_src
.clkr
,
3105 [VIDEO_SUBCORE0_CLK_SRC
] = &video_subcore0_clk_src
.clkr
,
3106 [VIDEO_SUBCORE1_CLK_SRC
] = &video_subcore1_clk_src
.clkr
,
3107 [PCLK0_CLK_SRC
] = &pclk0_clk_src
.clkr
,
3108 [PCLK1_CLK_SRC
] = &pclk1_clk_src
.clkr
,
3109 [MDP_CLK_SRC
] = &mdp_clk_src
.clkr
,
3110 [EXTPCLK_CLK_SRC
] = &extpclk_clk_src
.clkr
,
3111 [VSYNC_CLK_SRC
] = &vsync_clk_src
.clkr
,
3112 [HDMI_CLK_SRC
] = &hdmi_clk_src
.clkr
,
3113 [BYTE0_CLK_SRC
] = &byte0_clk_src
.clkr
,
3114 [BYTE1_CLK_SRC
] = &byte1_clk_src
.clkr
,
3115 [ESC0_CLK_SRC
] = &esc0_clk_src
.clkr
,
3116 [ESC1_CLK_SRC
] = &esc1_clk_src
.clkr
,
3117 [CAMSS_GP0_CLK_SRC
] = &camss_gp0_clk_src
.clkr
,
3118 [CAMSS_GP1_CLK_SRC
] = &camss_gp1_clk_src
.clkr
,
3119 [MCLK0_CLK_SRC
] = &mclk0_clk_src
.clkr
,
3120 [MCLK1_CLK_SRC
] = &mclk1_clk_src
.clkr
,
3121 [MCLK2_CLK_SRC
] = &mclk2_clk_src
.clkr
,
3122 [MCLK3_CLK_SRC
] = &mclk3_clk_src
.clkr
,
3123 [CCI_CLK_SRC
] = &cci_clk_src
.clkr
,
3124 [CSI0PHYTIMER_CLK_SRC
] = &csi0phytimer_clk_src
.clkr
,
3125 [CSI1PHYTIMER_CLK_SRC
] = &csi1phytimer_clk_src
.clkr
,
3126 [CSI2PHYTIMER_CLK_SRC
] = &csi2phytimer_clk_src
.clkr
,
3127 [CSIPHY0_3P_CLK_SRC
] = &csiphy0_3p_clk_src
.clkr
,
3128 [CSIPHY1_3P_CLK_SRC
] = &csiphy1_3p_clk_src
.clkr
,
3129 [CSIPHY2_3P_CLK_SRC
] = &csiphy2_3p_clk_src
.clkr
,
3130 [JPEG0_CLK_SRC
] = &jpeg0_clk_src
.clkr
,
3131 [JPEG2_CLK_SRC
] = &jpeg2_clk_src
.clkr
,
3132 [JPEG_DMA_CLK_SRC
] = &jpeg_dma_clk_src
.clkr
,
3133 [VFE0_CLK_SRC
] = &vfe0_clk_src
.clkr
,
3134 [VFE1_CLK_SRC
] = &vfe1_clk_src
.clkr
,
3135 [CPP_CLK_SRC
] = &cpp_clk_src
.clkr
,
3136 [CSI0_CLK_SRC
] = &csi0_clk_src
.clkr
,
3137 [CSI1_CLK_SRC
] = &csi1_clk_src
.clkr
,
3138 [CSI2_CLK_SRC
] = &csi2_clk_src
.clkr
,
3139 [CSI3_CLK_SRC
] = &csi3_clk_src
.clkr
,
3140 [FD_CORE_CLK_SRC
] = &fd_core_clk_src
.clkr
,
3141 [MMSS_MMAGIC_AHB_CLK
] = &mmss_mmagic_ahb_clk
.clkr
,
3142 [MMSS_MMAGIC_CFG_AHB_CLK
] = &mmss_mmagic_cfg_ahb_clk
.clkr
,
3143 [MMSS_MISC_AHB_CLK
] = &mmss_misc_ahb_clk
.clkr
,
3144 [MMSS_MISC_CXO_CLK
] = &mmss_misc_cxo_clk
.clkr
,
3145 [MMSS_MMAGIC_MAXI_CLK
] = &mmss_mmagic_maxi_clk
.clkr
,
3146 [MMAGIC_CAMSS_AXI_CLK
] = &mmagic_camss_axi_clk
.clkr
,
3147 [MMAGIC_CAMSS_NOC_CFG_AHB_CLK
] = &mmagic_camss_noc_cfg_ahb_clk
.clkr
,
3148 [SMMU_VFE_AHB_CLK
] = &smmu_vfe_ahb_clk
.clkr
,
3149 [SMMU_VFE_AXI_CLK
] = &smmu_vfe_axi_clk
.clkr
,
3150 [SMMU_CPP_AHB_CLK
] = &smmu_cpp_ahb_clk
.clkr
,
3151 [SMMU_CPP_AXI_CLK
] = &smmu_cpp_axi_clk
.clkr
,
3152 [SMMU_JPEG_AHB_CLK
] = &smmu_jpeg_ahb_clk
.clkr
,
3153 [SMMU_JPEG_AXI_CLK
] = &smmu_jpeg_axi_clk
.clkr
,
3154 [MMAGIC_MDSS_AXI_CLK
] = &mmagic_mdss_axi_clk
.clkr
,
3155 [MMAGIC_MDSS_NOC_CFG_AHB_CLK
] = &mmagic_mdss_noc_cfg_ahb_clk
.clkr
,
3156 [SMMU_ROT_AHB_CLK
] = &smmu_rot_ahb_clk
.clkr
,
3157 [SMMU_ROT_AXI_CLK
] = &smmu_rot_axi_clk
.clkr
,
3158 [SMMU_MDP_AHB_CLK
] = &smmu_mdp_ahb_clk
.clkr
,
3159 [SMMU_MDP_AXI_CLK
] = &smmu_mdp_axi_clk
.clkr
,
3160 [MMAGIC_VIDEO_AXI_CLK
] = &mmagic_video_axi_clk
.clkr
,
3161 [MMAGIC_VIDEO_NOC_CFG_AHB_CLK
] = &mmagic_video_noc_cfg_ahb_clk
.clkr
,
3162 [SMMU_VIDEO_AHB_CLK
] = &smmu_video_ahb_clk
.clkr
,
3163 [SMMU_VIDEO_AXI_CLK
] = &smmu_video_axi_clk
.clkr
,
3164 [MMAGIC_BIMC_NOC_CFG_AHB_CLK
] = &mmagic_bimc_noc_cfg_ahb_clk
.clkr
,
3165 [GPU_GX_GFX3D_CLK
] = &gpu_gx_gfx3d_clk
.clkr
,
3166 [GPU_GX_RBBMTIMER_CLK
] = &gpu_gx_rbbmtimer_clk
.clkr
,
3167 [GPU_AHB_CLK
] = &gpu_ahb_clk
.clkr
,
3168 [GPU_AON_ISENSE_CLK
] = &gpu_aon_isense_clk
.clkr
,
3169 [VMEM_MAXI_CLK
] = &vmem_maxi_clk
.clkr
,
3170 [VMEM_AHB_CLK
] = &vmem_ahb_clk
.clkr
,
3171 [MMSS_RBCPR_CLK
] = &mmss_rbcpr_clk
.clkr
,
3172 [MMSS_RBCPR_AHB_CLK
] = &mmss_rbcpr_ahb_clk
.clkr
,
3173 [VIDEO_CORE_CLK
] = &video_core_clk
.clkr
,
3174 [VIDEO_AXI_CLK
] = &video_axi_clk
.clkr
,
3175 [VIDEO_MAXI_CLK
] = &video_maxi_clk
.clkr
,
3176 [VIDEO_AHB_CLK
] = &video_ahb_clk
.clkr
,
3177 [VIDEO_SUBCORE0_CLK
] = &video_subcore0_clk
.clkr
,
3178 [VIDEO_SUBCORE1_CLK
] = &video_subcore1_clk
.clkr
,
3179 [MDSS_AHB_CLK
] = &mdss_ahb_clk
.clkr
,
3180 [MDSS_HDMI_AHB_CLK
] = &mdss_hdmi_ahb_clk
.clkr
,
3181 [MDSS_AXI_CLK
] = &mdss_axi_clk
.clkr
,
3182 [MDSS_PCLK0_CLK
] = &mdss_pclk0_clk
.clkr
,
3183 [MDSS_PCLK1_CLK
] = &mdss_pclk1_clk
.clkr
,
3184 [MDSS_MDP_CLK
] = &mdss_mdp_clk
.clkr
,
3185 [MDSS_EXTPCLK_CLK
] = &mdss_extpclk_clk
.clkr
,
3186 [MDSS_VSYNC_CLK
] = &mdss_vsync_clk
.clkr
,
3187 [MDSS_HDMI_CLK
] = &mdss_hdmi_clk
.clkr
,
3188 [MDSS_BYTE0_CLK
] = &mdss_byte0_clk
.clkr
,
3189 [MDSS_BYTE1_CLK
] = &mdss_byte1_clk
.clkr
,
3190 [MDSS_ESC0_CLK
] = &mdss_esc0_clk
.clkr
,
3191 [MDSS_ESC1_CLK
] = &mdss_esc1_clk
.clkr
,
3192 [CAMSS_TOP_AHB_CLK
] = &camss_top_ahb_clk
.clkr
,
3193 [CAMSS_AHB_CLK
] = &camss_ahb_clk
.clkr
,
3194 [CAMSS_MICRO_AHB_CLK
] = &camss_micro_ahb_clk
.clkr
,
3195 [CAMSS_GP0_CLK
] = &camss_gp0_clk
.clkr
,
3196 [CAMSS_GP1_CLK
] = &camss_gp1_clk
.clkr
,
3197 [CAMSS_MCLK0_CLK
] = &camss_mclk0_clk
.clkr
,
3198 [CAMSS_MCLK1_CLK
] = &camss_mclk1_clk
.clkr
,
3199 [CAMSS_MCLK2_CLK
] = &camss_mclk2_clk
.clkr
,
3200 [CAMSS_MCLK3_CLK
] = &camss_mclk3_clk
.clkr
,
3201 [CAMSS_CCI_CLK
] = &camss_cci_clk
.clkr
,
3202 [CAMSS_CCI_AHB_CLK
] = &camss_cci_ahb_clk
.clkr
,
3203 [CAMSS_CSI0PHYTIMER_CLK
] = &camss_csi0phytimer_clk
.clkr
,
3204 [CAMSS_CSI1PHYTIMER_CLK
] = &camss_csi1phytimer_clk
.clkr
,
3205 [CAMSS_CSI2PHYTIMER_CLK
] = &camss_csi2phytimer_clk
.clkr
,
3206 [CAMSS_CSIPHY0_3P_CLK
] = &camss_csiphy0_3p_clk
.clkr
,
3207 [CAMSS_CSIPHY1_3P_CLK
] = &camss_csiphy1_3p_clk
.clkr
,
3208 [CAMSS_CSIPHY2_3P_CLK
] = &camss_csiphy2_3p_clk
.clkr
,
3209 [CAMSS_JPEG0_CLK
] = &camss_jpeg0_clk
.clkr
,
3210 [CAMSS_JPEG2_CLK
] = &camss_jpeg2_clk
.clkr
,
3211 [CAMSS_JPEG_DMA_CLK
] = &camss_jpeg_dma_clk
.clkr
,
3212 [CAMSS_JPEG_AHB_CLK
] = &camss_jpeg_ahb_clk
.clkr
,
3213 [CAMSS_JPEG_AXI_CLK
] = &camss_jpeg_axi_clk
.clkr
,
3214 [CAMSS_VFE_AHB_CLK
] = &camss_vfe_ahb_clk
.clkr
,
3215 [CAMSS_VFE_AXI_CLK
] = &camss_vfe_axi_clk
.clkr
,
3216 [CAMSS_VFE0_CLK
] = &camss_vfe0_clk
.clkr
,
3217 [CAMSS_VFE0_STREAM_CLK
] = &camss_vfe0_stream_clk
.clkr
,
3218 [CAMSS_VFE0_AHB_CLK
] = &camss_vfe0_ahb_clk
.clkr
,
3219 [CAMSS_VFE1_CLK
] = &camss_vfe1_clk
.clkr
,
3220 [CAMSS_VFE1_STREAM_CLK
] = &camss_vfe1_stream_clk
.clkr
,
3221 [CAMSS_VFE1_AHB_CLK
] = &camss_vfe1_ahb_clk
.clkr
,
3222 [CAMSS_CSI_VFE0_CLK
] = &camss_csi_vfe0_clk
.clkr
,
3223 [CAMSS_CSI_VFE1_CLK
] = &camss_csi_vfe1_clk
.clkr
,
3224 [CAMSS_CPP_VBIF_AHB_CLK
] = &camss_cpp_vbif_ahb_clk
.clkr
,
3225 [CAMSS_CPP_AXI_CLK
] = &camss_cpp_axi_clk
.clkr
,
3226 [CAMSS_CPP_CLK
] = &camss_cpp_clk
.clkr
,
3227 [CAMSS_CPP_AHB_CLK
] = &camss_cpp_ahb_clk
.clkr
,
3228 [CAMSS_CSI0_CLK
] = &camss_csi0_clk
.clkr
,
3229 [CAMSS_CSI0_AHB_CLK
] = &camss_csi0_ahb_clk
.clkr
,
3230 [CAMSS_CSI0PHY_CLK
] = &camss_csi0phy_clk
.clkr
,
3231 [CAMSS_CSI0RDI_CLK
] = &camss_csi0rdi_clk
.clkr
,
3232 [CAMSS_CSI0PIX_CLK
] = &camss_csi0pix_clk
.clkr
,
3233 [CAMSS_CSI1_CLK
] = &camss_csi1_clk
.clkr
,
3234 [CAMSS_CSI1_AHB_CLK
] = &camss_csi1_ahb_clk
.clkr
,
3235 [CAMSS_CSI1PHY_CLK
] = &camss_csi1phy_clk
.clkr
,
3236 [CAMSS_CSI1RDI_CLK
] = &camss_csi1rdi_clk
.clkr
,
3237 [CAMSS_CSI1PIX_CLK
] = &camss_csi1pix_clk
.clkr
,
3238 [CAMSS_CSI2_CLK
] = &camss_csi2_clk
.clkr
,
3239 [CAMSS_CSI2_AHB_CLK
] = &camss_csi2_ahb_clk
.clkr
,
3240 [CAMSS_CSI2PHY_CLK
] = &camss_csi2phy_clk
.clkr
,
3241 [CAMSS_CSI2RDI_CLK
] = &camss_csi2rdi_clk
.clkr
,
3242 [CAMSS_CSI2PIX_CLK
] = &camss_csi2pix_clk
.clkr
,
3243 [CAMSS_CSI3_CLK
] = &camss_csi3_clk
.clkr
,
3244 [CAMSS_CSI3_AHB_CLK
] = &camss_csi3_ahb_clk
.clkr
,
3245 [CAMSS_CSI3PHY_CLK
] = &camss_csi3phy_clk
.clkr
,
3246 [CAMSS_CSI3RDI_CLK
] = &camss_csi3rdi_clk
.clkr
,
3247 [CAMSS_CSI3PIX_CLK
] = &camss_csi3pix_clk
.clkr
,
3248 [CAMSS_ISPIF_AHB_CLK
] = &camss_ispif_ahb_clk
.clkr
,
3249 [FD_CORE_CLK
] = &fd_core_clk
.clkr
,
3250 [FD_CORE_UAR_CLK
] = &fd_core_uar_clk
.clkr
,
3251 [FD_AHB_CLK
] = &fd_ahb_clk
.clkr
,
3254 static struct gdsc
*mmcc_msm8996_gdscs
[] = {
3255 [MMAGIC_BIMC_GDSC
] = &mmagic_bimc_gdsc
,
3256 [MMAGIC_VIDEO_GDSC
] = &mmagic_video_gdsc
,
3257 [MMAGIC_MDSS_GDSC
] = &mmagic_mdss_gdsc
,
3258 [MMAGIC_CAMSS_GDSC
] = &mmagic_camss_gdsc
,
3259 [VENUS_GDSC
] = &venus_gdsc
,
3260 [VENUS_CORE0_GDSC
] = &venus_core0_gdsc
,
3261 [VENUS_CORE1_GDSC
] = &venus_core1_gdsc
,
3262 [CAMSS_GDSC
] = &camss_gdsc
,
3263 [VFE0_GDSC
] = &vfe0_gdsc
,
3264 [VFE1_GDSC
] = &vfe1_gdsc
,
3265 [JPEG_GDSC
] = &jpeg_gdsc
,
3266 [CPP_GDSC
] = &cpp_gdsc
,
3267 [FD_GDSC
] = &fd_gdsc
,
3268 [MDSS_GDSC
] = &mdss_gdsc
,
3269 [GPU_GDSC
] = &gpu_gdsc
,
3270 [GPU_GX_GDSC
] = &gpu_gx_gdsc
,
3273 static const struct qcom_reset_map mmcc_msm8996_resets
[] = {
3274 [MMAGICAHB_BCR
] = { 0x5020 },
3275 [MMAGIC_CFG_BCR
] = { 0x5050 },
3276 [MISC_BCR
] = { 0x5010 },
3277 [BTO_BCR
] = { 0x5030 },
3278 [MMAGICAXI_BCR
] = { 0x5060 },
3279 [MMAGICMAXI_BCR
] = { 0x5070 },
3280 [DSA_BCR
] = { 0x50a0 },
3281 [MMAGIC_CAMSS_BCR
] = { 0x3c40 },
3282 [THROTTLE_CAMSS_BCR
] = { 0x3c30 },
3283 [SMMU_VFE_BCR
] = { 0x3c00 },
3284 [SMMU_CPP_BCR
] = { 0x3c10 },
3285 [SMMU_JPEG_BCR
] = { 0x3c20 },
3286 [MMAGIC_MDSS_BCR
] = { 0x2470 },
3287 [THROTTLE_MDSS_BCR
] = { 0x2460 },
3288 [SMMU_ROT_BCR
] = { 0x2440 },
3289 [SMMU_MDP_BCR
] = { 0x2450 },
3290 [MMAGIC_VIDEO_BCR
] = { 0x1190 },
3291 [THROTTLE_VIDEO_BCR
] = { 0x1180 },
3292 [SMMU_VIDEO_BCR
] = { 0x1170 },
3293 [MMAGIC_BIMC_BCR
] = { 0x5290 },
3294 [GPU_GX_BCR
] = { 0x4020 },
3295 [GPU_BCR
] = { 0x4030 },
3296 [GPU_AON_BCR
] = { 0x4040 },
3297 [VMEM_BCR
] = { 0x1200 },
3298 [MMSS_RBCPR_BCR
] = { 0x4080 },
3299 [VIDEO_BCR
] = { 0x1020 },
3300 [MDSS_BCR
] = { 0x2300 },
3301 [CAMSS_TOP_BCR
] = { 0x3480 },
3302 [CAMSS_AHB_BCR
] = { 0x3488 },
3303 [CAMSS_MICRO_BCR
] = { 0x3490 },
3304 [CAMSS_CCI_BCR
] = { 0x3340 },
3305 [CAMSS_PHY0_BCR
] = { 0x3020 },
3306 [CAMSS_PHY1_BCR
] = { 0x3050 },
3307 [CAMSS_PHY2_BCR
] = { 0x3080 },
3308 [CAMSS_CSIPHY0_3P_BCR
] = { 0x3230 },
3309 [CAMSS_CSIPHY1_3P_BCR
] = { 0x3250 },
3310 [CAMSS_CSIPHY2_3P_BCR
] = { 0x3270 },
3311 [CAMSS_JPEG_BCR
] = { 0x35a0 },
3312 [CAMSS_VFE_BCR
] = { 0x36a0 },
3313 [CAMSS_VFE0_BCR
] = { 0x3660 },
3314 [CAMSS_VFE1_BCR
] = { 0x3670 },
3315 [CAMSS_CSI_VFE0_BCR
] = { 0x3700 },
3316 [CAMSS_CSI_VFE1_BCR
] = { 0x3710 },
3317 [CAMSS_CPP_TOP_BCR
] = { 0x36c0 },
3318 [CAMSS_CPP_BCR
] = { 0x36d0 },
3319 [CAMSS_CSI0_BCR
] = { 0x30b0 },
3320 [CAMSS_CSI0RDI_BCR
] = { 0x30d0 },
3321 [CAMSS_CSI0PIX_BCR
] = { 0x30e0 },
3322 [CAMSS_CSI1_BCR
] = { 0x3120 },
3323 [CAMSS_CSI1RDI_BCR
] = { 0x3140 },
3324 [CAMSS_CSI1PIX_BCR
] = { 0x3150 },
3325 [CAMSS_CSI2_BCR
] = { 0x3180 },
3326 [CAMSS_CSI2RDI_BCR
] = { 0x31a0 },
3327 [CAMSS_CSI2PIX_BCR
] = { 0x31b0 },
3328 [CAMSS_CSI3_BCR
] = { 0x31e0 },
3329 [CAMSS_CSI3RDI_BCR
] = { 0x3200 },
3330 [CAMSS_CSI3PIX_BCR
] = { 0x3210 },
3331 [CAMSS_ISPIF_BCR
] = { 0x3220 },
3332 [FD_BCR
] = { 0x3b60 },
3333 [MMSS_SPDM_RM_BCR
] = { 0x300 },
3336 static const struct regmap_config mmcc_msm8996_regmap_config
= {
3340 .max_register
= 0xb008,
3344 static const struct qcom_cc_desc mmcc_msm8996_desc
= {
3345 .config
= &mmcc_msm8996_regmap_config
,
3346 .clks
= mmcc_msm8996_clocks
,
3347 .num_clks
= ARRAY_SIZE(mmcc_msm8996_clocks
),
3348 .resets
= mmcc_msm8996_resets
,
3349 .num_resets
= ARRAY_SIZE(mmcc_msm8996_resets
),
3350 .gdscs
= mmcc_msm8996_gdscs
,
3351 .num_gdscs
= ARRAY_SIZE(mmcc_msm8996_gdscs
),
3354 static const struct of_device_id mmcc_msm8996_match_table
[] = {
3355 { .compatible
= "qcom,mmcc-msm8996" },
3358 MODULE_DEVICE_TABLE(of
, mmcc_msm8996_match_table
);
3360 static int mmcc_msm8996_probe(struct platform_device
*pdev
)
3362 struct device
*dev
= &pdev
->dev
;
3364 struct regmap
*regmap
;
3366 regmap
= qcom_cc_map(pdev
, &mmcc_msm8996_desc
);
3368 return PTR_ERR(regmap
);
3370 /* Disable the AHB DCD */
3371 regmap_update_bits(regmap
, 0x50d8, BIT(31), 0);
3372 /* Disable the NoC FSM for mmss_mmagic_cfg_ahb_clk */
3373 regmap_update_bits(regmap
, 0x5054, BIT(15), 0);
3375 for (i
= 0; i
< ARRAY_SIZE(mmcc_msm8996_hws
); i
++) {
3376 ret
= devm_clk_hw_register(dev
, mmcc_msm8996_hws
[i
]);
3381 return qcom_cc_really_probe(pdev
, &mmcc_msm8996_desc
, regmap
);
3384 static struct platform_driver mmcc_msm8996_driver
= {
3385 .probe
= mmcc_msm8996_probe
,
3387 .name
= "mmcc-msm8996",
3388 .of_match_table
= mmcc_msm8996_match_table
,
3391 module_platform_driver(mmcc_msm8996_driver
);
3393 MODULE_DESCRIPTION("QCOM MMCC MSM8996 Driver");
3394 MODULE_LICENSE("GPL v2");
3395 MODULE_ALIAS("platform:mmcc-msm8996");